day 03作业

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.简述字符串类型

将字符串连起来就是字符串字符串只能+,*和逻辑比较

原文地址:https://www.cnblogs.com/LZF-190903/p/11493797.html