-
垃圾回收机制
在python中,申请和释放内存空间都是由python自动完成的,在清除垃圾文件的时候有三种垃圾回收机制-
引用计数
当数据值绑定一次,他的引用计数为1,当数据值的引用数据为0时,说明这个数据值没有被绑定,是个垃圾文件,就会被垃圾回收机制回收
但有一个问题,当两个垃圾文件相互引用时,引用计数回收机制就失效了,这时候就得用上第二个垃圾回收机制了 -
标记清除
用于处理循环引用的问题,每过一段时间,将内存空间程序产生的所有数据值都检查一遍,检查是否存在循环引用,将检查出来的打上标记,最后一起清除
可是每过一段时间就检查一次所有数据值,资源浪费太多,所以最后有了第三个垃圾回收机制 -
分代回收
为了减少资源的损耗,设置了三代管理,新数据都放在第一代里,每过5分钟检查一次,检查了三次以后如果还是有很多的引用计数,则会放到下一代
每一代的检测频率会逐渐降低
-
-
字符编码简介
- 字符编码只有文本文件才能使用,在python里就是字符串数据类型
- 计算机只能识别二进制数0和1
- 我们能在计算机里打出各种文字就是因为将文字和二进制数一一对应
- 转换的关系应该有统一的一个标准,不能每个人都不同所以有了字符编码表
-
字符编码发展史
-
初期
计算机最开始由美国人发明,美国人需要让计算机能够识别英文字符,当时他们就只考虑了大小写字母、数字和英文符号,只用了1bytes就能够全部存下,所以发明除了ASCII码:用来记录英文字符和二进制数的对应关系

