python程序编写简介

语句和语法变量的定义和赋值内存管理内存管理引用计数增加引用计数减少引用计数自动回收机制(python独有的)实例:python对象标识符专用下划线标识符_xxx:不能用from

大家好,又见面了,我是你们的朋友全栈君。

语句和语法

#  注释
 
\    转译回车,继续上一行,在一行语句较长的情况下可以使用其来切分成多行,因其可读性差所以不建议使用
 
;  将两个语句连接到一行,可读性差,不建议使用
 
:  将代码的头和体分开
 
语句(代码块)用缩进方式体现不同的代码级别,建议采用4个空格(不要使用tab),因为不同编程语言环境下tab所代表的空格数不一定是4
 
python文件以模块的方式组织,编写一个.py结尾的文件实际上就写了一个模块

变量的定义和赋值

a=1:1为内存变量存放于内存中,a为变量的引用,python为动态语言,变量及其类型均无需事先声明类型
 
与C语言和C++的区别:a=1无返回值
 
注:1.c语言变量声明必须位于代码最开始,而且要在所有语句之前
 
  2.c++,java可以随时随地声明变量,但是必须声明变量名字和类型
 
  3.python也可以随时随地声明变量,但是变量在被定义时,解释器会根据等式右侧的值来决定其类型
 
  4.变量必须先赋值,才可使用

内存管理

内存管理

1.变量无须指定类型
 
2.程序员无须关心内存管理
 
3.变量没有指向被赋予的值时会被自动回收
 
4.del能够直接释放内存对象(减少对象的引用计数)

引用计数

增加引用计数

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

减少引用计数

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)

自动回收机制(python独有的)

注意:python内存回收交给一段独立的代码即垃圾回收器(包含引用计数器和循环垃圾收集器),引用计数在归零时并不会立即清除(可能有循环调用)
 
   不必纠结循环引用收集,只需记住垃圾回收器帮你自动清理内存。

实例:

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解释器回收的目标

<span role="heading" aria-level="2">python程序编写简介

 <span role="heading" aria-level="2">python程序编写简介

python对象

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

对象有三种特性:

1.身份:内存地址,可以用id()确认,id相同的就是同一个对象

2.类型:可以用type()查看,返回值的type也是对象

3.值

标识符

定义:允许作为名字的有效字符串集合
 
1.名字必须有实际意义,可读性好
 
2.首字母必须是字母或下划线(_)
 
3.剩下的字符可以是字母和数字或者下划线
 
4.大小写敏感
 
5.两种风格:conn_obj或ConnObj
 
6.不能使用关键字,不能使用内建
 
内建:由解释器自动导入(提供基本功能),可以看作全局变量,

专用下划线标识符

<span role="heading" aria-level="2">python程序编写简介
<span role="heading" aria-level="2">python程序编写简介

_xxx:不能用from module import *导入
 
__xxx__:系统定义名字
 
__xxx:类中私有变量
 
下划线对于解释器来说有特殊意义,而且是内建标识符所使用符号,不建议自定义变量以下划线开头
 
但是如果是类中的私有变量,__xxx将会是一个好习惯
 
  
 
系统变量__name__会根据python文件被加载方式的不同得出不同的值。
 
    python文件被当作模块导入:__name__=模块名或者文件名
 
    python文件被执行:__name__='__main__'
 
  
 
在我们使用python编写一个软件时,应该只有一个主程序中包含大量顶级代码(就是没有缩进的代码,python解释器读取到顶级代码会立即执行),其他.py文件应
 
  
 
该只有少量顶级代码,所有功能都应该封装在函数或类中。
 
  
 
通常在文件结尾结合__name__变量,编写测试代码 

View Code

程序编写基本流程

1.标题2.文档注释3.模块导入4.变量定义5.类定义语句6.函数定义语句7.主程序8.测试代码

示例:

<span role="heading" aria-level="2">python程序编写简介
<span role="heading" aria-level="2">python程序编写简介

