• 【基础】变量设计机制

    【个人理解】python的变量与C++语言中的指针类似,是指向内存数据的一个引用。变量分为不可变变量string/int/float/tuple和可变变量list/dict。

    对于不可变量如果需要创建的对象的内容(value值)相同,则引用都指向同一个对象,不创建新的内存空间。

    理论上因为定义了值是不可变的。所以如果大家都一样的值,那就指向同一份内存空间好了。显然这么节省内存,避免冗余。

    对于可变量只要创建对象那就是本质是new一个新的内存空间,但是好处是能够修改。即修改对象值不会新开辟对象而是就是在原来内存空间改。

    变量无类型,对象有类型 使用一个变量之前不需要提前声明,只需要在使用的时候赋值。

严格地说明,只有放在内存空间中对象才有类型,而变量是没有类型的。一个变量只能对应只一个对象,一个对象可以对应多个变量。

  • 【基础】深度拷贝实现机制

    【个人理解】深度拷贝是针对可变变量进行内存复制的。机制不清楚。

    浅度拷贝:copy.copy,会创建的一个新的对象,如果是list对象,对于list对象的元素浅拷贝就只会使用原始元素的引用(内存地址)。

    深度拷贝:copy.deepcopy,会创建一个新的对象。如果是list对象,对于list对象的元素,深拷贝都会重新生成一份,而不是简单的使用原始元素的引用。

    对于不可以变的变量对象,不能拷贝,浅度拷贝和深度拷贝都是一样的。

  • new() 与 init()的区别

    【个人理解】init()可以认为是__new__()的包装的外壳,在定义类中必须要定义这个方法,可以传入类对象的属性值。__new__()类对象申请内存空间的方法?

    __new__是类方法,参数中带有cls,代表实例化的类。继承自object的新式类才有__new__。

    __new__必须要有返回值,返回实例化出来的实例,这点在自己实现__new__时要特别注意,可以return父类__new__出来的实例,或者直接是object的__new__出来的实例。

    __init__有一个参数self,就是这个__new__返回的实例,__init__在__new__的基础上可以完成一些其它初始化的动作,__init__不需要返回值

实例化一个类时,__new__是首先被调用的,然后才是__init__调用。

__new__是创建类实例的方法,可以创建单例模式的实例对象生成。__init__是实例创建后的方法。

  • 列表推导和生成器的区别及优劣

    【个人理解】列表推导通过较短的代码(一行)快速生成一个相应的列表变量。生成器是指生成可迭代对象,可迭代对象动态通过next方法生成列表元素。列表推导在内存中生成大量的数据,生成器是动态根据算法纪念性推导算出。

    列表推导的方法是直接在内存中生成对象的数据,这样需要占用内存空间。

    在python中,既可以循环又可以计算的对象成为生成器,生成器实现了迭代器协议,可迭代对象。
g = (i for i in range(10**100))#生成器表达式
l = [i for i in range(10**100)]#列表生成式 print g.__next__()#更省内存,需要一个取一个
print l.__next__()#需要在内存中创建1行10**100列的序列

另外,使用了yield替代return的函数称之为生成器函数。生成器函数和其他函数的执行流程不一样,其他函数是顺序执行,遇到return语句或者最后一行函数语句就结束。在调用生成器运行过程中,每次遇到yield时函数会暂停并保存当前所有的运行信息,返回yield值。并在下一次执行next方法时,从当前位置继续运行。

  • 编码和解码

    【个人理解】编码和解码的问题我认为是一个翻译的问题。unicode是计算机的标准语言,其他的utf-8或者gbk都是不同体系的语言,编码的过程是把unicode翻译到对应体系的语言,解码的过程是把不同的体系语言翻译成unicode的过程。

    参见以前写的博文基于Python的数据分析(2):字符串编码

  • 装饰器、wraps的使用、单例模式

    【个人理解】装饰器是函数或者类的对象的外壳,可以在指定被装饰的函数调用前后加入特定的功能。Python装饰器的作用是提高代码的简洁,降低代码的耦合性,将代码要执行的业务逻辑和公共功能进行分离,业务逻辑通过具体的函数来实现,公共功能(例如日志记录,权限认证,输入检查等等)由装饰器负责,代码耦合性降低的同时复用成都也大大提高。

    在 Python 中,使用关键字 def 和一个函数名以及一个可选的参数列表来定义函数。函数使用 return 关键字来返回值。Python 允许创建内嵌函数。即可以在函数内部声明函数,并且所有的作用域和生命周期规则仍然适用。装饰器其实就是一个以函数作为参数并返回一个替换函数的可执行函数。

    注意:1.@符号是装饰器的语法糖,在定义函数的时候使用,避免再一次赋值操作。2.args 可以表示在调用函数时从迭代器中取出位置参数, 也可以表示在定义函数时接收额外的位置参数。3. kwargs 来表示所有未捕获的关键字参数将会被存储在字典 kwargs。

    除了函数装饰器,还有一个类型叫做类装饰器。
    类装饰器*
    具有灵活度打、高内聚、封装性等优点。使用类装饰器以来内部的__call__方法,当使用语法糖@附加到函数上时,就可以调用此方法。注意带参数和不带参数的两种类装饰器的区别。

