函数基础
返回值
1.什么是返回值
返回值就是函数返回给函数调用者的值(概念)
返回值就是return后面的值(语法)
返回值就是函数调用表达式的值(获取返回值)
2.return
1)什么是return
return是一个关键字,只能出现在在函数体中
2)return的作用
a.结束函数: 执行函数体的时候,一旦遇到return,函数直接结束
b.将数据返回给函数调用者(将函数内部的数据传递到函数外部):return后面跟需要返回的数据
说明: 看一个函数的返回值是什么,就看执行函数的过程中有没有遇到return;
如果遇到return,return后面的值就是函数的返回值
3)什么样的数据应该作为函数的返回值
初学者: 如果执行完函数会产生新的数据,那么产生新数据的话就可以作为返回值返回;产生几个返回几个
return 返回值1, 返回值2
4)怎么获取函数返回值
获取函数调用表达式的值就是获取函数的返回值
3.函数调用过程(完整) - 执行过程
1)回到函数调用位置
2)传参,用实参给形参赋值;保证每个参数都有值
3)执行函数体
4)执行完函数体,确定函数返回值
(函数结束:a.执行完函数体的最后一条语句 b.执行过程中遇到return)
(怎么确定返回值: 看执行函数的过程中有没有遇到return,如果遇到return,return后面的值就是函数的返回值)
5)回到函数调用位置,接着往后执行
调用函数: 执行函数体,获取返回值
4.函数调用过程的内存变化
函数调用的过程是一个压栈的过程:每次调用函数的时候,系统都会自动地在内存中专门为这个函数开辟一个内存空间,用来保存在函数中声明的变量(形参也是声明在函数中的变量)当函数调用结束,这个内存区域会自动释放
def test_sum(num1, num2):
return num1 + num2
test_sum(32, 23)
print(test_sum(100, 23))
list1 = [test_sum(3, 2), test_sum(32, 1), test_sum(231, 456)]
print(list1)
匿名函数
1.匿名函数
匿名函数本质还是函数, 普通函数中除了声明的语法其他都适用于匿名函数
1)语法
lambda 参数列表:返回值
2)说明
lambda - 关键字,固定写法
参数列表 - 形参列表,以'参数名1, 参数名2,...'
: - 固定
返回值 - 写任何有结果的表达式都可以
注意:匿名函数的函数体,只有一条语句,而且这条语句的结果就是函数的返回值(不需要return)
3)什么时候使用匿名函数
a.函数的功能一行代码就可以实现
b.函数的功能不会重复使用
练习1:写一个函数,求两个数的和
sum1 = lambda num1, num2: num1 + num2
练习2:写一个匿名函数,求两个数中最大值
max1 = lambda num1, num2: '最大值:%d' % num1 if num1 > num2 else '最大值:%d' % num2
python中的三目运算符:
c语言 - 条件语句?值1:值2
python - 值1 if 条件语句 else 值2
作用域
1.什么是作用域
声明完变量后,这个变量能够使用的范围就是变量的作用域
2.全局变量和局部变量
1)全局变量: 声明在函数或者类外面的变量都是全局变量
全局变量的作用域: 从声明开始到整个文件结束
2)局部变量: 声明在函数中的变量就是局部变量
局部变量的作用域:从声明开始到整个函数结束
3.global和nonlocal
这两个关键字只能在函数体中使用
1)global: 在函数中声明一个全局变量(或者修改一个全局变量的值)
global 变量名
变量名 = 值
2)nonlocal: 在函数中的函数中声明一个局部变量(或修改)
nonlocal 变量名
变量名 = 值
n1 = 100
def fun1():
global n1
n1 = 200
print(n1)
fun1()
print(n1)
print(fun1())
递归函数
1.什么是递归函数: 在函数中调用函数本身,这样的函数就是递归函数
循环能做的事情递归都可以做
1)怎么写递归函数
第一步: 声明函数(和普通函数一样)
第二步: 找临界值(函数结束的条件)
第三步: 找关系
假设函数f的功能已经实现了, 找f(n)和f(n-1)的关系
第四步: 使用f(n-1)去实现f(n)的功能
2)总结: 通过for或者while能做的事情就不要用递归去做
练习1:用递归实现1 + 2 + 3 + ... + N
def sum1(n):
if n == 1:
return 1
return sum1(n-1) + n
练习2:斐波那契数列
def fibonacci(n):
if n <= 2:
return 1
return fibonacci(n-1) + fibonacci(n-2)