一,复习

# 什么是函数:具体特定功能的代码块 - 特定功能代码块作为一个整体,并给该整体命名,就是函数

# 函数的优点:
# 1.减少代码的冗余
# 2.结构清晰,可读性强
# 3.具有复用性,开发效率高,维护成本低 # 如何定义一个函数:用def关键词来声明函数
'''
def fn(参数列表):
函数体
return 函数的返回值
'''
# -- 定义函数时,函数体不会被执行 | 函数必须先定义后使用 # 函数的四部分:
# 函数名:存放着函数的地址,是调用函数的依据
# 函数体:解决问题的代码块
# 参数列表:外界为内部提供数据的途径 - 内部需要外部的数据,就需要定义参数列表
# 返回值:将内部的结果返回给外部 # 函数的使用
# 1.通过函数名找到函数的地址
# 2.函数名() 来调用执行函数
# 3.得到函数执行的结果 - 返回值 def add(n1, n2):
return n1 + n2
add(10, 20)    # 只执行的函数体
res = add(10, 20) # 执行的函数体,并拿到函数的执行结果
print(add(10, 20) + 100) # 执行的函数体,并拿到函数的执行结果,再使用 # 函数的分类
# 有无函数体:空函数 - pass填充 | 非空函数 - 有函数体 # 有无参数:
#无参函数 - 内部不需要外部数据
#有参函数 - 内部需要外部数据 # 有无返回值:
#不主动明确返回值的函数 - 系统主动在函数体末尾添加return
#主动明确返回值的函数 - 按需求明确return # 函数的返回值
# 没有return关键字的函数:不关系函数的返回值,但函数的返回值为None
# 有空return:不关系函数的返回值,但在特定条件下要主动结束函数,空return,函数的返回值为None
# return一个值:外界就可以接收到返回的一个值
# return多个值:外界用一个值接收,接收到的是元组 | 外界用多个值接收,接收的个数与返回的个数一定要统一(本质采用解压赋值) # return的作用:1.结束函数 2.携带内部参数给外部

二,今日内容

# 函数的参数: ****
# 函数对象 - 函数名:*****
# 函数的嵌套调用:***

三,形参与实参

# 参数介绍:
# 函数为什么要有参数:因为内部的函数体需要外部的数据
# 怎么定义函数的参数:在定义函数阶段,函数名后面()中来定义函数的参数
# 怎么使用函数的参数:在函数体中用定义的参数名直接使用 # 实参:有实际意义的参数
# -- 在函数调用的时候,()中传入的参数
# 形参:参数本身没有意义,有实参赋予形参值后,该形参就具备了意义
# 补充:有默认值的形参,在没有被实参赋值,具备的是自身意义,但一旦被实参赋值,意义同实参 - def add(n1, n2=2):
# -- 在定义函数的时候,()中出现的参数 # 形参范畴
def add(n1, n2): # 形参n1,n2在没有被实参赋值时,没有实际意义,被什么意义的实参赋值,就被赋予了什么意义
return n1 + n2 # 实参范畴
print(add('a', 'b')) # 实际的字符串
print(add(10, 20)) # 实际的数字
a = 200
b = 300
print(add(a, b)) # 存放实际数字的变量

四,形参是对实参的值拷贝

# 形参与实参可以重名,但是代表的是两个不同的变量

# 不可变类型,形参发生重指向,实参不变
def fn(num):
print('1>>>:', num) #
num = 20
print('2>>>:', num) # num = 10
fn(num)
print('3>>>:', num) # # 可变类型,形参发生值的内部变化,实参变,两个指向的是同一个地址
def func(ls):
print('1>>>:', ls) # [10]
ls.append(20)
print('2>>>:', ls) # [10, 20] ls = [10] func(ls)
print('3>>>:', ls) # [10, 20]

五,实参的分类

# 实参分为:1.位置实参  2.关键字实参

def fn(a, b):
print(a, b) # 1)拿实际值进行传参
fn(10, 20) # 10 => a | 20 => b # 2)拿位置实参进行传参:形参与实参进行位置一一对应,eg:1号位的实参一定传给1号位的形参
a = 100
b = 200
fn(a, b) # a:100 => a | b:200 => b
fn(b, a) # b:200 => a | a:100 => b # 3)拿关键字实参进行传参:指名道姓进行传参 - 传参的过程过指名道姓形参
# 明确:形参名目前为a和b
fn(a=1000, b=2000) # a:1000 => a | b:2000 => b
fn(b=2000, a=1000) # b:2000 => b | a:1000 => a
a = 666
b = 888
# 前面的是形参名,后面的是传递的实参名
fn(a=a, b=b) # a:666 => a | b:888 => b # 位置实参:一定按照位置,且个数要一一对应进行传参
# 关键字实参:指名道姓进行传参,个数一致位置可以改变进行传参 # 实参组合传参规则:必须先传位置实参,再传关键字实参

