昨天讲了函数的定义和简单分类

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

函数的优点:

  1:减少代码的冗余

  2:结构清晰,可读性强

  3:具有复用性,开发效率高

用def 来声明定义一个函数:

'''
def fn(参数列表):
  函数体
  return 函数的返回值
'''

  定义函数时,函数体不会被执行   函数必须先定义后使用

函数的四部分

函数名,存放着函数的地址,是调用函数的依据

函数体,解决问题的代码块

参数列表 外界为内部提供数据的途径 - 内部需要外部的数据,就需要定义参数列表

返回值:将内部的结果返回给外部

函数的使用

!通过函数名找到函数的地址

2:函数名()来调用执行函数

3:得到函数执行的返回值

def add(n1, n2):
  return n1 + n2
add(10, 20) # 只执行的函数体
res = add(10, 20) # 执行的函数体,并拿到函数的执行结果
print(add(10, 20) + 100) # 执行的函数体,并拿到函数的执行结果,再使用

函数的分类

有无函数体   空函数 -- pass填充,非空函数 --有函数体

有无参数   无参函数 --内部不需要外部数据。有参函数--内部需要外部数据

有无返回值      不主动明确返回值的  , 系统主动在函数体末尾执行return

       主动明确返回值, 按需求明确返回值

函数的返回值

return的作用:1:结束函数,2:携带内部参数给外部

没有return关键字的函数,不关心函数的返回值,但函数的返回值为None

空return的函数不关心函数的返回值,但在特定条件下要主动结束函数,空return  返回值为none

return 一个值  外界就可以接收到返回的一个值

return 多个值,外界用一个值接收  就是一个元租,外界用多个值接受,接收的个数要与返回的个数相同,(本质就是解压赋值)

今日内容

函数的参数,函数对象就是函数名,函数的嵌套调用

形参与实参

实参:有实际意义的参数

    在调用函数时候 ()中传入的参数

形参,形参本身没有意义,有实参赋予形参后,该形参就具备了意义

  在定义函数时候()中出现的参数      

  有默认值的形参,在没有被实参赋值,具备的是自身默认值,一旦被实参赋值,意义同时惨  --def add(n1,n2=20):

 形参范畴

def add(n1,n2)#形参n1 ,n2在没有被实参赋值时,没有实际意义,被什么实参赋值,就被赋予了什么意义

比如:

print(add('a', 'b')) # 实际的字符串
print(add(10, 20)) # 实际的数字
a = 200
b = 300
print(add(a, b)) # 存放实际数字的变量

形参是对实参的值拷贝

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

不可变类型,形参发生重指向,实参不变

def fn(num):
  print('1>>>:', num) # 10
  num = 20
  print('2>>>:', num) # 20

num = 10
fn(num)
print('3>>>:', num) # 10

可变类型,形参发生值得内部变化,实参变,两个指向的是同一个地址

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)

拿位置实参进行传参:形参与实参进行位置一一对应, 一号位的实参一定传给一号位的形参

a=100

b=100

fn(a,b) #a:100 ==>a  | b:200 ==>b

fn(b,a) #b:200==>a   | a:100 ==>b

3:拿关键字实参进行传参,直接指名道姓的传参,传参的过程 直接把形参的名 = 值

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)

位置实参,一定按照位置,且个数要一一对应进行传参

关键字实参,指名道姓进行传参,个数一致位置可以改变进行传参

实参组合传参规则,必须先传位置实参,在传关键字实参

形参的分类

#六大分类

1:无值位置形参(位置形参) 可以被位置和关键字实参进行传参,必须传值

2:有值位置形参(默认形参):可以被位置与关键字实参进行传参,可以不用传参,采用默认值

3:可变长位置形参:可以接受钱两个没有接收完位置实参,接受的个数可以为0-n个

4:无值关键字形参:只能由关键字实参进行传参,必须传值

5:有值关键字形参,只能由关键字实参进行传参,可以不用传参采用默认值

6:可变长关键字形参:接受4,5没有接收完的关键字实参,接收的个数可以为0-n个 0个就是空字典

声明顺序

位置形参 =》默认形参=》可变长位置形参=》有无默认值关键字形参=》可变长关键字形参

def fn(a, b=10, *args, c, d=20, e, **kwargs): pass

注意点:

可变长位置形参,只能接受位置实参,要想被附上值,前面的有值位置形参的默认值就没有多大意义了

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

使用法则:

所有位置形参都采用位置实参进行传值

所有关键字形参全部采用关键字实参进行传值

不管位置还是关键字形参,全部按照顺序进行传参

打散机制*与**

*单列容器,会打散单列容器

**双列容器,会打散双列容器

函数传参时候 直接把一个列表或元祖这样的数据放进去 然后在前面放一个*号, 会把这个容器打散成一个个的值传过去,然后函数形参用可变长形参接收就可以了

传参时候把字典前面放** 会把字典打散成关键字实参的样式传过去,形参用可变长关键字形参接受即可

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