#不带参数的类装饰器
class Check(object):
def __init__(self, func):
self.func = func def __call__(self, *args,**kwargs):
print("111111")
self.func(*args,**kwargs)
print("222222") @Check
def param_check(request):
print(request) param_check('hello')
param_check('world') #带参数的类装饰器
class Check(object):
def __init__(self, name):
self.name = name def __call__(self, func):
print ("1111111111") def decorator(*args, **kwargs):
print ("2222222222")
return func(*args, **kwargs)
return decorator @Check('parm')
def param_check():
print('Hello') param_check()
param_check()

Python装饰器(decorator)在实现的时候,被装饰后的函数其实已经是另外一个函数了(函数名等函数属性会发生改变),为了不影响,Python的functools包中提供了一个叫wraps的decorator来消除这样的副作用。写一个decorator的时候,最好在实现之前加上functools的wrap,它能保留原有函数的名称和docstring。

装饰器的单例模式:

def singleton(cls, *args, **kw):
instance={}
def _singleton():
if cls not in instance:
instance[cls]=cls(*args, **kw)
return instance[cls]
return _singleton @singleton
class test_singleton(object):
def __init__(self):
self.num_sum=0
def add(self):
self.num_sum=100
  • 正则表达式

    【个人理解】从文本信息中匹配或者抽取制定规则的信息。

  • 垃圾回收

    【个人理解】内存回收。

    python的内存回收机制是引用计数策略。对Python语言来讲,对象的类型和内存都是在运行时确定的。这也是为什么我们称Python语言为动态类型的原因(这里我们把动态类型可以简单的归结为对变量内存地址的分配是在运行时自动判断变量类型并对变量进行赋值)。

    解释器负责跟踪对象的引用计数,垃圾收集器负责释放内存。

    通过销毁对象的引用,使引用计数减少至 0。

    假设 x = 3,以下情况会使 3 这个整型对象的引用计数减少:

  1. 函数运行结束,所有局部变量都被销毁,对象的引用计数也就随之减少。例如 foo(x) 运行结束,x 被销毁;
  2. 当变量被赋值给另一个对象时,原对象的引用计数也会减少。例如 x = 4,这时候 3 这个对象的引用计数就减 1 了;
  3. 使用 del 删除一个变量也会导致对象引用减少。例如 del x;
  4. 对象从集合对象中移除。例如 lst.remove(x);包含对象的集合对象被销毁。例如 del lst。



    Python的内存机制以金字塔行,-1,-2层主要有操作系统进行操作;第0层是C中的malloc,free等内存分配和释放函数进行操作;第1层和第2层是内存池,有Python的接口函数,PyMem_Malloc函数实现,当对象小于256K时有该层直接分配内存;第3层是最上层,也就是我们对Python对象的直接操作。

    垃圾回收时,Python不能进行其它的任务。频繁的垃圾回收将大大降低Python的工作效率。如果内存中的对象不多,就没有必要总启动垃圾回收。所以,Python只会在特定条件下,自动启动垃圾回收。当Python运行时,会记录其中分配对象(object allocation)和取消分配对象(object deallocation)的次数。当两者的差值高于某个阈值时,垃圾回收才会启动。可以手动启动gc.collect.

    当内存中有不再使用的部分时,垃圾收集器就会把他们清理掉。它会去检查那些引用计数为0的对象,然后清除其在内存的空间。当然除了引用计数为0的会被清除,还有一种情况也会被垃圾收集器清掉:当两个对象相互引用时,他们本身其他的引用已经为0了。垃圾回收机制还有一个循环垃圾回收器, 通过消除引用换的方式释放循环引用对象(a引用b, b引用a, 导致其引用计数永远不为0)。

  • 多进程和多线程

  • 协程