六, 形参的分类

# 六大分类:
# 1.无值位置形参(位置形参):可以被位置与关键字实参进行传参,必须传值 # 2.有值位置形参(默认形参):可以被位置与关键字实参进行传参,可以不用传参采用默认值 # 3.可变长位置形参(*args):可以接受前两个没有接收完位置实参,接收的个数可以为0~n个,0个是就是空元组 # 4.无值关键字形参(c):只能由关键字实参进行传参,必须传值 # 5.有值关键字形参(d = 10):只能由关键字实参进行传参,可以不用传参采用默认值 # 6.可变长关键字形参(**kwargs):接收4,5没有接收完的关键字实参,接收的个数可以为0~n个,0个是就是空字典 # 声明顺序:
# 位置形参:a -> 默认形参:b -> 可变长位置形参:args -> 有无默认值关键字形参:cde -> 可变长关键字形参:kwargs
def fn(a, b=10, *args, c, d=20, e, **kwargs): pass # 注意点:
# 1.可变长位置形参只能接受位置实参,要想被赋上值,前面的有值位置形参的默认值没有多大意义
# 2.args与kwargs是可变长形参的变量名,所以可以自定义,但约定俗成就用它俩 # 位置形参一定遵循:无值在前,有值在后
# 关键字形参顺序可以任意 # 常出现的组合
def f1(*args, **kwargs): pass def f2(a, b=10, **kwargs): pass
def f3(a, *args, **kwargs): pass def f4(a, *, x, **kwargs): pass
def f5(a, *args, x, **kwargs): pass # 使用法则:
# 1.所有位置形参全部采用位置实参进行传值
# 2.所有关键字形参全部采用关键字实参进行传值
# 3.不管位置还是关键字形参,全部按照顺序进行传参

七,打散机制

def fn(*args, **kwargs):
print(args)
print(kwargs) t = (1, 2, 3)
dic = {'a': 100, 'b': 200, 'c': 300} # *单列容器 会打散单列容器(字符串,列表,元组,集合)
# **双列容器 会打散双列容器(字典)
fn(1, 2, 3, a=100, b=200, c=300) # (1, 2, 3) {'a': 100, 'b': 200, 'c': 300}
fn(*t, **dic) # (1, 2, 3) {'a': 100, 'b': 200, 'c': 300}
fn(*(1, 2, 3), **{'a': 100, 'b': 200, 'c': 300}) # (1, 2, 3) {'a': 100, 'b': 200, 'c': 300} # 字符串也可以被打散
fn(*'abc') # ('a', 'b', 'c') {}
print(*'abc') # a b c

八,函数的嵌套调用

# 函数的嵌套调用:在一个被调用的函数内部调用另一个函数
# -- 复用之前已定义好的函数功能 - 功能有重叠 def a():
b() def b():
pass a() # a的调用必须在b的声明之后,原因a中要使用b # 注意:在提前声明的函数中可以嵌套调用之后声明的函数,
# 但是本函数的调用必须在嵌套被调用的函数声明之后 # 应用场景
# 求两个数的大者
def max_two(a, b):
if a > b:
return a
return b
print(max_two(100, 20)) # 求三个数的大者
# def max_three(a, b, c):
# # if b < a > c:
# # return a
# # if a < b > c:
# # return b
# # if a < c > b:
# # return c
def max_three(a, b, c):
max_num = max_two(a, b)
return max_two(max_num, c)
# print(max_three(20, 10, 5)) # 求四个数的大者
def max_four(a, b, c, d):
max_num = max_three(a, b, c)
return max_two(max_num, d)