#_*_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()

View Code

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/124505.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • 配对t检验的应用条件是什么_配对t检验在实际工作中的应用[通俗易懂]

    配对t检验的应用条件是什么_配对t检验在实际工作中的应用[通俗易懂](r:相关系数)双样本t时用此公式计算标准误:→三、成组t检验:适用于完全随机设计的两均值比较,要求个体之间相互独立,两组资料均服从正态分布且方差齐性,即为标准的双样本t检验。四、我们重点来看一下,配对t检验,配对t检验从设计上分为3种情况,如下:1、自身配对设计:选择K个受试者,分别在甲、乙两个不同的试验条件(即某个因素的两个水平)下,测出每个受试者同一个指标的两个数值,并把它们配成一对。2、同…

  • 模型视图矩阵和投影矩阵_马尔可夫模型

    模型视图矩阵和投影矩阵_马尔可夫模型1概述机器视觉就是用机器代替人眼来做测量和判断。机器视觉系统工作的基本过程是获取目标的图像后,对图像进行识别、特征提取、分类、数学运算等分析操作,并根据图像的分析计算结果,来对相应的系统进行控制或决策的过程。在很多机器视觉应用中,都需要用到机器视觉测量,即根据目标的图像,来得到目标在实际空间中的物理位置,最典型的如行走机器人、SLAM等。要根据图像中的目标像素位置,得到目标的物理空间位置,我们需要首先有一个图像像素坐标与物理空间坐标的映射关系,这种能够表达空间位置如何映射到图像像素位置的数学公式,就

  • ntp服务器ntp协议时间戳,计算机的时钟(一):NTP 协议[通俗易懂]

    ntp服务器ntp协议时间戳,计算机的时钟(一):NTP 协议[通俗易懂]本系列文章主要介绍计算机系统中时钟的处理。主要内容包含NTP,Lamport逻辑时钟,向量时钟,TrueTime等。本文是第一篇,介绍NTP协议。电脑的时钟不知道你注意过没有,假如隔了好几天打开你的电脑,任务栏的时间依然是显示正确的,即使你的电脑没有联网,这是如何做到的?post-quartz.png计算机的主板上有一个石英晶体振荡器和一个纽扣电池。石英晶体振荡器的频率是32768Hz每秒。在通电…

    2022年10月12日
  • 详解ThinkPHP支持的URL模式有四种普通模式、PATHINFO、REWRITE和兼容模式

    详解ThinkPHP支持的URL模式有四种普通模式、PATHINFO、REWRITE和兼容模式

    2021年10月17日
  • 计算机组成原理 寻址方式_计算机组成原理寻址方式的判断

    计算机组成原理 寻址方式_计算机组成原理寻址方式的判断一、寻址方式是指确定本条指令的数据地址以及下一条将要执行的指令地址的方法,与硬件结构紧密相关,而且直接影响指令格式和指令功能。分为指令寻址和数据寻址两大类。二、指令寻址分为顺序寻址和跳跃寻址两种。顺序寻址可通过程序计数器PC加1,自动形成下一条指令的地址;跳跃寻址则通过转移类指令实现。数据寻址种类较多,在指令字中必须设一字段来指明属于哪一种寻址方式。指令的地址码字段通常都不代表操作数的真实地址,把它称为真实地址,记作A。操作数的真实地址成为有效地址,记作EA,它是由寻址方式和形式地址共同来确定的。由

    2022年10月24日
  • 常见的多种在线代码编辑器[通俗易懂]

    常见的多种在线代码编辑器[通俗易懂]1、BeautifyTools提供各种转化工具,但是不会提供前端代码运行的结果。如图,这个编辑器提供的是转化工具,代码提示,错误提示功能很强大,就是没有执行结果。主要功能全部是转化工具。2、codepen可以编辑前端html、css、js代码并查看执行结果,也可以指定其它的编程语言。编辑代码时没有代码提示,错误提示也只有css代码会出现。3、jsbin提供基本的…

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号