Python学习摘要201802的更多相关文章

  1. 【跟我一起学Python吧】python学习摘要

    开始靖,怒推一篇文章:码农平时应该注意的办公室礼节 学习一门脚本语言是很有必要的,当我们在开发一些简单,快速程序时,脚本语言便有了用武之地,而且还很給力.根据python的介绍,python是一门很简 ...

  2. python学习摘要(3)--字符串处理函数

    python没有字符类型, "字符串" '字符串' '''字符串''' """字符串""" 三引号可以支持字符串跨行 字 ...

  3. python学习摘要(2)--基本数据类型

    python申请存储空间是动态的.变量如同指针一样指向存储空间.多个变量会指向同一个存储空间(节省空间).当变量改变时,原来的地址单元并不会马上释放.(引用计数自行回收) c/c++根基性语言,想要什 ...

  4. python学习摘要(4)--列表简单处理

    列表打印,访问列表元素 alist = [a,b,c,d,e] print(alist) friends_name = ['alex','bill','castle','dale'] c = 1 wh ...

  5. Python学习资料整理以及书籍、开发工具推荐

    我不知道大家学习Python的时候是不是和我一样感觉很无助,不知道在入门或者进阶的时候应该掌握哪些知识点,下面我就梳理下我自己学习Python开 发的过程及资料分享给大家,这些方法资料可能并不适合所有 ...

  6. Python 学习笔记 - 不断更新!

    Python 学习笔记 太久不写python,已经忘记以前学习的时候遇到了那些坑坑洼洼的地方了,开个帖子来记录一下,以供日后查阅. 摘要:一些报错:为啥Python没有自增 ++ 和自减 --: 0x ...

  7. Python 学习书籍推荐

    谁会成为AI 和大数据时代的第一开发语言? 这本已是一个不需要争论的问题.如果说三年前,Matlab.Scala.R.Java 和 Python还各有机会,局面尚且不清楚,那么三年之后,趋势已经非常明 ...

  8. 【old】Python学习笔记

    上学期看视频记得,也没学到多少,目前打算一边通过<Python学习手册 第四版>提高核心语法(太厚了 噗),一边学习Python Web开发 然后这里的多任务编程和网络编程是暑假学的 5. ...

  9. a byte of vim -- 学习摘要

    说在前面的话 -- a byte of vim 是我见过的最介绍vim 最好的书,想了解强大的vim的人,或者是已经在使用vim而打算进一步了解的人,我感觉都应该看看这个,内容精炼但涵盖非常广,--& ...

随机推荐

  1. Linux IPC实践(7) --Posix消息队列

    1. 创建/获取一个消息队列 #include <fcntl.h> /* For O_* constants */ #include <sys/stat.h> /* For m ...

  2. Windows7 64位机上,OpenCV中配置CUDA,实现GPU操作步骤

    原文地址:http://blog.csdn.net/haorenka2010/article/details/24385955 按语:首先感谢http://blog.csdn.net/fengbing ...

  3. 2015年北京的第一场雪-关于android学习的思考(84)

    今天是2015年11月6日,今天北京下了大雪,我听着民谣,发现丢火车的摇滚也还不错,我身体的一部分毛发也发生了变异,由黑色变成红色,一切来的太突然了......不知不觉学习android开发2年多了, ...

  4. Android表格布局(Table Layout)

    Android表格布局(Table Layout) 先来看布局管理器之间继承关系图: 图1 可知TableLayout继承了LinearLayout,所以表格布局本质上依然是线性管理器. 表格布局采用 ...

  5. 《java入门第一季》之面向对象(static关键字)

    /* static的特点:(它可以修饰成员变量,还可以修饰成员方法) A:随着类的加载而加载 回想main方法. B:优先于对象存在 C:被类的所有对象共享 举例:班级的学生应该共用同一个班级编号. ...

  6. java http缓存

    HTTP/1.1中缓存的目的是为了在很多情况下减少发送请求,也即直接返回缓存:同时在许多情况下可以不需要发送完整响应.前者减少了网络回路的数量,挺高响应速度,HTTP利用一个"过期(expi ...

  7. Learning ROS forRobotics Programming Second Edition学习笔记(八)indigo rviz gazebo

    中文译著已经出版,详情请参考:http://blog.csdn.net/ZhangRelay/article/category/6506865 Learning ROS forRobotics Pro ...

  8. 修改Tomcat访问的端口号

    修改Tomcat端口号步骤: 1.找到Tomcat目录下的conf文件夹 2.进入conf文件夹里面找到server.xml文件 3.打开server.xml文件 4.在server.xml文件里面找 ...

  9. OpenCV 金字塔图像缩放

    // image_pyramid.cpp : 定义控制台应用程序的入口点. // #include "stdafx.h" #include <string> #incl ...

  10. linux下D盘(适用于U盘、硬盘等一切移动存储设备)策略(比格式化猛,因为是不可恢复!)

    关于这样的资料,在百度上还是比较少的,今天就共享出来,在电脑主机上插上你的U盘,输入以下命令: dd if=/dev/zero of=/dev/sdb  bs=1024 count=102400   ...