python中的变量:

一个变量是局部还是全局,在编译函数的时候就已经决定,因此读变量值的时候也不会逐层向外查找。变量是全局还是局域,根据如下3条:

  1. 如果函数内部有global语句,那么它声明的变量是全局的。

  2. 如果函数内部有对变量的赋值语句,那么它是局域的。

  3. 除此之外都是全局的。

注意1和2,和语句的位置无关,只要有这样的语句,那么它的范围就确定了。例如:

  1. def f():
  2. print x
  3. if 0:
  4. x = 1

上面的程序中存在x=1,因此x为局域变量。(运行报错)

  x = 0

  def  f():
    print x

上面的程序不报错,x为全局变量,符合第三条  

只有一种特例会逐层向外查找,函数体内存在exec语句时,例如:

  1. def f3():
  2. exec("")
  3. a = 1
  4. global b
  5. print a,b,c

在这个程序中,根据规则1和2,a是局域,b是全局。而c符合第3种情况,但存在exec语句,因此它变成了逐层向外查找,这样可以应付exec("c=100")这样的情况,读取c时,先在locals()中查找c,找不到的话就在全局globals()中寻找。

Python 支持4种参数传递的方式:

1.定义:

F(a,b)

调用:

F(1,2)

2.定义:

F(a,b=9)

调用:

F(1) 或 F(1,2)  #第二个参数未给出的话,使用默认的值 9

3.定义:

F(*a)

调用:

F(1) 或 F(1,2)或F(1,2,3)

#这种方式可以接收任意多个参数保存到名为a的元组中,在函数内部可通过a元组访问这些参数

4.定义:

F(**a)

调用:

F(x=1)或F(x=1,y=2)

## 这种方式同样可以接收任意多个参数,并将参数保存到名为a的字典中,字典表示为{'x':1}或{'x':1,'y':2}

上面*号都是出现在函数的定义中

其实*号同样可以出现在函数的调用中,实际效果与在定义中使用刚好相反,下面给出实例代码:

  1.  #!/usr/bin/env python
    def F(a,b):
    print a,b argv = (1,2)
    #argv = [1,2]
    #argv = {'a':1,'b':2}
    F(*argv)  

调用 F(*argv),将输出 1,2

将argv 定义成代码中注释掉的列表,字典仍然有效,且对于字典F(*argv)与F(**argv) 调用结果相同

由此我们可以这样理解:

函数定义中的 * ,用于将多余的参数合并为一个元组 (对于 ** 是合并为字典)

函数调用中的* ,用于将元组或列表或字典参数,分解为单个的变量值,并做为参数传递 (ps:暂时只能这样表述了 )

Python 参数传递的更多相关文章

  1. Python参数传递(传值&传引用)

    # 测试参数是传值还是传引用def test(arg): print("test before") print(id(arg)) arg[1]=30 # 测试可变对象 # arg[ ...

  2. Python参数传递,既不是传值也不是传引用

    面试的时候,有没有被问到Python传参是传引用还是传值这种问题?有没有听到过Python传参既不是传值也不是传引用这种说法?一个小小的参数默认值也可能让代码出现难以查找的bug? 如果你也遇到过上面 ...

  3. Python学习日记(十)—— 杂货铺(全局变量补充、Python参数传递、字符串格式化、迭代器、生成器)

    全局变量补充 python自己添加了些全局变量 print(vars()) """结果: {'__name__': '__main__', '__doc__': None ...

  4. Python参数传递中的 args, kwargs

    概念 真正的Python参数传递语法是*和**,其被称为 被称为打包和解包参数.*args和**kwargs只是大家默认的一种形式.也可以写成*keys和**kkeys等其他形式.二者都是为了在不知道 ...

  5. python 参数传递 传值还是传引用

    个人推测结论: 可变对象传引用,不可变对象传值 python里的变量不同于c中地址储值模型 a=100 b=100 print(id(a),id(b),a==b,a is b) #8790877986 ...

  6. python参数传递:对象的引用

    大家都知道在python中,一切皆对象,变量也不再具有类型,变量仅仅是对象的一个引用,我们通常用变量来测类型,通常测得就是被这个变量引用得对象的类型. python采用的是传递对象的引用,为了方便说明 ...

  7. python参数传递

    1.形式参数:在定义函数时,函数名后面括号中的参数为“形式参数”,也称形参 2.实际参数:在调用一个函数时,函数名后面括号种的参数为“实际参数”,也就是将函数的调用者提供给函数的参数称为实际参数,也称 ...

  8. Python引用复制,参数传递,弱引用与垃圾回收

    引用 先上个示例: >>> val = [1] >>> val[0] = val >>> val [[...]] 上述代码使val中包含自身,而产 ...

  9. Python中的参数传递问题

    首先需要说明python中元组,列表,字典的区别. 列表: 什么是列表呢?我觉得列表就是我们日常生活中经常见到的清单. 例如:lst = ['arwen',123] 向list中添加项有两种方法:ap ...

随机推荐

  1. Hive学习之动态分区及HQL

    Hive动态分区 1.首先创建一个分区表create table t10(name string) partitioned by(dt string,value string)row format d ...

  2. 张孝祥Java高新技术汇总

    一.自动装箱和拆箱: 在Java中有8种基本数据类型:byte,short,int,long,float,double,char,boolean.而基本数据类型不是对象,这时人们给他们定义了包装类,使 ...

  3. FileInputStream(字节流)与fileReader(字符流) 的区别

    FileInputStream 类 1 ) FileInputStream 类介绍: 以字节为单位的流处理.字节序列:二进制数据.与编码无关,不存在乱码问题. FileInputStream 类的主要 ...

  4. hdu 1823 Luck and Love 二维线段树

    题目链接 很裸的题, 唯一需要注意的就是询问时给出的区间并不是l<r, 需要判断然后交换一下, WA了好多发... #include<bits/stdc++.h> using nam ...

  5. Cortex-M3动态加载三(模块调用系统函数)

    在我的arm动态加载实验中需要解决一个模块调用系统函数的问题,可以使用以下的一个方法.将系统函数固定在某一段地址空间,然后导出这一块的符号表到符号文件中,要记载的模块link的时候使用这个符号表文件, ...

  6. JAVA并发,CyclicBarrier

    CyclicBarrier 翻译过来叫循环栅栏.循环障碍什么的(还是有点别扭的.所以还是别翻译了,只可意会不可言传啊).它主要的方法就是一个:await().await() 方法没被调用一次,计数便会 ...

  7. 什么是LED锡膏?

    LED锡膏熔点172℃,俗称中温锡膏,其合金为Sn64Bi35Ag1,此类产品是含Bi类的低熔点无铅锡膏,加入Ag改变了SnBi合金的焊点的机械强度.大幅度提高焊点可靠性,适用于高频调谐器系列产品的贴 ...

  8. HUB主要芯片方案

    HUB主要品牌:慧荣.擎泰.联盛  安国.创惟 创惟GL850G简介:拥有低耗电.温度低及接脚数减少等产品特性.它支援4个下游连接埠,采用48 pin LQFP封装,可完全支援USB 2.0/1.1规 ...

  9. Qt信息隐藏(Q_D/Q_Q)介绍——从二进制兼容讲起

    http://www.cnblogs.com/SkylineSoft/articles/2046404.html

  10. nat123外网SSH访问内网LINUX的N种方法

    一,动态公网IP环境 1,环境描述: 路由器分配的是动态公网IP,且有路由管理权限,LINUX主机部署在路由内网.如何实现外网SSH访问内网LINUX主机? 2,解决方案: 使用nat123动态域名解 ...