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)
blank

相关推荐

  • 【日常】如何将微信中对方所撤回的消息恢复?——电脑PC端微信教程:附源码[通俗易懂]

    【日常】如何将微信中对方所撤回的消息恢复?——电脑PC端微信教程:附源码[通俗易懂]1前言寻找微信撤回的图片是不少人一直在寻找的方法但苦于在网上一直找不到结果因此本文提出了一种可以找到微信撤回图片的方法。区别于网上其他的不可用代码,本文能成功恢复!2原理之前的说法是,工程师并没有真正把撤回的图片删除,而是加密后藏起来了。其实这样说并不严谨,经过后续测试,发现PC端的确如此,而手机端(Android)撤回的图片是有删除的,但是删除的不干净。2.1PC端微信所有接收到的图片都储在:C:\Users\你的用户名\Documents\WeChatFiles\wxid_你

  • ajax的实现_培训的基本内容有哪些?

    ajax的实现_培训的基本内容有哪些? 点击这里下载PDF文件。  点击这里下载示例文件。  点击这里下载视频文件。  相关内容:AJAX培训第二讲:使用AJAX框架(上)  “AJAX培训第二讲:使用AJAX框架”现在拆成了两部分,现在发布是第一部分,探讨了AJAX框架相关内容,并给出了一些最简单的例子。  如果大家对于讲座的内容有任何疑问,请在Q&A专用文章里进行提问,当然如果您有其它任何疑问的话,也能在那里提出,我会尽快为您

  • CSDN 博客备份工具「建议收藏」

    CSDN 博客备份工具「建议收藏」前言核心登录模块备份模块博文扫描模块演示如何使用效果总结前言近段时间以来,听群友博友都在谈论着一件事:“CSDN博客怎么没有备份功能啊?”。这其实也在一定程度上表征着大家对于文章这种知识性产品的重视度越来越高,也对于数据的安全提高了重视。所以我就尝试着写了这么一个工具。专门用来备份CSDN博友的博客。核心说起来是核心,其实也就那么回事吧。严格来说也就是一对代码,不能称之为核心啦。

  • PHP代码审计入门学习过程

    PHP代码审计入门学习过程PHP代码审计学习过程:花了两周的时间在B站上看完了一个老师讲的代码审计课程,主要是通过实战的方式对一个CMS系统里面的漏洞进行讲解,一步一步的审计找出漏洞,对新手来说确实困难,要上手的话还是自己找网上一些简单的CMS或是代码审计靶场来练手。代码审计入门确实挺难的,大部分原理都没有学会,后续也要继续加深学习。进行代码审计必须要关注:1.敏感的函数和变量2.跟踪敏感函数和关键字参数传递过程。3.查找可控变量,一步一步的跟踪变量测传递过程。4.寻找敏感功能点,对功能点进行审计PH.

  • ctf-web:关于文件上传漏洞的深入研究[通俗易懂]

    ctf-web:关于文件上传漏洞的深入研究[通俗易懂]上次我们研究了关于文件上传的漏洞,这次我们研究的内容属于上节课的补充内容,关于文件上传的绕过与防御.怎么说呢,算是一种锻炼吧.因为下个月有个awd的比赛,因此最近会经常发一些关于web的内容.其实我还是挺慌的,因为以前参加的都是ctf线上赛,而且我做的都是逆向这个方面的,然而这次突然来了个web,搞得我有点懵.web也是最近才开始研究的,所以写的可能不尽人意,希望各位大佬看看就好,不喜勿喷.一.实验环境我们这次的实验依然用的是上次的网站和phpstudy.我发在了下面.1.upload-f.

  • ETH挖矿初尝_eth挖矿教程

    ETH挖矿初尝_eth挖矿教程参考博客:http://blog.csdn.net/a1291985595/article/details/72849999挖矿软件:http://pan.baidu.com/s/1o7ZQ2HO问题解决:各类dll缺失解决办法http://www.pcyisheng.com/act/20150616050d56a766.html或下载360安全卫士–

    2022年10月10日

发表回复

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

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