1.在函数内部内部修改全局变量
需要在函数的内部声明一下,利用global关键字
2,能用自带的函数就别自己写,你自己写的执行的效率基本上比自带的函数低
3, 字典的基本操作很重要
删除字典中的键
del dict[key]
合并字典
dict1.update(dict2)
添加新的键值对
dict1[key1]=value1
4.python 中的GIL
GIL 是python的全局解释器锁,同一进程中假如有多个线程运行,一个线程在运行python程序的时候会霸占python解释器(加了一把锁即GIL),使该进程内的其他线程无法运行,等该线程运行完后其他线程才能运行。如果线程运行过程中遇到耗时操作,则解释器锁解开,使其他线程运行。所以在多线程中,线程的运行仍是有先后顺序的,并不是同时进行。
多进程中因为每个进程都能被系统分配资源,相当于每个进程有了一个python解释器,所以多进程可以实现多个进程的同时运行,缺点是进程系统资源开销大
所以使用python的时候一般是使用多进程加速,多线程加速影响太小
5.python中的列表去重
一般是先转成集合,集合再转回列表
list(set(list_1))
因为集合中的值是唯一的
6.*args, **kwargs是什么意思?
7.python2 中的xrange 与range ,其中range是返回一个列表,比较占内存,而xrange返回的是一个迭代器
在python3中取消掉了原先的range函数,然后只保存下xrange函数,然后将xrange函数改名为range函数
8.一句话解释什么样的语言能够用装饰器?
函数可以作为参数传递的语言,可以使用装饰器
9.面向对象中的__new__和__init__区别
__init__是初始化方法,创建对象后,就立刻被默认调用了,可接收参数,如图
1、__new__至少要有一个参数cls,代表当前类,此参数在实例化时由Python解释器自动识别
2、__new__必须要有返回值,返回实例化出来的实例,这点在自己实现__new__时要特别注意,可以return父类(通过super(当前类名, cls))__new__出来的实例,或者直接是object的__new__出来的实例
3、__init__有一个参数self,就是这个__new__返回的实例,__init__在__new__的基础上可以完成一些其它初始化的动作,__init__不需要返回值
4、如果__new__创建的是当前类的实例,会自动调用__init__函数,通过return语句里面调用的__new__函数的第一个参数是cls来保证是当前类实例,如果是其他类的类名,;那么实际创建返回的就是其他类的实例,其实就不会调用当前类的__init__函数,也不会调用其他类的__init__函数。
10,with方法打开处理文件帮我我们做了什么?
在使用open打开文件进行读写操作的时候,可能会出现一些异常情况,如果按照一般的写法,使用f.open的写法,我们需要使用try,except,finally来进行异常判断,并且文件不论最终遇到什么情况,都需要执行finally f.close()关闭文件操作,清理掉缓存,而使用with方法帮我们实现了finally中的f.close
当然使用with的好处不仅仅是这些,若想深入了解,可以研究with的源码
11.