目录
1.简述执行Python程序的两种方式以及他们的优缺点:
1.1交互式:编写一条翻译一条
优点:调试方便
缺点:数据无法永久保存,关闭即消失
1.2命令行式:写完所有代码再翻译
优点:数据永久保存
缺点:调试麻烦
2.简述Python垃圾回收机制:
引用计数: 当一个变量值的引用计数为0时,会触发垃圾回收机制,该变量值会被回收
标记清除: 为了解决循环引用,引出了标记清除
1.维护引用计数消耗资源
2.循环引用,就是两个对象你指向我,我指向你,但是没有被外界引用
a = 10
a = 20
引用计数指的是后面的10和20
标记清除指的是前面的a引用变量
分代回收: 为了提高效率,又引出了分代回收
分代回收,是利用了空间换时间的操作
Python将内存根据对象的存活时间划分为不同的集合,
每个集合称为一个代,python分了三个代;老中少;
垃圾收集频率随对象的存活时间的增大而减小。
新创建的对象都会分配在年轻代,年轻代链表的总数达到上限时,
Python垃圾收集机制就会被触发,把那些可以被回收的对象回收掉,
而那些不会回收的对象就会被移到中年代去,
依此类推,老年代中的对象是存活时间最久的对象,甚至是存活于整个系统的生命周期内。
同时,分代回收是建立在标记清除技术基础之上。
分代回收同样作为Python的辅助垃圾收集技术处理那些容器对象
3.对于下述代码:
x = 10
y = 10
z = 10
del y
10的引用计数为多少?
答:2
x = 257
y = x
del x
z = 257
x对应的变量值257的引用计数为多少?
答:1
4.简述Python小整数池概念:
在打开python时[-5,256]之间的整数,就在内存已经写死了。并且在这个区间的整数不会触发垃圾回收机制
5.对于x = 10
,请用Python代码分别打印变量值、变量值内存地址和变量数据类型:
x = 10
print(x)
print(id(x))
print(type(x))
6.对于下述代码:
x = 257
y = x
z = 257
print(id(x),id(y),id(z))
请判断x、y、z的变量值是否相同?x、y、z的所在的内存地址是否相同?请用python代码阐述为什么?
答:x y z的变量值相同,x和y的内存地址相同,z的不相同。因为x和y都指向第一个开辟的257,而z是单独开辟的内存。但在pychar中地址都相同,因为pythar的小整数池包含了257。
7.简述数字类型
整型与浮点型统称为数字型
用于加减乘除,逻辑判断(大于,小于)
8.简述字符串类型
将字符串连起来就是字符串字符串只能+,*和逻辑比较