Python(2)—Python程序的编写简单介绍
一.语句和语法
1
2
3
4
5
6
7
8
9
10
11
|
# 注释
\ 转译回车,继续上一行,在一行语句较长的情况下可以使用其来切分成多行,因其可读性差所以不建议使用
; 将两个语句连接到一行,可读性差,不建议使用
: 将代码的头和体分开
语句(代码块)用缩进方式体现不同的代码级别,建议采用
4
个空格(不要使用tab),因为不同编程语言环境下tab所代表的空格数不一定是
4
python文件以模块的方式组织,编写一个.py结尾的文件实际上就写了一个模块
|
二.变量定义与赋值
1
2
3
4
5
6
7
8
9
10
11
|
a=
1
:
1
为内存变量存放于内存中,a为变量的引用,python为动态语言,变量及其类型均无需事先声明类型
与C语言和C
+
+
的区别:a=
1
无返回值
注:
1.c
语言变量声明必须位于代码最开始,而且要在所有语句之前
2.c
++,java可以随时随地声明变量,但是必须声明变量名字和类型
3.python
也可以随时随地声明变量,但是变量在被定义时,解释器会根据等式右侧的值来决定其类型
4.
变量必须先赋值,才可使用
|
三.内存管理
内存管理:
1
2
3
4
5
6
7
|
1.
变量无须指定类型
2.
程序员无须关心内存管理
3.
变量没有指向被赋予的值时会被自动回收
4.del
能够直接释放内存对象(减少对象的引用计数)
|
引用计数:
增加引用计数:
1
2
3
4
5
6
7
|
1.
对象被创建并将其引用赋值给变量,引用计数加
1
(例a=
1
)
2.
同一个对象的引用又赋值给其它变量,引用计数加
1
(例b=a)
3.
对象作为参数被函数调用,引用计数加
1
(例
int
(a))
4.
对象成为容器对象中的一个元素,引用计数加
1
(例list_test
=
[
'xuyaping'
,
'z'
,a])
|
减少引用计数:
1
2
3
4
5
6
7
8
9
|
1.a
作为被函数调用的参数,在函数运行结束后,包括a在内的所有局部变量均会被销毁,引用计数减
1
2.
变量被赋值给另外一个对象,原对象引用计数减
1
(例b=
2
,
1
这一内存对象的引用只剩a)
3.
使用
del
删除对象的引用,引用计数减
1
(例
del
a)
4.a
作为容器list_test中的一个元素,被清除,引用计数减少(例list_test.remove(a))
5.
容器本身被销毁(例
del
list_test)
|
1
2
3
|
注意:python内存回收交给一段独立的代码即垃圾回收器(包含引用计数器和循环垃圾收集器),引用计数在归零时并不会立即清除(可能有循环调用)
不必纠结循环引用收集,只需记住垃圾回收器帮你自动清理内存。
|
简单例子
1
2
3
4
5
6
7
|
x=
1
#创建内存变量
1
,将变量
1
的引用传给x,此刻
1
的引用计数为
1
y=x #
1
的引用计数增加到
2
y=
2
#创建新的内存变量
2
,将变量
2
的引用传给y,原本指向
1
的y,此刻给了
2
,所以
1
的引用计数减少到了
1
del
x #删除了内存对象
1
的引用x,此刻
1
再无引用,此刻它就成了python解释器回收的目标
|
四.python对象
python中使用对象模型来存储数据,用来生成数据类型的工厂函数本质上是类,新建数据的结果本质是实例化一个对象 对象有三种特性:
1.身份:内存地址,可以用id()确认,id相同的就是同一个对象 2.类型:可以用type()查看,返回值的type也是对象 3.值
五.标识符
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
定义:允许作为名字的有效字符串集合
1.
名字必须有实际意义,可读性好
2.
首字母必须是字母或下划线(_)
3.
剩下的字符可以是字母和数字或者下划线
4.
大小写敏感
5.
两种风格:conn_obj或ConnObj
6.
不能使用关键字,不能使用内建
内建:由解释器自动导入(提供基本功能),可以看作全局变量,
|
六.专用下划线标识符
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
|
_xxx:不能用
from
module
import
*
导入
__xxx__:系统定义名字
__xxx:类中私有变量
下划线对于解释器来说有特殊意义,而且是内建标识符所使用符号,不建议自定义变量以下划线开头
但是如果是类中的私有变量,__xxx将会是一个好习惯
系统变量__name__会根据python文件被加载方式的不同得出不同的值。
python文件被当作模块导入:__name__
=
模块名或者文件名
python文件被执行:__name__
=
'__main__'
在我们使用python编写一个软件时,应该只有一个主程序中包含大量顶级代码(就是没有缩进的代码,python解释器读取到顶级代码会立即执行),其他.py文件应
该只有少量顶级代码,所有功能都应该封装在函数或类中。
通常在文件结尾结合__name__变量,编写测试代码 。
|
七.编写模块基本风格
1
2
3
4
5
6
7
8
|
1.
标题
2.
文档注释
3.
模块导入
4.
变量定义
5.
类定义语句
6.
函数定义语句
7.
主程序
8.
测试代码
|
八.示范
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
|
#_*_coding:utf-8_*_
#!/usr/bin/env python
'''
This is an example module
'''
import
sys,os
debug
=
True
class
Test:
'''
test class
'''
pass
def
main():
'''
test func
:return:
'''
pass
if
__name__
=
=
'__main__'
:
main()
|
一.语句和语法
1
2
3
4
5
6
7
8
9
10
11
|
# 注释
\ 转译回车,继续上一行,在一行语句较长的情况下可以使用其来切分成多行,因其可读性差所以不建议使用
; 将两个语句连接到一行,可读性差,不建议使用
: 将代码的头和体分开
语句(代码块)用缩进方式体现不同的代码级别,建议采用
4
个空格(不要使用tab),因为不同编程语言环境下tab所代表的空格数不一定是
4
python文件以模块的方式组织,编写一个.py结尾的文件实际上就写了一个模块
|
二.变量定义与赋值
1
2
3
4
5
6
7
8
9
10
11
|
a=
1
:
1
为内存变量存放于内存中,a为变量的引用,python为动态语言,变量及其类型均无需事先声明类型
与C语言和C
+
+
的区别:a=
1
无返回值
注:
1.c
语言变量声明必须位于代码最开始,而且要在所有语句之前
2.c
++,java可以随时随地声明变量,但是必须声明变量名字和类型
3.python
也可以随时随地声明变量,但是变量在被定义时,解释器会根据等式右侧的值来决定其类型
4.
变量必须先赋值,才可使用
|
三.内存管理
内存管理:
1
2
3
4
5
6
7
|
1.
变量无须指定类型
2.
程序员无须关心内存管理
3.
变量没有指向被赋予的值时会被自动回收
4.del
能够直接释放内存对象(减少对象的引用计数)
|
引用计数:
增加引用计数:
1
2
3
4
5
6
7
|
1.
对象被创建并将其引用赋值给变量,引用计数加
1
(例a=
1
)
2.
同一个对象的引用又赋值给其它变量,引用计数加
1
(例b=a)
3.
对象作为参数被函数调用,引用计数加
1
(例
int
(a))
4.
对象成为容器对象中的一个元素,引用计数加
1
(例list_test
=
[
'xuyaping'
,
'z'
,a])
|
减少引用计数:
1
2
3
4
5
6
7
8
9
|
1.a
作为被函数调用的参数,在函数运行结束后,包括a在内的所有局部变量均会被销毁,引用计数减
1
2.
变量被赋值给另外一个对象,原对象引用计数减
1
(例b=
2
,
1
这一内存对象的引用只剩a)
3.
使用
del
删除对象的引用,引用计数减
1
(例
del
a)
4.a
作为容器list_test中的一个元素,被清除,引用计数减少(例list_test.remove(a))
5.
容器本身被销毁(例
del
list_test)
|
1
2
3
|
注意:python内存回收交给一段独立的代码即垃圾回收器(包含引用计数器和循环垃圾收集器),引用计数在归零时并不会立即清除(可能有循环调用)
不必纠结循环引用收集,只需记住垃圾回收器帮你自动清理内存。
|
简单例子
1
2
3
4
5
6
7
|
x=
1
#创建内存变量
1
,将变量
1
的引用传给x,此刻
1
的引用计数为
1
y=x #
1
的引用计数增加到
2
y=
2
#创建新的内存变量
2
,将变量
2
的引用传给y,原本指向
1
的y,此刻给了
2
,所以
1
的引用计数减少到了
1
del
x #删除了内存对象
1
的引用x,此刻
1
再无引用,此刻它就成了python解释器回收的目标
|
四.python对象
python中使用对象模型来存储数据,用来生成数据类型的工厂函数本质上是类,新建数据的结果本质是实例化一个对象 对象有三种特性:
1.身份:内存地址,可以用id()确认,id相同的就是同一个对象 2.类型:可以用type()查看,返回值的type也是对象 3.值
五.标识符
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
定义:允许作为名字的有效字符串集合
1.
名字必须有实际意义,可读性好
2.
首字母必须是字母或下划线(_)
3.
剩下的字符可以是字母和数字或者下划线
4.
大小写敏感
5.
两种风格:conn_obj或ConnObj
6.
不能使用关键字,不能使用内建
内建:由解释器自动导入(提供基本功能),可以看作全局变量,
|
六.专用下划线标识符
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
|
_xxx:不能用
from
module
import
*
导入
__xxx__:系统定义名字
__xxx:类中私有变量
下划线对于解释器来说有特殊意义,而且是内建标识符所使用符号,不建议自定义变量以下划线开头
但是如果是类中的私有变量,__xxx将会是一个好习惯
系统变量__name__会根据python文件被加载方式的不同得出不同的值。
python文件被当作模块导入:__name__
=
模块名或者文件名
python文件被执行:__name__
=
'__main__'
在我们使用python编写一个软件时,应该只有一个主程序中包含大量顶级代码(就是没有缩进的代码,python解释器读取到顶级代码会立即执行),其他.py文件应
该只有少量顶级代码,所有功能都应该封装在函数或类中。
通常在文件结尾结合__name__变量,编写测试代码 。
|
七.编写模块基本风格
1
2
3
4
5
6
7
8
|
1.
标题
2.
文档注释
3.
模块导入
4.
变量定义
5.
类定义语句
6.
函数定义语句
7.
主程序
8.
测试代码
|
八.示范
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
|
#_*_coding:utf-8_*_
#!/usr/bin/env python
'''
This is an example module
'''
import
sys,os
debug
=
True
class
Test:
'''
test class
'''
pass
def
main():
'''
test func
:return:
'''
pass
if
__name__
=
=
'__main__'
:
main()
|