python类的引用变量
❶ python的类中引用成员变量必须加self吗
Python的类中引用成员变量必须加self
类(class)初始化之后会得到实例(instance)。 self就是用于代表初始化的到的实例。 明确地写一个self参数,使得类的方法(method)和普通的函数(function)本质上没有差异,所有的输入参数都显示地传递到方法/函数当中。 当然作为类的方法,作用的对.
self是只有在类中才会有的。self在定义类的方法时是必须有的,虽然在调用时不必传入相应的参数。 但self的名称并不是一定的,在python中self不是关键词。在初始化函数中可以把self换成任意名字.
❷ python3.2.3怎么引用赋值了的变量
先解释第三行中中括号。
python的语法里面,中括号可以表示index。t[1]
就表示
t
这个
list
的第一项。
再解释
int
和
list
变量赋值的问题。
第三行中,l=t[1],意思就是给
t
这个
list
的第一项起了个别名叫做
l。
这就好比给张三起了个名字叫小明,下文里不论提到张三还是小明,说的都是同一个人。
那么在第四行里
l[0]='d'
其实就等价于
t[1][0]
=
'd',相当于改变了list的内容。
这在编程里叫做aliasing,python
的
list
都是有aliasing的,但是
int
(整数)没有。
所以,在第二段中,把
x
放到
m
这个
list
里的时候,只是拷贝进去了一个数值,从此以后和
x
不再有关联了。
这就好比做了个张三的克隆人,那个克隆人后来怎样,跟张三都没什么关系了。
第15-18行也是一样的道理。
如果,把那几行改为a=[4];
b=a;
b[0]=5;
print
a;
这时就会打出5来了。
综上所述,造成第一段和第二段区别的主要原因就是它们涉及的数据类型不同,list
=
起别名,
int
=克隆人。
❸ 对python 中class与变量的使用方法详解
python中的变量定义是很灵活的,很容易搞混淆,特别是对于class的变量的定义,如何定义使用类里的变量是我们维护代码和保证代码稳定性的关键。
枚举了各种情况,没有办法全部枚举,但大部分情况应该都已经包含了。
1. 类变量:能够通过类名或者object的self来访问到,在类的内部和外部均可达,比如class_var_1
2. 对象变量:可以通过对象的self来使用的变量,通过constructor一路走向去的的self初次被赋值的变量都会成为对象变量,比如object_var_1, object_var_2, object_var_3, object_var_4
3. 内部变量:可以在函数中定义,并加上self前缀,在初次调用过定义的函数后,就可以在后面的对象的函数中被使用,比如internal_var_1
4. 局部变量:在函数内部定义,并使用的变量,在使用完之后就会被回收对类及object不可见
5. 全局变量:定义在类或者函数外部,作用域在变量被定义之后的任意代码段,比如:global_var_1
❹ python如何在一个模块中调用另一个模块中的变量
python在一个模块中调用另一个模块中的变量步骤如下:
1、要实现变量的深度拷贝,需要使用到模块,导入这个模块。
❺ Python中的类变量、实例变量、局部变量
类体内,所有函数外定义。
所有实例对象共享。
只有通过类名调用时才能修改,通过实例调用时无法修改。
假设某类变量名为“name",如果用该类的某个实例x来为name赋值:x.name = 'xxx',实质是为该实例新定义了一个变量name。且之后无法再通过该实例调用类变量name了。因为使用实例调用某名为“xxx”变量时,若该实例没有名为“xxx”的实例变量,则会去调用名为“xxx”的类变量;若有该名称的实例变量,则该实例无法再直接调用该名称对应的类变量。因此也不推荐通过实例来调用类变量。
即:通过类实例修改类变量的值时,实际是在定义新的与类变量同名的实例变量。
类体内,某函数(一般是__ init __ ())内定义。 “self.变量名”
因为是属于某个具体实例的,因此不能通过类名访问。
如果不在__ init __ () 中调用(该函数会在创建实例时自动调用一次),则只有调用该实例中定义目标实例变量的那个函数后,才能使用目标实例变量。因此最好在__ init __ () 中定义实例变量。
类体内,某函数内定义。
直接在函数内用“变量名=值”的方式进行定义。
函数执行完毕后,该局部变量即被销毁。
❻ python中变量的引用、可变和不可变类型、局部变量和全局变量
变量的引用
变量和数据都是保存在内存中的
变量和数据是分开存储的
数据保存在内存中某个位置,通过地址来标记
变量保存的是数据的地址,通过地址可以找到数据在内存空间的位置
把变量保存数据地址的过程称为引用
变量的重新赋值修改的是变量中引用数据的内存地址
变量之间的赋值实际是引用的传递
函数参数的传递,本质也是引用的传递
函数的返回值本身也是引用的传递
可变和不可变类型
不可变类型,内存中的数据不允许被修改:数字类型(int,bool,float,complex,long(2,x)、字符串、元组(tuple)
可变类型,内存中的数据可以被修改:列表list、字典dict
无论是可变还是不可变数据类型,通过赋值语句,都会改变变量的引用
Hash函数只能接收不可变数据类型,字典的键也只能是不可变数据类型,字典的value值可以是任意数据类型
局部变量
1.在函数内部定义的变量就是局部变量(作用范围只能是当前函数内部)
2.在函数外部无法直接访问局部变量
3.不同的函数中可以定义同名的局部变量
4.局部变量的生命周期:从定义变量时开始,到函数运行结束
全局变量
1.在所有函数外边定义的变量就是全局变量
2.让所有函数都能访问到,可以作为函数通信的桥梁
3.一般情况下,为了和普通变量的区别,需要加上g_或gl_前缀
4.全局变量一般放在所有函数的最上面
5.在函数内部修改全局变量,必须要加上global关键字,如果不加global只是定义了一个同名的局部变量
函数的多个返回值
❼ Python中的变量引用对象需注意的几点
给你介绍Python中普通引用和共享引用在引用对象中需要注意的点:
普通引用:
Python中,变量的作用仅仅是一个标识,只有赋值后才被创建,它可以引用任何类型的对象,而且在引用之前必须赋值。赋值后的变量指向响应的对象,拥有该对象的空间。类型属于对象,但是不是变量。
[python]
view plain
a = 3
a = "science"
上述代码说明数值3和字符串“science”分别是两种对象,初始变量a赋值对象3被创建,变量a指向对象3的内存空间,之后变量a又指向了字符串的内存空间。
共享引用:
[python]
view plain
a = 3
b = a
上述代码说明变量a,b同时引用了对象3,两个变量引用了相同的对象。正是因为两者都是指向了相同的对象,所以当其中一个变量引用其他对象的时候,不会对另一个变量造成影响。例如:
[python]
view plain
a = “science”
在上面代码的基础上,变量a引用了字符串对象“science”,此时变量b依旧引用对象3,而不是“science”。
但是有些对象的操作会在原处修改,例如列表。例如:
[python]
view plain
a = [1,2,3]
b = a
变量a,b应用了包含1,2,3对象的列表,自然而然的a[0]引用对象1,如果在变量a中执行操作
[python]
view plain
a[0] = 4
那么变量b就变随之变为[4,2,3]。避免这种情况可以使用操作,替换引用操作。