Python中数据模型与对象模型的关系是什么?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。
对象有三个要素:编号(identity)、类型(type)、值(value)。
编号就是对象的内存地址,从创建后就不会改变。is运算符用来比较2个对象的编号。id()函数返回对象编号的整数表示。
identity也可以翻译为身份,对象身份。
类型决定了可以对对象做哪些操作,也定义了对象的可能值,比如int
和bool
类型的值就不一样。type()
函数返回对象类型。很多人会误以为Python是弱类型语言,其实Python是强类型语言,这个误解的真实原因是,Python不需要编译,不需要提前知道变量的类型,在运行时才检查类型,这应该叫做动态语言。
JavaScript是弱类型语言,在Python中1+"2"会运行失败,在JavaScript中能运行成功。
类型在创建后也不会改变,虽然可以进行类型转换,但转换实际会产生新对象:
a = 1 print(id(a)) print(id(str(a))) print(id(a))
结果为:
140715000207008 2136059506160 140715000207008
对象三要素中唯一能改变的就只有值了。官网有一句正确的废话:允许改变值的对象是mutable
(可变的),不允许改变值的对象是immutable
(不可变的)。它的意义在于当不可变对象的值是对可变对象的引用时,该如何判断对象的可变性?结论是不可变对象仍然是不可变的,因为这个引用是不能变的,但是我们通常会认为这个不可变对象的值是可变的,尤其是对象容器。对象类型也会决定是否可变,比如numbers
、strings
、tuples
是不可变的,dictionaries
、lists
是可变的。
有些对象包含了对其他对象的引用,这叫做containers
对象容器,比如tuples
、lists
、dictionaries
。大多数情况下,我们说容器的值,说的是引用的对象的值,而不是引用编号。但讨论容器可变性时,则仅仅是指容器直接包含的引用编号。比如tuple
是不可变的,如果它包含了对一个可变对象的引用后,当该可变对象改变时容器的值也会改变。
对象不会被显式销毁,但是它们会被当做垃圾回收,只要不存在对象引用,这就是Python垃圾回收机制!垃圾回收机制比较复杂,比如循环引用,实际上已经没有使用了,但是还存在引用等,涉及到算法规则,等写完Python进阶,在写Python原理时做进一步研究。
Python垃圾回收机制不是银弹,不能解决所有问题,所以在引用外部资源,比如打开文件后,我们需要注意显式close,防止资源始终占用内存,无法释放,造成内存泄漏。close除了手动调用close()
方法外,也可以使用with来自动close。
使用try...except可能会让对象继续存活。
对象的类型几乎决定了对象的一切行为,甚至是对象编号,比如对于不可变类型:
a = 1 b = 1
a和b可能会指向同一个值为1的对象,也可能会指向两个不同的值为1的对象,这取决于具体实现。
但是对于可变类型:
c = [] d = []
c和d一定会指向两个不同的单独的空列表。
注意c = d = [] 则是将同一个对象赋值给 c 和 d。
关于Python中数据模型与对象模型的关系是什么问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注亿速云行业资讯频道了解更多相关知识。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。