Python 变量 对象 引用

1.变量

变量第一次赋值时被创建,变量在使用前必须赋值

变量本身没有类型,变量类型为它引用的对象类型;

变量在使用时被替换成它引用的对象

2.对象

对象本身具有计数和类型,变量引用对象,当对象的引用变为0的时候,回收对象内存。但是类似INT等小类型对象,不一定立马回收它的内存。

修改指向同一个可变对象的任何一个变量,都会影响到指向的对象,也就是两个变量的值都会被修改。

>>> l=[1,2,9]
>>> s= l
>>> s[0]=11
>>> s
[11, 2, 9]
>>> l
[11, 2, 9]
>>>

可变对象之间的拷贝:

1. copy.copy 浅拷贝 只拷贝父对象,不会拷贝对象的内部的子对象。
2. copy.deepcopy 深拷贝 拷贝对象及其子对象

3.可以通过is 来判断2个对象是否是同一个

import copy
a = [1, 2, 3, 4, [‘a‘, ‘b‘]]  #原始对象

b = a  #赋值,传对象的引用
c = copy.copy(a)  #对象拷贝,浅拷贝
d = copy.deepcopy(a)  #对象拷贝,深拷贝

a.append(5)  #修改对象a
a[4].append(‘c‘)  #修改对象a中的[‘a‘, ‘b‘]数组对象

print(‘a= ‘,a)
print(‘b= ‘,b)
print(‘c= ‘,c)
print(‘d= ‘,d)
print(‘a is b‘, a is b)
print(‘a is c‘, a is c)
print(‘d is a‘, d  is a)

输出结果:
a=  [1, 2, 3, 4, [‘a‘, ‘b‘, ‘c‘], 5]

b=  [1, 2, 3, 4, [‘a‘, ‘b‘, ‘c‘], 5]

c=  [1, 2, 3, 4, [‘a‘, ‘b‘, ‘c‘]]

d=  [1, 2, 3, 4, [‘a‘, ‘b‘]]

a is b True

a is c False

d is a False

时间: 2024-10-13 17:29:39

Python 变量 对象 引用的相关文章

Python——变量的引用和函数的参数和返回值的传递方式

变量的引用 在python中,所有的变量都是指向地址,变量本身不保存数据,而是保存数据在内存中的地址.我们用下面的程序来理解: 1 a = 10 2 print(id(a)) 3 a = 11 4 print(id(a)) (利用id( )方法查看数据的地址) 输出结果为: 可以发现:修改变量的值,变量保存的地址随之改变. python中: 变量和数据是分开存储的 变量 中保存着数据在内存中的地址 我们把变量中记录数据的地址的行为,叫做 引用. 通俗的来说,在 Python 中,变量的名字类似于

python变量、引用、拷贝之间的关系

Python中一切皆为对象,不管是集合变量还是数值型or字符串型的变量都是一个引用,都指向对应内存空间中的对象. 简而言之: 变量直接赋值:新变量本身及其内部的元素都与原变量指向相同的内存空间,并且值相同,当一个发生变化时,另一个也随之变化. 变量浅拷贝:新变量本身与原变量指向不同的内存空间,但是新变量内部的元素与原变量指向相同的内存空间:当改变原变量内部的可变对象的值时,新变量内部的值也发生随之变化:改变原变量内部的不可变对象的值时,新变量内部的值不随之变化:反之亦然(即改变新变量时). 变量

Python 变量&对象初识

Python中没有常量类型,但为了与其他语言保持一致,我们约定用全大写的变量名代表常量. 关于变量创建,与c不同,python的变量只有在被赋值之后,才会被创建,才会被分配内存空间. 变量不需要声明类型,赋值即包含了声明和定义. 对变量赋值,实际上是把对象的引用赋给变量.本质上,Python的变量与c中的指针类似. a=1 #这里的1实际上是一个整型对象,不可变对象,变量a指向这个对象的地址. b=a #变量b同样指向1这个对象的地址. a=2 #2是新创建的整型对象,指针a指向2的地址,此时,

python中的引用传递,可变对象,不可变对象,list注意点

python中的引用传递 首先必须理解的是,python中一切的传递都是引用(地址),无论是赋值还是函数调用,不存在值传递. 可变对象和不可变对象 python变量保存的是对象的引用,这个引用指向堆内存里的对象,在堆中分配的对象分为两类,一类是可变对象,一类是不可变对象.不可变对象的内容不可改变,保证了数据的不可修改(安全,防止出错),同时可以使得在多线程读取的时候不需要加锁. 不可变对象(变量指向的内存的中的值不能够被改变) 当更改该对象时,由于所指向的内存中的值不可改变,所以会把原来的值复制

final修饰的变量是引用不能变还是对象的内容不能变?

int a=1;此时a是变量: StringBuffer a=new StringBuffer();此时a就是引用变量,可以说是a引用String对象,通过a来操作String 对象 final StringBuffer a=new StirngBuffer(); a=new StringBuffer();会报错: a.append("两");没错 这就说明final 修饰的变量是引用不能变,对象的内容可以变的:

final修饰的变量是引用不能改变还是引用的对象不能改变

我们都知道final修饰变量时 会变为常量,但是使 用final关键字修饰一个变量时,是引用不能变,还是引用的对象不能变? 下面让我们来看这段代码: /** * 验证final修饰的变量是引用不能变,还是引用的对象不能变 * StringBuilder 线程不安全 但速度快 * 引用初始化以后不能被改变 --- 不是指变量的值不可变,而是指向的变量地址不可变 * @author Tomato * */ public class TestFinal { public static void mai

python 变量引用

最近在看<<流畅的python>>关于变量引用部分时,有一些自己的看法,就再次记录一下. 问题: # From flunet python example 8-8 class Bus: def __init__(self, passengers=[]): self.passengers = passengers def pick(self, name): self.passengers,append(name) def remove(self, name): self.passen

python的计数引用分析(一)

python的垃圾回收采用的是引用计数机制为主和分代回收机制为辅的结合机制,当对象的引用计数变为0时,对象将被销毁,除了解释器默认创建的对象外.(默认对象的引用计数永远不会变成0) 所有的计数引用+1的情况: 一.对象被创建:1.a = 23 这里23这个对象并没有在内存中新建,因为在Python启动解释器的时候会创建一个小整数池,-5~256之间的这些对象会被自动创建加载到内存中等待调用:a = 23是为23这个整数对象增加了一个引用.执行代码: >>> import sys >

python string 对象

上一篇的整数对象是定长数据,即C中的long型整数. 但是python中还大量存在着不定长的数据类型.如字符串对象 和整数对象一样,字符串对象的组成如下: PyStringObject定义如下: Ob_size就是实际使用的内存大小,在注释中:ob_sval contains space for 'ob_size+1' elements. 因为末尾需要额外包含一个0 byte来保证字符串的结束. 这个学过C语言的应该都不会陌生的.但是这只是一个字符数组,怎么能包含N个字符呢? 显然这只能是一个字