zoukankan      html  css  js  c++  java
  • 代码块

    什么是代码块

      在python中代码块指的是

        一个模块,一个函数,一个类,一个文件等都是代码块

      而在用户交互里面,就是cmd中进入python解释器例,每一行代码就是一个代码块.

    is

      is 是比较的两边的内存地址是否相等

    ==

      比较俩边的数值是否相等

    id

      指内存地址,利用id()内置函数去查询一个数据的内存地址

    小数据池(驻留机制,小整数缓存机制)

      是python对内存做的一个优化,对一些常用的数字(整数-5~256),一定规律的字符串提前创建一个小数据池(容器),

      优点:节省内存,在内存级别提高性能与效率,常用的字符串可以直接从小数据池中提用

      缺点:在“池”中创建或插入字符串,整数时,会“相对”花费更多的时间

      int:

        在小数据池中保存的有(-5~256)之间的整数,即之间从小数据池中调用

      str:

      1.对于字符串是ASCII码中的,默认采用小数据池(驻留机制)

        注意:字符串的内容不包括中文,字符串中含有特殊字符的话长度(字符串的长度)只能是1才是True,

      2.对于乘法,如果a = "afhjdhsaflh***"   b = a *1     print(a is b)     输出都是True,即都默认采用驻留机制

         如果是乘于2以上的  即a = "aslfj"*4  b = "aslfj"*4   总长度必须在20以内才是默认采用驻留机制

      指定驻留

    from sys import intern
    a = intern('hello!@'*20)
    b = intern('hello!@'*20)
    print(a is b)
    #指定驻留是你可以指定任意的字符串加入到小数据池中,让其只在内存中创建一个对象,多个变量都是指向这一个字符串。

      bool

        布尔值始终保存在小数据池内

    编码升级

      不同编码直接不可以直接识别,都是进过转化才可以识别的

      网络传输和存储:由于Unicode太占用内存,所以必须以非Unicode的编码进行网络传输或者存储

      在大环境python3x中

        str:字符串的编码是Unicode

        其余都是utf-8

      所以引入了bytes的数据类型概念

      ytes类型和字符串类型是类似关系,字符串类型的内置函数在bytes类型都可以使用。

    而区别是bytes类型没办法以b'中文字符串'的类型存储中文数据,只有字符串可以,并且bytes类型的内存编码方式不是Unicode,所以当字符串需要进行网络传输和存储时必须进行编码,就是把Unicode->其他编码方式进行操作。
    编码及解码:
    str->bytes encode 编码
    bytes->str decode 解码

      

  • 相关阅读:
    Qt BarChart实践
    Qt Charts_Audio实践
    Qt 报错LINK2019:无法解析的外部符号
    Qt Charts实践
    Qt Qwdget 汽车仪表知识点拆解8 淡入效果
    因果图法设计测试用例
    Jsoup获取部分页面数据失败 Unhandled content type. Must be text/*, application/xml, or application/xhtml+xml
    loadrunner入门篇
    如何对jmeter设置IP欺骗
    jmeter录制移动端脚本
  • 原文地址:https://www.cnblogs.com/yuncong/p/9449906.html
Copyright © 2011-2022 走看看