python基础---命名空间与常用函数
一、命名空间
1、什么叫命名空间
从python解释器开始执行之后,就在内存中开辟了一个空间,每当遇到一个变量的时候,就把变量名和值之间的对应关系(值的内存地址)记录下来。
但是当遇到函数定义的时候解释器只是象征性的将函数名读入内存,表示知道这个函数的存在了,至于函数内部的变量和逻辑解释器根本不关心。
等执行到函数调用的时候,python解释器会再开辟一块内存来存储这个函数里的内容,这个时候,才关注函数里面有哪些变量,而函数中的变量会存储在新开辟出来的内存中。函数中的变量只能在函数的内部使用,并且会随着函数执行完毕,这块内存中的所有内容也会被清空。
我们给这个“存放名字与值的关系”的空间起了一个名字——叫做命名空间
代码在运行伊始,创建的存储“变量名与值的关系”的空间叫做全局命名空间,在函数的运行中开辟的临时的空间叫做局部命名空间
2、命名空间变量访问的规则
一共有三种命名空间从大范围到小范围的顺序:内置命名空间、全局命名空间、局部命名空间作用域(包括函数的作用域链)。变量访问的三个原则:
小范围的可以用大范围的,但是大范围的不能用小范围的
在小范围内,如果要用一个变量,是当前这个小范围有的,就用自己的,如果在小范围内没有,就用上一级的,上一级没有就用上上一级的,以此类推。如果都没有,报错
如果是对变量进行赋值,相当于新开一块空间,与外部变量无关。如,list1=list1+[],虽然右边的list1可能是上一级的,但赋值后,新的list1已经与上一级没有关系了。
二、函数:
1、函数的基本概念
函数名的本质:就是一个变量,保存了函数所在的内存地址
嵌套定义:定义在内部的函数无法直接在全局被调用,如需要调用,可以用return返回
闭包:内部函数包含对外部作用域而非全剧作用域名字的引用,该内部函数称为闭包函数,实际上,闭包是将对个部作用域引用地址存在了closure中,可以通过 .closure[0].cell_contents 获得值
def func():
name = 'eva'
x='x'
print 'name id:%x' % (id(name),), 'x id:%x' % (id(x),) # name id:300de40 x id:2a87a30
def inner():
print name
print x
return inner
f = func()
print f.__closure__ # (<cell at 0x0000000002F7F0A8: str object at 0x000000000300DE40>, <cell at 0x0000000002F7F618: str object at 0x0000000002A87A30>)
g= f.__closure__[0] # __closure__是一个元组,
print g.cell_contents # 获取内容
2、递归函数
递归的定义——在一个函数里再调用这个函数本身
递归的最大深度——997。因为每一次函数调用都会产生一个属于它自己的名称空间,如果一直调用下去,就会造成名称空间占用太多内存的问题,于是python强制的将递归层数控制在了997,可以通过sys.setrecursionlimit(100000)进行修改
3、函数装饰器
装饰器的本质:一个闭包函数
装饰器的功能:在不修改原函数及其调用方式的情况下对原函数功能进行扩展
5、常用函数
1.常用函数
1.abs(x) abs()返回一个数字的绝对值。如果给出复数,返回值就是该复数的模。
2.callable(object) callable()函数用于测试对象是否可调用,如果可以则返回1(真);否则返回0(假)。可调用对象包括函数、方法、代码对象、类和已经定义了“调用”方法的类实例。
3.cmp(x,y) cmp()函数比较x和y两个对象,并根据比较结果返回一个整数,如果xy,则返回1,如果x==y则返回0。
5.isinstance(object,class-or-type-or-tuple) -> bool
6.len(object) -> integer len()函数返回字符串和序列的长度。
7.pow(x,y[,z]) pow()函数返回以x为底,y为指数的幂。如果给出z值,该函数就计算x的y次幂值被z取模的值。
8.range([lower,]stop[,step]) range()函数可按参数生成连续的有序整数列表。
9.round(x[,n]) round()函数返回浮点数x的四舍五入值,如给出n值,则代表舍入到小数点后的位数。
10.type(obj) type()函数可返回对象的数据类型。
11.xrange([lower,]stop[,step]) xrange()函数与range()类似,但xrnage()并不创建列表,而是返回一个xrange对象,它的行为与列表相似,但是只在需要时才计算列表值,当列表很大时,这个特性能为我们节省内存。
2.内置类型转换函数
1.chr(i) chr()函数返回ASCII码对应的字符串。
2.complex(real[,imaginary]) complex()函数可把字符串或数字转换为复数。
3.float(x) float()函数把一个数字或字符串转换成浮点数。
4.hex(x) hex()函数可把整数转换成十六进制数。
5.long(x[,base]) long()函数把数字和字符串转换成长整数,base为可选的基数。
6.list(x) list()函数可将序列对象转换成列表。如:
7.int(x[,base]) int()函数把数字和字符串转换成一个整数,base为可选的基数。
8.min(x[,y,z…]) min()函数返回给定参数的最小值,参数可以为序列。
9.max(x[,y,z…]) max()函数返回给定参数的最大值,参数可以为序列。
10.oct(x) oct()函数可把给出的整数转换成八进制数。
11.ord(x) ord()函数返回一个字符串参数的ASCII码或Unicode值。
12.str(obj) str()函数把对象转换成可打印字符串。
13.tuple(x) tuple()函数把序列对象转换成tuple。
3.序列处理函数
1.常用函数中的len()、max()和min()同样可用于序列。
2.filter(function,list)
3.map(function,list[,list]) map()函数把一个函数应用于序列中所有项,并返回一个列表。
4.reduce(function,seq[,init]) reduce()函数获得序列中前两个项,并把它传递给提供的函数,获得结果后再取序列中的下一项,连同结果再传递给函数,以此类推,直到处理完所有项为止。
5.zip(seq[,seq,…]) zip()函数可把两个或多个序列中的相应项合并在一起,并以元组的格式返回它们,在处理完最短序列中的所有项后就停止。
上一篇: thinkphp公共命名空间图文详解
下一篇: c++命名空间
推荐阅读