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

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

  • 相关阅读:
    005 字符串
    004 变量
    003 python中的内置函数
    002 如何在一台PC上装两个版本的python
    在github上创建新的分支(包括管理分支)
    使用git工具上传自己的程序到github上
    004 Java的一次面试题,学长列举
    为什么分布式一定要有Redis?
    027 ResourceBundle.getBundle方法
    Jenkins下载安装
  • 原文地址:https://www.cnblogs.com/LZF-190903/p/11493797.html
Copyright © 2020-2023  润新知