python 中,变量是以内容为基准而不是像 c 中以变量名为基准
- python 不使用 ++ 的哲学逻辑:编译解析上的简洁与语言本身的简洁,就不具体翻译了。
- 后面还有老外回答并附带了一个例子非常的精彩,指出了 python 与 c 语言概念上的一些差异,语言描述的可能未必准确,直接上例子:
-
>>> b = 5 >>> a = 5 >>> id(a) 162334512 >>> id(b) 162334512 >>> a is b True
-
>>> a, b, c, d([1, 2, 3], [1, 2, 3], [1, 2, 3], [1, 2, 3])
-
>>> b[0] = 'b'
-
>>> a, b, c, d(['b', 2, 3], ['b', 2, 3], ['b', 2, 3], [1, 2, 3])
-
>>> id(a), id(b), id(c), id(d)(140180778120200, 140180778120200, 140180778120200, 140180778122696)
-
>>> c[0] = 'c'
-
>>> a, b, c, d(['c', 2, 3], ['c', 2, 3], ['c', 2, 3], [1, 2, 3])
-
>>> id(a), id(b), id(c), id(d)(140180778120200, 140180778120200, 140180778120200, 140180778122696)
- 可以看出, python 中,变量是以内容为基准而不是像 c 中以变量名为基准,所以只要你的数字内容是5,不管你起什么名字,这个变量的 ID 是相同的,同时也就说明了 python 中一个变量可以以多个名称访问。 拷贝解析:a.copy() ID虽不同,但a的子对象(内部)改变,b也改变,只有copy模块的深拷贝才是两个独立个体
- 这样的设计逻辑决定了 python 中数字类型的值是不可变的,因为如果如上例,a 和 b 都是 5,当你改变了 a 时,b 也会跟着变,这当然不是我们希望的。
- 因此,正确的自增操作应该 a = a + 1 或者 a += 1,当此 a 自增后,通过 id() 观察可知,id 值变化了,即 a 已经是新值的名称。
-
纠正一下楼上的一些观点
楼上的同学所说的在脚本式编程环境中没有问题。但是在交互式环境中,编译器会有一个小整数池的概念,会把(-5,256)间的数预先创建好,而当a和b超过这个范围的时候,两个变量就会指向不同的对象了,因此地址也会不一样,比如下例:
>>> a=1000 >>> b=1000 >>> id(a);id(b) 2236612366224 2236617350384>>>
python 中,传参只有传可变参数且修改参数内部,才内外都改变
def dc(a):
#a[1]=9 //以内容为基准,当作指针 --可认为传递的是拷贝的指针 a= 内指针指向改变,外a内容不变 ; a[ ]=内外a指向相同,内容改变
a=[11,12]
return a
a=[2,3,4]
#a[1]=9 //以内容为基准,当作指针 --可认为传递的是拷贝的指针 a= 内指针指向改变,外a内容不变 ; a[ ]=内外a指向相同,内容改变
a=[11,12]
return a
a=[2,3,4]
#a=(1,2) //函数内[11,12],函数外(1,2)
print(dc(a))
print(a)
print(dc(a))
print(a)
python 中,函数中用全局变量
def ss(a):
#c=a+b // --可认为传递的是拷贝的指针 ,b=a只改变局部变量b的指向,全局b仍指向1
b=a
print(b)
b=1
ss(2)
print(b)
#c=a+b // --可认为传递的是拷贝的指针 ,b=a只改变局部变量b的指向,全局b仍指向1
b=a
print(b)
b=1
ss(2)
print(b)
python 中,元组在输入时可能无括号,逗号分隔