-
中期
其他国家也有计算机了,也需要让计算机能够识别自己国家的文字,所以需要开发一套属于自己的编码表
中国:GBK码,记录了中文字符,英文字符,数字与二进制数的对应关系,用1bytes存储英文字符,2bytes存储中文字符(遇到生僻字使用更多字节)
日本:shift_JIS码,记录了日文字符,英文字符,数字与二进制数的对应关系
韩国:Euc_kr码,记录了韩文字符,英文字符,数字与二进制数的对应关系
此时在中国计算机的文件发给日本计算机打开,会发生乱码的情况 -
后期
万国码(Unicode):兼容所有国家字符,所有的字符都以2bytes以上存储
因为所有字符都以2bytes以上存储,占用的存储空间太多了所以有了utf
utf家族(针对于Unicode的优化版):英文采用1bytes,其他均使用3bytes(内存里边使用的Unicode,硬盘使用utf8)
-
-
字符编码实操
- ###怎么解决乱码
使用编码的格式解码 -
编码与解码
编码是以指定的编码将人类的字符转换成计算机可以识别的数字
解码是将计算机能识别的数字以指定的编码转换成人类的字符"""字符串有内置方法能够直接转换""" # 1.编码 s1 = '编码与解码' r1 = s1.encoed('utf8') print(r1) # b'\xe7\xbc\x96\xe7\xa0\x81\xe4\xb8\x8e\xe8\xa7\xa3\xe7\xa0\x81' 开头的b是bytes的意思 # 2.解码 t1 = r1.decode('utf8') # 只能以编码的方式解码,否则会报错 print(t1) # 编码与解码 # 3.解释器 """utf8出现的时间比python2晚,所以python2中默认使用的是ASCII码 python2中想要写中文需要在开头加上文件头: # coding:utf8 然后再在字符串的开头加上字母u """
- ###怎么解决乱码
-
文件操作简介
-
文件操作是什么
是通过编写代码来控制文件读写 -
什么是文件
文件就是计算机让用户能够操作硬盘数据的快捷方式之一 -
怎样用代码操作文件
# 使用关键字open # 第一种方式 file = open(‘路径’, r, encoding='utf8') # 三个参数分别是文件路径,读写模式,字符编码 print(file.read()) file.close() # 需要手动关闭 # 第二种方式 with open('路径', r, encoding='utf8') as file: print(file.read()) # 子代码执行结束后自动调用close方法 """针对文件路径""" # 文件路径可能存在特殊含义(比如\n、\r),此时在路径字符串前加上字母r可以取消特殊含义
-
-
练习
# 1.统计列表中每个数据值出现的次数并组织成字典战士 # eg: l1 = ['jason','jason','kevin','oscar'] # 结果:{'jason':2,'kevin':1,'oscar':1} # 真实数据 l1 = ['jason', 'jason', 'kevin', 'oscar', 'kevin', 'tony', 'kevin'] d1 = {} # 创建一个空字典保存结果 for i in l1: # 循环列表,拿出每一个数据值 if i in d1: # 判断当前数据值是否在字典里 d1[i] += 1 # 存在则次数+1 else: d1[i] = 1 # 不存在则新建,值等于1 print(d1) # 2.编写员工管理系统 # 1.添加员工信息 # 2.修改员工薪资 # 3.查看指定员工 # 4.查看所有员工 # 5.删除员工数据 # 提示:用户数据有编号、姓名、年龄、岗位、薪资 # 数据格式采用字典:思考如何精准定位具体数据>>>:用户编号的作用 user_dict = {} while True: choice = input(""" 1.添加员工信息 2.修改员工薪资 3.查看指定员工 4.查看所有员工 5.删除员工数据 6.退出管理系统 请输入您要使用的功能:""").strip() if choice == '1': print('\n--添加员工信息--\n') number = input('number:').strip() if not (user_dict.get(number) is None): # 判断输入的编号是否存在 print('该编号以占用') continue name = input('name(letter):').strip() age = input('age(num):').strip() post = input('post(letter):').strip() pay = input('pay(num):').strip() if age.isdigit() and pay.isdigit() and (not name.isdigit()) and (not post.isdigit()): # 判断用户输入的数据格式是否正确 user_dict[number] = {'name': name, 'age': age, 'post': post, 'pay': pay} # 以编号为键,用户信息字典为值,保存在user_dict中 print(f'员工{name}添加成功') else: print('\n数据格式错误') elif choice == '2': print('\n--修改员工薪资--\n') post_num = input('希望修改薪资员工的编号:').strip() if not (user_dict.get(post_num) is None): # 判断编号对应员工是否存在 print(f'员工姓名:{user_dict[post_num]["name"]},当前薪资:{user_dict[post_num]["pay"]}') set_post = input('新的薪资:').strip() if set_post.isdigit(): # 判断新的薪资是否是数字 user_dict[post_num]['pay'] = set_post else: print('修改失败') else: print('该员工不存在') elif choice == '3': print('\n--查看指定员工--\n') check_num = input('想要查看员工的编号:').strip() if not (user_dict.get(check_num) is None): # 判断编号对应员工是否存在 print(f'number:{check_num}') for k, v in user_dict.get(check_num).items(): # 循环该员工的信息 print(f'{k}:{v}') else: print('该员工不存在') elif choice == '4': print('\n--查看所有员工--\n') for k, v in user_dict.items(): # 循环大字典,取出编号和小字典 print(f'number:{k}') # 先打印编号 for k1, v1 in v.items(): # 循环小字典 print(f'{k1}:{v1}', end='\t') # 打印字典内信息 print('\n') elif choice == '5': print('\n--删除员工数据--\n') del_num = input('输入想要删除员工编号:') if not (user_dict.get(del_num) is None): # 判断编号对应员工是否存在 sure = input(f"是否删除以下员工name:{user_dict[del_num]['name']}(确定输入y)") # 打印员工姓名并询问是否确定删除 if sure.lower() == 'y': # 如确定则删除 del_dict = user_dict.pop(del_num) print(f'员工{del_dict["name"]}已删除') else: print('取消删除') elif choice == '6': print('\n--退出管理系统--\n') break else: print('输入正确的数字')
垃圾回收机制与字符编码
最新推荐文章于 2025-02-18 14:54:59 发布
5022

被折叠的 条评论
为什么被折叠?



