必须参数须以正确的顺序传入函数,调用的数量必须和声明时的一样
def f(name,age):
print('I am %s,I am %d'%(name,age))
f('alex',18)
f('alvin',16)
输出:
I am alex,I am 18
I am alvin,I am 16
关键字参数和函数调用关系紧密,函数调用使用关键字参数来确定传入的参数值。使用关键字参数允许函数调用时参数的顺序与声明时不一致,因为 Python 解释器能够用参数名匹配参数值。
def f(name,age):
print('I am %s,I am %d'%(name,age))
# f(16,'alvin') #报错
f(age=16,name='alvin')
输出:
I am alvin,I am 16
调用函数时,缺省参数的值如果没有传入,则被认为是默认值。下例会打印默认的age,如果age没有被传入:
def print_info(name, age, sex='male'):
print('Name:%s' % name)
print('age:%s' % age)
print('Sex:%s' % sex)
return
print_info('alex', 18)
print_info('小明', 40, 'female')
输出:
Name:alex
age:18
Sex:male
Name:小明
age:40
Sex:female
你可能需要一个函数能处理比当初声明时更多的参数。这些参数叫做不定长参数,和上述2种参数不同,声明时不会命名。
# def add(x,y):
# return x+y
def add(*tuples):
sum=0
for v in tuples:
sum+=v
return sum
print(add(1,4,6,9))
print(add(1,4,6,9,5))
输出:
20
25
加了星号*
的变量名会存放所有未命名的变量参数,而加**
的变量名会存放命名的变量参数
def print_info(**kwargs):
print(kwargs)
for i in kwargs:
print('%s:%s' % (i, kwargs[i])) # 根据参数可以打印任意相关信息了
return
print_info(name='小明', age=18, sex='female', hobby='girl', nationality='Chinese', ability='Python')
###########################位置
def print_info(name, *args, **kwargs): # def print_info(name,**kwargs,*args):报错
print('Name:%s' % name)
print('args:', args)
print('kwargs:', kwargs)
return
print_info('小明', 18, hobby='girl', nationality='Chinese', ability='Python')
# print_info(hobby='girl','小明',18,nationality='Chinese',ability='Python') #报错
# print_info('小明',hobby='girl',18,nationality='Chinese',ability='Python') #报错
输出:
{'name': '小明', 'age': 18, 'sex': 'female', 'hobby': 'girl', 'nationality': 'Chinese', 'ability': 'Python'}
name:小明
age:18
sex:female
hobby:girl
nationality:Chinese
ability:Python
Name:小明
args: (18,)
kwargs: {'hobby': 'girl', 'nationality': 'Chinese', 'ability': 'Python'}
注意,还可以这样传参:
def f(*args):
print(args)
f(*[1, 2, 5])
def f(**kargs):
print(kargs)
f(**{'name': '小明'})
输出:
(1, 2, 5)
{'name': '小明'}
至少满足下面一个条件的函数:
def add(x,y,f):
return f(x) + f(y)
res = add(3,-6,abs)
print(res)
###############
def foo():
x=3
def bar():
return x
return bar
输出:
9
程序是指在执行的过程中动态的申请内存空间,随着程序的运行不再需要使用这些内存空间。这时如果不释放这些空间,就会驻留内存成为无用的垃圾,也就是造成了内存泄漏。
垃圾回收机制:GC,垃圾回收机制的存在,使得开发人员可以把更多的精力关注业务逻辑,而不是内存中垃圾的回收,因此GC的存在帮助了程序开发人员管理内存。
Python中的垃圾回收以引用计数为主,标记清除和分代回收为辅,同时还有缓存机制。