一丶is 和 == 的区别

  == 比较的是值

  is 比较的是内存地址

#字符串
a = "abc"
b = "abc"
print(a == b)
print(a is b)

#数字
a = 123
b = 123
print(a == b)
print(a is b)

# 字典
a = {"a":1,"b":2,"c":3}
b = {"a":1,"b":2,"c":3}
print(a == b)
print(a is b)
print(id(a))
print(id(b))

#元组
a = (1,"a","b")
b = (1,"a","b")
print(a == b)
print(a is b)
print(id(a))
print(id(b))

#列表
a = [1,"a","b"]
b = [1,"a","b"]
print(a == b)
print(a is b)
print(id(a))
print(id(b))

二丶id() 和小数据池

  id()是查看内存地址的

a = 123
print(id(a))

⼩数据池(常量池): 把我们使⽤过的值存储在⼩数据池中.供其他的变量使⽤.

注:在python中一般的字符串都是会被缓存的,为了节约内存

⼩数据池给数字和字符串使⽤, 其他数据类型不存在

对于数字: -5~256是会被加到⼩数据池中的. 每次使⽤都是同⼀个对象.
对于字符串:

  1. 如果是纯⽂字信息和下划线. 那么这个对象会被添加到⼩数据池

  2. 如果是带有特殊字符的. 那么不会被添加到⼩数据池. 每次都是新的

  3. 如果是单⼀字⺟*n的情况. 'a'*20, 在20个单位内是可以的. 超过20个单位就不会添加到⼩数据池中

三丶编码的补充

  ascii 码:

     不支持中文

     支持 英文 数字 符号

     8位   一个字符

  gbk码  国标码:

     支持 中文,英文,数字,符号

     英文  16位  二个字节

     中文  16位  二个字节

  unicode  万国码:

     支持 中文,英文,数字,符号

     英文 32位  四个字节

     中文 32位  四个字节

  utf-8  长度可变的万国码 :

     最少用8位

     英文  8位 一个字节

     中文  24位  三个字节

  Python3中 程序运行阶段 使用的是unicode  显示所有的内容

  bytes类型

    传输和存储都是使用bytes

  pycharm  存储的时候默认是使用utf-8

 编码和解码:

  encode(编码方式) -----拿到明文编码后对应的字节

  decode(编码方式) -----将编码后的字节解码成对应的明文

s = "饿了吗"
s1 = s.encode("utf-8") #编码 encode(XXX) XXX是指要编码的类型
print(s1)
s2 = s1.decode("utf-8") #解码 decode(XXX) XXX是指要解码的类型
print(s2)

  注意:用什么进行编码就要用什么进行解码  不然会解不开

is 和 == 区别 编码的问题 id()函数的更多相关文章

  1. python基础之小数据池,is和==区别 编码问题

    主要内容 小数据池,is和==区别 编码问题 小数据池 一种缓存机制,也称为驻留机制,是为了能更快提高一些字符串和整数的处理速度is 和 == 的区别 == 主要指对变量值是否相等的判断,只要数值相同 ...

  2. Python id() 函数

    Python id() 函数  Python 内置函数 描述 id() 函数用于获取对象的内存地址. 语法 id 语法: id([object]) 参数说明: object -- 对象. 返回值 返回 ...

  3. Python学习笔记八:文件操作(续),文件编码与解码,函数,递归,函数式编程介绍,高阶函数

    文件操作(续) 获得文件句柄位置,f.tell(),从0开始,按字符数计数 f.read(5),读取5个字符 返回文件句柄到某位置,f.seek(0) 文件在编辑过程中改变编码,f.detech() ...

  4. id函数

    描述 id() 函数用于获取对象的内存地址. 语法 id 语法: id([object]) 参数说明: object -- 对象. 返回值 返回对象的内存地址. 实例 以下实例展示了 id 的使用方法 ...

  5. 通过id()函数学习python的数据存储以及引用方式

    id()函数是python的内置函数,用于获取对象的内存地址. 1.1 可以看出,33被存储在内存地址19877464上,对变量a赋值,实际上是将其指向存储着33的内存地址. 1.2 不仅是数字类型, ...

  6. 【linux开发】IO端口和IO内存的区别及分别使用的函数接口

    IO端口和IO内存的区别及分别使用的函数接口 每个外设都是通过读写其寄存器来控制的.外设寄存器也称为I/O端口,通常包括:控制寄存器.状态寄存器和数据寄存器三大类.根据访问外设寄存器的不同方式,可以把 ...

  7. python2和python3的编码encode解码decode函数

    python比较坑的一个点:意义完全变了的两个函数 首先 常用的编码方式有3种,utf-8:  常用的传输和存储格式,Unicode的一种简化 Unicode:包括了所有可能字符的国际统一编码 GBK ...

  8. python学习日记(python2/3区别补充,is / id/ encode str,bytes)

    python2和python3区别 print python2中,print 是语句 :用法 ---->print '***' python3中,print 是函数:用法----->pri ...

  9. python全栈开发 随笔 'is' 和 == 的比较知识与区别 编码和解码的内容及转换

    python 一. is 和 == 的区别; == 比较的是两边的值. a = 'alex' b = 'alex' print(a = b) #True a = 10 b = 10 print(a = ...

随机推荐

  1. Day05:装饰器,三元表达式,函数的递归,匿名/内置函数,迭代器,模块,开发目录

    上节课复习:1.函数的对象    函数可以被当作数据取处理2.函数嵌套    嵌套调用:在调用一个函数时,函数体代码又调用了其他函数    嵌套定义:在一个函数内部又定义了另一个函数 def foo( ...

  2. __setup宏简介

    内核组件用__setup宏来注册关键字及相关联的处理函数,__setup宏在include/linux/init.h中定义,其原型如下:             __setup(string, fun ...

  3. 项目清理和删除svn信息(转)

    svn信息是根据文件夹里面的 .svn 文件夹保存相关配置的,删除此文件夹即可去掉svn信息: linux下: find . -type d -name ".svn"|xargs ...

  4. Open Live Writer 代码插入插件测试

    #-*-coding:utf-8-*- import urllib import json import sys import ssl ssl._create_default_https_contex ...

  5. CodeForces 1109F. Sasha and Algorithm of Silence's Sounds

    题目简述:给定一个$n \times m$的二维矩阵$a[i][j]$,其中$1 \leq nm \leq 2 \times 10^5$,矩阵元素$1 \leq a[i][j] \leq nm$且互不 ...

  6. CF-828B

    B. Black Square time limit per test 1 second memory limit per test 256 megabytes input standard inpu ...

  7. HDU 3549 Flow Problem (最大流ISAP)

    Flow Problem Time Limit: 5000/5000 MS (Java/Others)    Memory Limit: 65535/32768 K (Java/Others)Tota ...

  8. HDU - 5875 Function(预处理)

    Function The shorter, the simpler. With this problem, you should be convinced of this truth.      Yo ...

  9. include跟include_once 以及跟require的区别

    include如果引入两个文件,都有一个相同的函数名,那么就会发生重定义的错误.使用include_once可以避免此错误,一般都_once用的比较多.应该根据实际情况需求include和_once的 ...

  10. Solr 6.7学习笔记(02)-- 配置文件 managed-schema (schema.xml) - Analyzer, tokenizer(4)

    有些时候,我们需要自定义 fieldType.下面的例子就是自定义的 fieldType,<analyzer type="index"> 表示索引时怎么处理,<a ...