day_11函数的形参与实参的更多相关文章

  1. JavaScript中函数的形参和实参的实现原理剖析

    我们都知道JS里面参数的传递是可以不一样的,比如我们有一个函数: <script type="text/javascript"> function one(a,b,c) ...

  2. js 函数中形参与实参的关系

    函数中形参与实参的关系 对于形参和实参的定义,在 权威指南中有着明确的定义.但是,我们更在意的是它们之间的关系,到底形参会不会影响到实参? 形参到底会不会影响到实参? 对于这个问题的答案,请先看以下两 ...

  3. 函数的形参和实参之arguments对象

    当函数调用函数时候传入的实参比函数声明时候制定的形参要少时候,剩余的形参就设置成了undefined.例如 function getPropertyNames(o,/*optional*/a){ va ...

  4. day-11函数的形参与实参

    形参与实参 参数介绍: 函数为什么要有参数:因为内部的函数体需要外部的数据 怎么定义函数的参数:在定义函数阶段,函数名后面()中来定义函数的参数 怎么使用函数的参数:在函数体中用定义的参数名直接使用 ...

  5. day10 十 函数、形参和实参

    一.形参和实参 1.形参:在函数定义()中出现的参数形参就是拷贝实参的值,随着函数的调用才产生,随着函数调用结束而销毁 def fn(a, b, c): print(a) print(b) print ...

  6. 一道题带你搞定Python函数中形参和实参问题

    昨天在Python学习群里有位路人甲问了个Python函数中关于形参和实参一个很基础的问题,虽然很基础,但是对于很多小白来说不一定简单,反而会被搞得稀里糊涂.人生苦短,我用Python. 为了解答大家 ...

  7. python3 函数的形参、实参、位置参数、默认参数、关键字参数以及函数的递归

    python 版本 3.5 #Author by Andy#_*_ coding:utf-8 _*_def func(x,y=2): print('我是形参%s'%x) print('我是默认参y-- ...

  8. Day 10 函数的形参,实参

    今日内容 '''实参:调用函数,在括号内传入的实际值,值可以为常量.变量.表达式或三者的组合​*****形参:定义函数,在括号内声明的变量名,用来接受外界传来的值​'''​'''注:形参随着函数的调用 ...

  9. python——函数的形参和实参、参数

    python的参数分类 python参数可以分为两类:1.定义时的参数--形参(形式参数).2.调用时的参数--实参(实际参数,传参) 实参的规则 实参就是在函数调用的时候,通过函数后面的括号传递给函 ...

随机推荐

  1. 桥接模式和nat模式的区别

    桥接模式:VMware虚拟的系统就想局域网中独立的主机一样(有独立的IP)它可以访问网内任何一台机器 Nat模式:可以通过宿主机访问互联网(宿主机联网,虚拟机就能联网)它不能和本局域网中的其他主机进行 ...

  2. mysql数据库分区和分表

    转载自 https://www.cnblogs.com/miketwais/articles/mysql_partition.html https://blog.csdn.net/vbirdbest/ ...

  3. 010 Editor 8.0.1 之 逆向分析及注册机编写

    前言一.工具及软件介绍二.逆向分析2.1.找到提示错误注册弹窗2.2.分析跳转处代码2.3.=2D 函数分析2.3.1.获取注册码处分析2.3.2.3处分支分析2.3.2.1.9C情况2.3.2.2. ...

  4. CSS中的字体描边

    兴趣使然,突然看见网上的一些带有描边的字体,觉得有点意思,便尝试去做了下 不是什么很厉害的技巧,当然也有参考张鑫旭大神写的文章 只能感叹,css的世界还很大,很广阔 直入主题: 对于文字的描边,一般都 ...

  5. mongocxx-driver编译安装

    1. 确保安装epel yum install -y epel-release 2. 按照<CentOS7.2部署node-mapnik>一文中的步骤,手动安装 gcc-6.2.0 和 b ...

  6. scrapy项目对接Docker

    1.项目根目录生成requirements.txt文件  命令pip freeze > requirements.txt 2.项目根目录新建Dockerfile文件,文件不加任何后缀名 内容如下 ...

  7. Mysql数据库性能优化(一)

    参考 http://www.jb51.net/article/82254.htm 今天,数据库的操作越来越成为整个应用的性能瓶颈了,这点对于Web应用尤其明显.关于数据库的性能,这并不只是DBA才需要 ...

  8. ECMA262学习笔记(二)

    Property特性:特性用于定义和解释命名属性的状态. ECMAScript建立执行环境: 解释执行全局代码或使用eval函数输入的代码会创建并进入一个新的执行环境.每次调用ECMA脚本代码定义的函 ...

  9. Connection failed Flowsocketconnector Failed to connect to target addressWindows error10061:由于目标计算机积极拒绝,无法连接

    使用bitbise时报上面错误   : 解决方法 :卸载软件并删除相关的文件 (包含bitvise 及注册表中的文件)重新安装后能连接

  10. [精华][推荐]CAS SSO实现单点登录框架学习源码

    1.通过下载稳定版本的方式下载cas的相关源码包,如下: 直接选择4.2.1的稳定代码即可 2.我们项目中的版本版本使用maven apereo远程库去下载 通过远程maven库下载cas-serve ...