day11(函数参数,函数对象,打散机制,函数嵌套调用)的更多相关文章

  1. Day04:函数参数、对象、嵌套、闭包函数和装饰器

    上节课复习:    1.什么是函数        函数就是具备某一功能的工具    2.为何用函数        1.程序的组织结构和可读性        2.减少代码冗余        3.扩展性强 ...

  2. agruments应用——求出函数参数的总合&&css函数——设置/读取对象的属性&&当前输入框高亮显

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  3. python函数:函数参数、对象、嵌套、闭包与名称空间、作用域

    今天的内容整理共有5部分 一.命名关键字参数 二.函数对象 三.函数的嵌套 四.名称空间与作用域 五.闭包函数 一.命名关键字参数 # 命名关键字参数: 在定义函数时,*与**之间参数称之为命名关键字 ...

  4. python基础-4 函数参数引用、lambda 匿名函数、内置函数、处理文件

    上节课总结 1.三元运算 name=“name1”if 条件 else “name2” 2.深浅拷贝 数字.字符串 深浅,都一样 2.其他 浅拷贝:只拷贝第一层 深拷贝:不拷贝最后一层 3.set集合 ...

  5. javascript 在一个函数参数中包含另一个函数的引用

    javascript函数的参数包含另一个函数的情形: <script> //b函数的参数func为另一个函数 function b(a, func) {  alert(a); //调用参数 ...

  6. c++函数参数或返回值为函数指针

    C++中函数指针的形式为:返回值类型 + 参数类型,函数没有值类型,但是却可以声明函数的指针,因为函数是可寻址的,存放在内存中的代码段,可以从指针访问. 函数指针可以声明为: void (*pF)(v ...

  7. 11、Python函数基础(定义函数、函数参数、匿名函数)

    函数先定义函数,后调用 一.定义函数: 1.简单的规则: 函数代码块以 def 关键词开头,后接函数标识符名称和圆括号 (). 任何传入参数和自变量必须放在圆括号中间,圆括号之间可以用于定义参数. 函 ...

  8. day12 函数的嵌套调用 闭包函数,函数对象

    函数嵌套: 函数嵌套: 嵌套指的是,一个物体包含另一个物体,函数嵌套就是一个函数包含另一个函数 按照函数的两个阶段 嵌套调用 指的是在函数的执行过程中调用了另一个函数,其好处可以简化外层大函数的代码, ...

  9. Day8 函数指针做函数参数

    课堂笔记 课程回顾         多态 virtual关键字 纯虚函数 virtual func() = 0;         提前布局vptr指针 面向接口编程 延迟绑定 多态的析构函数的虚函数. ...

  10. Java获取函数参数名称

    原理 编译之后的class文件默认是不带有参数名称信息的,使用 IDE 时,反编译jar包得到的源代码函数参数名称是 arg0,arg1......这种形式,这是因为编译 jar 包的时候没有把符号表 ...

随机推荐

  1. CSS Modules In Webpack

    1)从形式上看,CSS Modules 是将CSS中的选择器转换为变量,然后在DOM中引用变量来引入样式. 2)从效果上看,CSS Modules 可以将CSS选择器名字转成随机字符串,保证选择器同名 ...

  2. Java的数组,栈,队列

    import java.util.Arrays; public class Array<E> { private E[] data; private int size; //构造函数,传入 ...

  3. SVN问题解决--Attempted to lock an already-locked dir

    今天上午更新uap(uap就是基于eclipse开发的软件,可以当eclipse来使用)上的代码时,发现在svn上更新不了,一直报这个Attempted to lock an already-lock ...

  4. docker~不使用yml批量部署服务

    回到目录 有时,我们在进行持续集成环境有时,有时yml环境是没有的,它可能只提供了docker工具,而docker-compose这个大家伙可能不被提供,而这样我们如果希望自动化构建解决方案下所有的项 ...

  5. 前端笔记之JavaScript面向对象(二)内置构造函数&相关方法|属性|运算符&继承&面向对象

    一.复习 1.1复习上下文 函数的调用方式 上下文 fun() window obj.fun() obj box.onclick = fun box setInterval(fun,1000) set ...

  6. SQL优化 MySQL版 -分析explain SQL执行计划与笛卡尔积

    SQL优化 MySQL版 -分析explain SQL执行计划 作者 Stanley 罗昊 [转载请注明出处和署名,谢谢!] 首先我们先创建一个数据库,数据库中分别写三张表来存储数据; course: ...

  7. Java基础系列-Stream

    原创作品,可以转载,但是请标注出处地址:https://www.cnblogs.com/V1haoge/p/10748817.html 一.概述 Stream操作简称流操作,这里的流与IO流毫无关系, ...

  8. SpringCloud系列——SSO 单点登录

    前言 作为分布式项目,单点登录是必不可少的,文本基于之前的的博客(猛戳:SpringCloud系列——Zuul 动态路由,SpringBoot系列——Redis)记录Zuul配合Redis实现一个简单 ...

  9. 树莓派播放视频的播放器omxplayer

    omxplyer为树莓派量身定做的一款GPU硬件加速的播放器,很好的解决了树莓派cpu计算力不足的缺点.(播放时cpu一定都不烫手) 1.安装方法: CTRL + ALT + T 调出终端命令行输入 ...

  10. .net工具类 分享一个简单的随机分红包的实现方式

    废话不多说,直接上代码 /// <summary> /// 分红包 /// </summary> public class RandomMoney { public Rando ...