python函数传对象 python对象

python中如何将函数的运算结果传出来作为函数参数使用?首先你要明白,Python的函数传递方式是赋值 , 而赋值是通过建立抄变量与对象的关联实现的 。
对于你的代码:
执行 d = 2时,你在__main__里创建了d,并让它指向2这个整型对象 。
执行函数add(d)过程中:
d被传递给add()函数后,在函数内部,袭num也指向了__main__中的百2
但执行num = num + 10之后,新建了对象12,并让num指向了这个新对象——12 。
如果你明白函数中的局部变量与__main__中变量的区别 , 那么很显然,在__main__中,d仍在指着2这个对象,它没有改变 。因此,你打印d时得到了2 。
如果你想让输出为12,最简洁的办法是:度
在函数add()里增加return num
调用函数时使用d = add(d)
代码如下:
def add(num):
num += 10
return num
d = 2
d = add(d)
print d
python函数调用的参数传递python的函数参数传递是"引用传递(地址传递)" 。
python中赋值语句的过程(x = 1):先申请一段内存分配给一个整型对象来存储数据1,然后让变量x去指向这个对象 , 实际上就是指向这段内存(这里有点和C语言中的指针类似) 。
在Python中,会为每个层次生成一个符号表,里层能调用外层中的变量,而外层不能调用里层中的变量,并且当外层和里层有同名变量时,外层变量会被里层变量屏蔽掉 。函数调用会为函数局部变量生成一个新的符号表 。
局部变量:作用于该函数内部 , 一旦函数执行完成,该变量就被回收 。
全局变量:它是在函数外部定义的,作用域是整个文件 。全局变量可以直接在函数里面应用,但是如果要在函数内部改变全局变量,必须使用global关键字进行声明 。
注意 :默认值在函数定义作用域被解析
在定义函数时 , 就已经执行力它的局部变量
python中不可变类型是共享内存地址的:把相同的两个不可变类型数据赋给两个不同变量a,b,a , b在内存中的地址是一样的 。
python如何使用socket来传输对象import socket
import struct
sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
sock.connect(('localhost', 10000))
values = (1, 'ab', 2.7)
packer = struct.Struct('I 2s f')
packed_data = https://www.04ip.com/post/packer.pack(*values)
try:
sock.sendall(packed_data)
finally:
sock.close()
有个模块叫struct,可以自定义结构体,可以这样发送代码 。
try:
import cPickle as pickle
except:
import pickle
class AA():
def a(self):
print "123"
ddd = AA()
data = https://www.04ip.com/post/pickle.dumps(ddd)
还有个模块叫pickle,可以打包任何python对象,打包的结果也可以拿到套接字里发 。
python函数传参是传值还是传引用python中所有数据都是对象,所以传参也是传的对象的引用,这个引用在函数执行前和执行后是不会被改变的,如:
num = 1
def change(num):
print(id(num))
num = 2
print(id(num))
执行change(num)后num的值还是1
可以看到在执行前num的id值(可以理解为内存地址)是某一值
但在执行change后 , num的id值改变了,也就是说内部的num指向了另外的对象,而外部的num却还是指向原来的对象 , 所以值没有变;
同理 , 如:
num_list = [1,2]
def change_list(num_list):
print(id(num_list))
num_list.append(3)
print(id(num_list))
可以看到执行change_list后num_list的id值没有改变,也就是说num_list是在原来的对象上添加了新的数据,外部的num_list也是指向这一对象,所以外部的num_list数据也添加了新的数据 。

推荐阅读