• 函数参数 形参/实参


    函数中,有两种参数,形参与实参:

    形参:在定义函数阶段定义的参数称之为形式参数,简称形参,相当于变量名

    def func(x, y):  # x=1,y=2
        print(x, y)
    

      

    实参:在调用阶段传入的值称之为实际参数,简称实参,相当于变量值

    func(1,2)
    

      

    实参和形参的关系
    • # 在调用阶段,实参(变量值)会绑定给形参(变量名)

    • # 绑定关系只能在函数体内使用

    • # 实参与形参的绑定关系在函数调用时生效,函数调动结束后解除绑定关系

    实参是传入的值,但值可以是以下形式

    ​ 只要参数结果是一个值就可以了

    # 形式一:
    func(1,2)
     
    # 形式二:
    a=1
    b=2
    func(a,b)
     
    # 形式三:
    func(int('1'),2)
    func(func1(1,2,),func2(2,3),333)
    

    形参与实参的具体使用

    位置形参:在函数定义阶段按照从左到右的顺序直接定义的’变量名‘

    ​ 特点:必须被传值,多一个不行,少一个也不行

    def func(x,y):
        print(x,y)
    func(1,2)
    func(1,2,3)  #错误  多了一个
    func(1,)  #错误   少了一个
    func(1,5)
    func(8,9)

      位置实参:在函数调用阶段, 按照从左到有的顺序依次传入的值  特点:按照顺序与形参一一对应

    关键字实参数:在函数调用阶段,按照 key=value 的形式传入的值

    • 指名道姓给某个参数传值,可以完全不参照顺序  

    def func(x,y):
        print(x,y)
     
    func(y=2,x=1)
    func(1,2)
    

    强调:如果需要混合使

    位置实参必须放在关键字实参前

    def func(x,y):
    print(x,y)
    func(1,y=2) func(y=2,1) #错误
    func(1,y=2,x=3)  #错误
    func(1,2,x=3,y=4)  #错误
    不能能为同一个形参重复传值

      

    默认形参:在定义函数阶段,就可以被赋值的形参,称之为默认参数

    ​ 特点:在定义阶段就已经被赋值,意味着在调用阶段可以不用为其赋值

    def func(x,y=3):    #y是
            print(x,y)
    func(x=1)#1,3
    func(x=1, y=44)#1,44
    
    •   使用场景:一般需要传入的参数大部分都是同一个值,只有偶尔需要传入不同值时,这时候可以在定义阶段将参数设为默认参数
    def register(name, age, gender='男')  #案例
                print(name, age, gender)
    register('三炮',18)
    register('二炮',18)
    register('大炮',19)
    register('没炮',19,’女)
    
    结果展示:
    三炮 18 男
    二炮 18 男
    大炮 19 男
    没炮 19 女
    

     位置形参与默认参数混用,强调

    • 位置参数必须在默认形参的前面
    ef func(y=2,x): #报错
                pass
    

    默认参数的值是在函数定义阶段被赋值的,准确地说被赋予的是值的内存地址

    m=2
    def func(x, y=m):#y =>2的内存地址
        print(x,y)
    m =33333333
    func(1) #1,2
    
    
    
    m = [111,]
    def func(x, y=m): #y=>[111, ]的内存地址
             pinrt(x,y)
    m.append(333)
    func(1) #1,[111,333]    #列表是地址是可变的
    
    • 虽然默认值可以被指定为任意数据类型,但是不推荐使用可变类型。函数最理想的状态:函数的调用只跟函数本身有关系,不外界代码的影响
    def index(x,y,z):
        print('index=>>> ',x,y,z)
     
    def wrapper(*args,**kwargs): #args=(1,) kwargs={'z':3,'y':2}
        index(*args,**kwargs)
     
        # index(*(1,),**{'z':3,'y':2})
     
        # index(1,z=3,y=2)
     
    wrapper(1,z=3,y=2) # 为wrapper传递的参数是给index用的
     
    # 原格式---》编码-----》解码


    #这方法的好处就是以什么样的格式传参,内部调用的函数就会以什么样的格式传参

      

    示例:
    def func(x,y,z,l=None):
        if l is None:
            l=[]
        l.append(x)
        l.append(y)
        l.append(z)
        print(l)
    func(1,2,3) #[1, 2, 3]
    func(4,5,6) #[4, 5, 6]
    

      

    def func(x,y,z,l=None): 
        if l is None:  #is 比较是 id,但是 None 只有一个,所以 id 是唯一的
            l = []
        l.append(x)
        l.append(y)
        l.append(z)
        print(l)
    func(1,2,3) #[1, 2, 3]
    new_l = [111,222]
    func(1,2,3,new_l) #[111, 222, 1, 2, 3]
    

      

    可变长度的参数(*与 ** 的用法)

    • 可变长度指的是在调用函数时,传入的值(实参)的个数不固定
    • 而实参是用来为形参赋值的,所以对应着,针对溢出的实参必须有对应的形参来接收

    可变长度的位置参数

    形参格式 形参名:用来接收溢出的位置实参, 溢出的位置实参会被 保存成元组的格式然后赋值给紧跟后面的参数名

    def func(x,y,*z):  #z=(3,4,5,6)   
        print(x,y,z)
    
    func(1,2,3,4,5,6) #1,2(3,4,5,6) 
    def my_sum(*args):   #后跟的可以是任意名字,但是约定俗成应该是 args
        res=0
        for item in args:
            res+=item
        return res
     
    res=my_sum(1,2,3,4,)
    print(res)
    

    可以用在实参中,实参中带,先*后的值打散成位置实参

    def func(x,y,z):
        print(x,y,z)
     
    # func(*[11,22,33]) # func(11,22,33)
     
    # func(*[11,22]) # func(11,22)
     
    l=[11,22,33]
    func(*l)
    

     形参与实参中都带*

    def func(x,y,*args): # args=(3,4,5,6)
        print(x,y,args)
     
    func(1,2,[3,4,5,6])
    func(1,2,*[3,4,5,6]) # func(1,2,3,4,5,6)
    func(*'hello') # func('h','e','l','l','o')
    #h e ('l', 'l', 'o')

    可变长度的关键字参数

    形参格式 * * 形参名:用来接收溢出的关键实参** 会将溢出的关键字实参保存成字典格式,然后赋值给紧跟后面的参数名

    **后跟的可以是任意名字,但是约定俗成应该是 kwargs

    def func(x,y, **kwargs):
        print(x,y,kwargs)
    func(1,y=2,a=1,b=2,c=3) #1 2 {'a': 1, 'b': 2, 'c': 3}
    

     ** 形参名:用来接收溢出的关键字实参,**会将溢出的关键字实参保存成字典格式,然后赋值给紧跟其后的形参名

    def func(x,y,**kwargs):
        print(x,y,kwargs)
     
    func(1,y=2,a=1,b=2,c=3)   #   1 2 {'a': 1, 'b': 2, 'c': 3}
    

     ** 可以用在实参中 (** 后跟的只能是字典),实参中带** ,先**后的值打散成关键字实参

    def func(x,y,z):
        print(x,y,z)
     
    func(*{'x':1,'y':2,'z':3}) # func('x','y','z')
    func(**{'x':1,'y':2,'z':3}) # func(x=1,y=2,z=3)
     
    错误
    func(**{'x':1,'y':2,}) # func(x=1,y=2)
    func(**{'x':1,'a':2,'z':3}) # func(x=1,a=2,z=3)
    

    形参与实参中都带**

    def func(x,y,**kwargs):
        print(x,y,kwargs)
     
    func(y=222,x=111,a=333,b=444)     #111 222 {'a': 333, 'b': 444}
    func(**{'y':222,'x':111,'a':333,'b':4444})     #111 222 {'a': 333, 'b': 4444}

    混用* 与 ** : * args必须在**kwargs之前(无敌模式)

    def func(x,*args,**kwargs):
        print(args)
        print(kwargs)
     
    func(1,2,3,4,5,6,7,8,a=1,y=2,z=3)
    

      

    命名关键字参数(了解) 
    命名关键字参数:在定义函数时,*后定义的参数,如下所示,称之为命名关键字参数# 特点:
    1、命名关键字实参必须按照key=value的形式为其传值
    def func(x,y,*,a,b): # 其中,a和b称之为命名关键字参数
        print(x,y)
        print(a,b)
    
    func(1,2,b=222,a=111)
    

      

    def func(x,y,*,a=11111,b):
        print(x,y)
        print(a,b)
    
    func(1,2,b=22222)
    

      

    组合使用(了解)

    形参混用的顺序:位置新参,默认形参,*args,命名关键字形参,**kwargs

    def func(x,y=111,*args,z,**kwargs):
      print(x)
      print(y)
      print(args)
      print(z)
      print(kwargs)
    

      

      

    实参混用的顺序:
    def func(x,y,z,a,b,c):
        print(x)
        print(y)
        print(z)
        print(a)
        print(b)
        print(c)
    

      

    func(111,y=222,*[333,444],**{'b':555,'c':666})  错误
    func(111,y=222,333,444,b=555,c=666)   错误
    
    func(111,*[333,444],a=222,**{'b':555,'c':666})    可以
    func(111,333,444,a=222,b=555,c=66)     可以
    
    func(111,*[333,444],**{'b':555,'c':666},a=222,)   可以
    func(111,3333,4444,b=555,c=666,a=222)   可以
    

      

    func(1)
    func(x=1)
    func(1,x=1)
    func(*'hello')
    func(**{})
    func(*'hell',**{})
    

      

  • 相关阅读:
    JSP中getParameter和getAttribute区别
    用jsp实现省市区三级联动下拉
    SQL
    Unity3d笔试题大全
    FPSCalc——简单FPS观测类
    GameObjectPool——Unity中的对象池
    MonoSingleton——Unity中的单例模式
    用非递归、不用栈的方法,实现原位(in-place)的快速排序
    一道有序洗牌的笔试题,阿里UC等都用过
    MFC中显示图像的放大、缩小、移动功能
  • 原文地址:https://www.cnblogs.com/Tornadoes-Destroy-Parking-Lots/p/12518557.html
Copyright © 2020-2023  润新知