Python学习之路3☞编程风格

语句和语法

  • #   表示注释掉的内容
  •    续行
1 print("yyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyy
2 yyyyyyyyyyyyyyyyyyyyyyy")
  • ;    分号:同一行放置多个语句以分号作为分割符
1 print('cyy');print('zzl')
2  
3 输出结果:
4 cyy
5 zzl
  • 语句(代码块)用缩进方式体现不同的代码级别,建议用4个空格(不要用tab)
  • python文件以模块的方式组织,编写一个.py结尾的文件实际上就是写了一个模块,模块的名称也是脚本的名称
  • 首行以关键字开始,如if、while 等,以冒号结束
  • Python使用缩进来分隔代码组,同一代码组的代码行必须严格左对齐,否则会造成语法错误 
  • 模块里的代码可以是一段直接执行的脚本,也可以是一些类似库函数的代码从而可由别的模块执行导入(import) 因为模块在被import的那一刻就会执行;所以模块中一般存放的都是一些可调用的代码段;

标识符

标识符是计算机语言中允许作为名字的有效字符串集合

  • 变量名只能是 字母、数字或下划线的任意组合
  • 变量名的第一个字符不能是数字(是字母或下划线(_))
  • 大小写敏感
  • 两种风格:conn_obj或ConnObj
  • 不能使用关键字,不能使用内建

专用下划线的标识符

  • _xxx:不能用from module import *导入
  • __xxx__:系统定义名字
  • __xxx:类中私有变量

下划线对于解释器来说有特殊意义,而且是内建标识符所使用符号,不建议自定义变量以下划线开头

变量的定义与赋值

变量定义方法很简单:

1 x=5
2 print(x,type(5))
3 print(x*5,type(x*5))
4  
5 结果:
6 5 <class 'int'>
7 25 <class 'int'>
  • 这个操作过程就是赋值,意思把整型数字5赋值给了变量x,用等号来连接变量名和值。之后就可以在表达式中使用这个新变量了。
  • 5为内存变量存放于内存中,x为变量的引用,python为动态语言,变量及其类型均无需事先声明类型
  • 与c的区别:a=1无返回值

注意:在赋值时,值是什么数据类型,就决定了这个变量的类型,变量名引用了数值的同时也引用了它的类型。

变量命名规范

1、变量名可以包括字母、数字、下划线,但是数字不能做为开头。例如:name1是合法变量名,而1name就不可以。
2、系统关键字不能做变量名使用
3、除了下划线之个,其它符号不能做为变量名使用
4、Python的变量名是除分大小写的,例如:name和Name就是两个变量名,而非相同变量哦。

python对象

python中使用对象模型来存储数据,用来生成数据类型的工厂函数本质上是类,新建数据的结果本质是实例化一个对象

对象有三种特性

  • 身份:内存地址,可以用id()确认,id相同的就是同一个对象
  • 类型:可以用type()查看,返回值的type也是对象

python内存管理

内存管理:

变量无序指定类型

程序员无须关心内存管理

变量会自动回收

del能够直接释放内存对象(减少对象的引用计数)

解释:mem删除的则是引用,并不是100占用的这块内存地址,也不是100,删除引用以后,内存地址会自动回收

引用计数:

增加引用计数:

  • 对象被创建并将其引用赋值给变量,引用计数加1(例a=1)
  • 同一个对象的引用又赋值给其它变量,引用计数加1(例b=a)
  • 对象作为参数被函数调用,引用计数加1(例int(a)
  • 对象成为容器对象中的一个元素,引用计数加1(例list_test=['zzl','z',a])

减少引用计数:

  • a作为被函数调用的参数,在函数运行结束后,包括a在内的所有局部变量均会被销毁,引用计数减1
  • 变量被赋值给另外一个对象,原对象引用计数减1(例b=2,1这一内存对象的引用只剩a)
  • 使用del删除对象的引用,引用计数减1(例del a)
  • a作为容器list_test中的一个元素,被清除,引用计数减少(例list_test.remove(a))
  • 容器本身被销毁(例del list_test)

示例说明:

 1 增加引用计数:
 2     name = ‘yyp’  #创建内存变量yyp,将变量yyp的引用传给name,此刻yyp的引用计数为1
 3     name1 = name  #name有赋值给name1,现在yyp的引用计数增加到2
 4     def foo(name):   #作为函数调用的时候,引用计数加1
 5         pass
 6  
 7 减少引用计数 
 8     name1=‘sy’ #创建新的内存变量sy,将变量sy的引用传给name1,原本指向yyp的name1,此刻给了2,所以1的引用计数减少了1
 9  
10     del name #删除了内存对象yyp的引用name,此刻yyp再无引用,此刻它就成了python解释器回收的目标

用数据类型的可变/不可变与内存地址相互关联起来理解:

定义:基于一个内存地址的修改,是可变类型

数字:

数字更改元素,内存地址发生变化,所以数字是不可变的数据类型

字符串:

字符串更改元素,内存地址发生变化,所以字符串是不可变的数据类型

列表:

列表元素发生改变,内存地址不变,所以列表是可变类型

元组:

元祖本身就不能修改,所以元组是不可变的数据类型

字典:

字典元素发生改变,内存地址不变,所以字典是可变类型

补充知识:

一上两种情况,实际上应该开辟两块内存空间,为什么内存空间地址相同?

因为:如果变量占用的内存地址的长度比较短,所有python解释器会缓存起来

下面写一个长的内存地址进行对比:

编写模块基本风格

  • 标题
    •  #_*_coding:utf-8_*_
       #!/usr/bin/env python
  • 文档注释
    • 既不能缺少注释,也要避免过度注释
  • 模块导入
    • import os
  • 变量定义
    • name=‘cy’
  • 类定义语句
    • class
  • 函数定义语句
    • def 
  • 主程序
    • 无论当前模块是被别的模块导入还是作为脚本直接执行,都会执行这部分代码
    • if __name__ == '__main__'
  • 测试代码
    • test()

eg:

 1 #!/usr/bin/python # (1)起始行
 2 #coding=utf-8                    #mod.__doc__ 引用类的文档
 3 #"this is test module" (2)模块文档(文档字符串)
 4 import sys #(3)模块导入
 5 import os
 6  
 7 debug = true
 8 name = "Tom" #(4)全局变量
 9  
10 class FooClass(object): #(5)类定义(若有)
11     "Foo class"
12     pass
13  
14 def test():
15   "test function"
16   foo = FooClass() #将类实例化 
17   if debug:
18     print 'ran test()'
19  
20 def main(name): #(6)函数定义(若有)
21       '''
22      test func
23      :return:
24       '''
25     pass
26  
27  
28  
29 if __name__ == '__main__'#(7)主程序
30 test()
31 main()
View Code
原文地址:https://www.cnblogs.com/Vae1242/p/6940810.html