内存地址的变化

>>> a = [1,2,3,4]
>>> b = a
>>> id(a),id(b)
(139877719463120, 139877719463120)
>>> a.pop()
4
>>> a
[1, 2, 3]
>>> b
[1, 2, 3]
>>> id(a),id(b)
(139877719463120, 139877719463120)
>>> a = [1,2]
>>> b
[1, 2, 3]
>>> id(a),id(b)
(139877719537712, 139877719463120)
>>> 

开始的时候a,b同时指向内存地址为139877719463120中的数据。
函数pop()直接在内存地址中修改数据,造成了内存地址不变,但是里面的数据发生变动。
同时指向内存地址的a,b数据发生了变动

>>> a = [1,2]
>>> b
[1, 2, 3]
>>> id(a),id(b)
(139877719537712, 139877719463120)

重新定义了啊的内存地址,但是b的内存地址并没有变动

字典同理

>>> a = {'one':1,'two':2,'three':3,'four':4}
>>> b = a
>>> id(a),id(b)
(139877719583552, 139877719583552)
>>> a
{'four': 4, 'three': 3, 'two': 2, 'one': 1}
>>> b
{'four': 4, 'three': 3, 'two': 2, 'one': 1}
>>> a.clear()
>>> a
{}
>>> b
{}
>>> id(a),id(b)
(139877719583552, 139877719583552)

元组不能改变,只能重新定义

>>> a = (1,2,3,4)
>>> b = a
>>> a
(1, 2, 3, 4)
>>> b
(1, 2, 3, 4)
>>> a.pop()
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
AttributeError: 'tuple' object has no attribute 'pop'
>>> a.clear()
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
AttributeError: 'tuple' object has no attribute 'clear'
>>> id(a),id(b)
(139877719726928, 139877719726928)
>>> a = a[:2]+a[2:]
>>> a
(1, 2, 3, 4)
>>> b
(1, 2, 3, 4)
>>> id(a),id(b)
(139877719524464, 139877719726928)
>>> 
在C语言中,`malloc` 和 `realloc` 是动态内存分配函数,用于在堆上分配内存。`malloc` 函数用于分配一块指定大小的内存区域,而 `realloc` 函数用于调整之前由 `malloc` 或 `calloc` 分配的内存区域的大小。 下面是使用 `malloc` 和 `realloc` 函数时,可能观察到的内存地址变化情况: 1. 使用 `malloc` 函数分配内存时,系统会在堆上查找一块足够大的空闲内存区域,并返回该区域的首地址。这个地址是系统通过内部算法动态分配的,因此每次运行程序时,即使是相同的分配请求,也可能得到不同的内存地址。 2. 如果使用 `realloc` 函数调整内存大小时,如果原有内存区域的后面有足够的连续空间,则 `realloc` 可能就在原有内存的基础上进行扩展,此时内存地址可能不变。但如果原内存区域后面没有足够的空间,系统需要在其他位置找到一块足够大的内存区域,将原内存中的数据复制到新的位置,并释放原有的内存区域,此时内存地址会发生变化。 3. `realloc` 函数在调整内存大小时,并不保证原有的数据不会被移动,所以在调用 `realloc` 后,应当用返回的新指针来访问内存区域,而不是原来的指针。 示例代码如下: ```c #include <stdio.h> #include <stdlib.h> int main() { int *p = (int*)malloc(10 * sizeof(int)); // 分配内存 printf("malloc 分配的内存地址: %p\n", (void*)p); // 假设系统允许的情况下,调整内存大小 p = (int*)realloc(p, 20 * sizeof(int)); if (p != NULL) { printf("realloc 调整后的内存地址: %p\n", (void*)p); } free(p); // 释放内存 return 0; } ``` 在这个例子中,我们首先使用 `malloc` 分配了10个整型的内存,然后使用 `realloc` 尝试调整为20个整型的空间。需要注意的是,在实际使用中,应当检查 `realloc` 的返回值以确定操作是否成功。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值