开发者学堂课程【Python开发基础入门:Python入门基础必备-垃圾回收和分支语句】学习笔记,与课程紧密联系,让用户快速学习知识。
课程地址:https://developer.aliyun.com/learning/course/556/detail/7650?
目录:
一,内存管理
二,程序控制
三,分支结构
四,练习
一, 内存管理
u 变量无须事先声明,也不需要指定类型
u 动态语言的特性
u 编程中一般无须关心变量的存亡,也不用关心内存的管理python使用引用计数记录所有对象的引用数
//和C++类似,有异曲同工之妙
u 当对象引用数变为0,它就可以被垃圾回收GC
//被自动回收的数据被称之为垃圾回收
附辅助理解视图:
//当线性内存中放满了数据时,系统会自动识别出不常用的数据,将其自动识别成垃圾数据,进行回收。
//回收后的样图如下:
//碎片化内存展示如下图:
//此时出现的问题有,总内存足够,但是用户无法申请连续的大片内存,导致新需求无法存入系统。
//解决方案:设计一套垃圾回收系
垃圾回收系统的作用有以下几点:
Ø 清理不常用数据
Ø 规整内存数据,标记数据,自动清洗
//注:应用对象值为垃圾回收主要参考指标
u 计数增加:赋值给其它变量就增加引用计数,例如x=3;y=x
u 计数减少:
u 函数运行结束时,局部变量就会被自动销毁,对象引用计数减少变量被赋值给其它对象。例如x=3;y=x;x=4
//垃圾回收较为复杂,针对不同的应用场景,会有不同的回收策略。
//C,C++语言不存在垃圾回收。
注:辅助理解示意图;
//用户在使用Python时可以根据自己的编程习惯去划分内存区,这里也可以使用对应的算法去对垃圾回收的数据规整进行管理。
//Python在进行垃圾回收时存在一个数据规整问题,这里Python学习了JAVA对数据内存
进行了分区管理,将常用数据划分到永久区,如此便解决了数据规整的难题。
u 有关性能的时候,就需要考虑变量的引用问题,但是该释放内存,还是尽量不释放内存,看需求
//垃圾回收的时间过长容易影响到系统的性能。此时的程序便处于一种待机状态。
//在对垃圾回收没有深刻认识的情况下,不建议用户手动的去进行垃圾回收。
//在现实生活中,一台服务器在运行几年后,是会产生大量的用户数据的,这时就存在一个在什么时间段做jc比较合适呢?
在当下这个网上购物时代,半夜jc已经变得不太现实,如淘宝,京东的双十一。此时做jc会出现服务器奔溃的状况。
//特别注意:新手不要使用jc进行手动的数据清理。在不了解jc的情况下,建议让jc自己独立运行。
//内存空洞:不存在大量的连续的空间向用户提供使用便叫内存空洞。
//举例:C语言以及C++在频繁的使用过程中也需要释放内存空间,否则易导致用户无法申请内存,导致程序崩溃。经常使用jc容易导致效率问题。
//内存管理是java语言和Python语言的一个核心机制。(新手了解即可,高手必备 )
//误区:程序员不能够完全依赖jc去进行垃圾回收,,尽量做到内存里面只放最常用的数据。毕竟使用jc的代价很高。
//作为一名合格的程序员,一定要学会内存管理,不能够认为内存是一个取之不尽,用之不竭的资源。在开拓新内存的同时,还要学会维护内存,释放内存。
注意:Python下的内存管理主要运用了引用技术。
一, 程序控制
//结构化编程引入了程序控制
l 顺序
l 按照先后顺序一条条执行
l 例如,先洗手,再吃饭,再洗碗
//顺序控制是最简单的程序控制,也是日常开发中使用最广泛的方式。
l 分支
l 根据不同的情况判断,条件满足执行某条件下的语句
l 例如,先洗手,如果饭没有做好,玩游戏,如果饭做好了,就吃饭,如果饭都没有做,叫外卖
l 循环
l 条件满足就反复执行,不满足就不执行或不再执行
l 例如,先洗手,看饭好了没有,没有好,一会来看一次是否好了,一会儿来看一次,直到饭好了,才可是吃饭。这里循环的条件是饭没有好,饭没有好,就循环的来看饭好了没有。
二, 分支结构
单分支结构
n if语句
if condition:
代码块
condition必须是一个bool类型,这个地方有一个隐式转换bool(condition)
if 1<2:
print('1 less than 2')
n 代码块
n 类似于if语句的冒号后面的就是一个语句块
n 在if、for、def、class等
真值表:
n False等价布尔值,相当于bool(value)
n 集合
//空集合一律视为false
n 工子符串
n 空字典空列表
n 空元祖
n None对象
n 0
//重点理解等价false
多分支结构:
n if...elif...else语句
if condition1:
代码块1
l
elif condition2:
代码块2
elif condition3:
代码块3
else:
代码块
n 举例
a = 5
if a<0:
//判断a是否等于0.
print(‘negative’)
elif a==0:
print(‘zero’)
//删除下面这一句不影响结果
else:
print(‘positive’)
//分支只能满足一个,不能够同时满足多个。
//效果验证
a = 5if a<8:
wprint ( ' less 8 ')elif a<6:
print ( ' less 6')else:
print ( 'positive')
less 8
分支嵌套
n 举例
score = 80
if score<O:
print('wrong')
else:
if score==O:
print(egg')
elif score <= 100:print('right')else:
C
print("'too big')
n 嵌套结构可以是分支、循环的嵌套
n 可以互相嵌套多层
三, 练习
n 输入2个数字,输出最大数
n 给定一个不超过5位的正整数,判断其有几位
n 使用input函数
input函数获取键盘输入input([prompt])
//可以去网上查看帮助文档。
In[3]:input
Out[3]: <funtion input>
In[4]: input()
123
Out[4]:
’
123
’
In[5]:input(
‘
>>>
’
)
>>>abc
/
/
int的意思是整型
/
/
不要随意使用下划线。
In【6】:input()
12345
Out[6]:
’
12345
In[7]:int(_)
Out [7]: 12345
//这里的下滑线的意思是上一次输出的结果。