关于网友提出的“python中关于函数参数值传递的问题”问题疑问,本网通过在网上对“python中关于函数参数值传递的问题”有关的相关答案进行了整理,供用户进行参考,详细问题解答如下:
问题:python中关于函数参数值传递的问题
描述:现在有两个问题:
1.如果在一个类的定义中,想定义一个该类的对象,该怎么办?
class UserInfo:
bidderID = 0 #用户ID
name = " " #用户名
addr = " " #IP地址
port = 0 #端口号
rname = '' #所在竞拍室名称
bidprice = 0 #出价
str=''
next = UserInfo() #???
会在next= UserInfo()这里报错,提示说UserInfo未定义
2.怎样让传递给函数的参数(是一种自定义的类),在经过函数处理之后,可以改变它的值。
例如:
添加新用户n的信息
def addUser(self,n):
self.pointer = self.root
n.next = self.pointer.next
self.pointer.next = n
self.count += 1
当其他函数调用这个函数,self.userList.addUser(self.user)之后,userlist会真的增加一项。
解决方案1:1. 引用自身
虽然Python是动态解释型语言,但在解释到
class UserInfo:
# ...
next = UserInfo() # <===
这句时,由于类UserInfo还没定义结束,直接开始使用是不行的。但是Python本身由于是动态解释运行的,完全可以利用动态修改内容(甚至新增属性)来解决这个需求。例如
class UserInfo:
# ...
next = None
user = UserInfo()
user.next = UserInfo()
当然,这样就做不到一个类内初始化了,那么可以使用一些魔术方法
class UserInfo:
def __init__(self):
# 要注意执行__new__创建的实例是没经过__init__初始化的,切记
# 这在做很多lazy-loading的时候很管用
self.next = UserInfo.__new__(UserInfo)
参考:http://www.rafekettler.com/magicmethods.html#construction
2. 参数的引用传递
简单来说
- Python中的参数传递都是对参数引用的传递
- 参数的类型可以分为可变的(mutable)以及不可变的(immutable)
举点例子
list是可变的,如果在函数内直接对其进行修改,而不修改引用,那么将会改变参数内容
def test(n):
n.append(2)
m = [1]
test(m)
print(m) # 这里将会输出 [1, 2]
如果调换参数的引用的话
def test(n)
n = [2] # 这里其实已经将参数的引用调换了
m = [1]
test(m)
print(m) # 所以这里将输出[1]
str是不可变的,也没有对其inplace操作的方法,皆为返回一个新的copy
def test(n)
n = "Hello, Python!"
m = "Hello, World!"
test(m)
print(m) # 这里还是Hello, World!
stackoverflow上个更清楚的回答:
Python自己的文档也有说明:https://docs.python.org/3/faq/programming.html#how-do-i-write-a-function-with-output-parameters-call-by-reference
以上介绍了“python中关于函数参数值传递的问题”的问题解答,希望对有需要的网友有所帮助。
本文网址链接:http://www.codes51.com/itwd/1530292.html