python 基础篇

时间:2023-11-11 08:23:32

1.编程语言介绍.

  1.机器语言:直接用二进制编程,直接对硬件的控制,需对硬件掌握比较深。

    优点:执行效率快

    缺点:开发效率低下

  2.汇编语言:用英文标签代替二进制编写程序,直接对硬件的控制,需对硬件掌握比较深。

    优点:开发效率比机器语言高

    缺点:仍然没有改变直接对硬件的操控

  3.高级语言:直接用人类的语言去编程,不需要掌握对硬件的操作细节

    编译型语言:类似谷歌翻译,经过一次翻译,以后拿结果去执行

      优点:执行效率高于解释型

      缺点:开发效率低于解释型

    解释型语言:类似同声翻译。

      优点:开发效率高于解释型

      缺点:执行效率低于编译型

总结:

  执行效率排序:机器语言 》汇编语言 》高级语言(编译型 》解释型)

  开发效率排序:机器语言 《汇编语言 《高级语言(编译型 《解释型)

  

PS:
    学习难度从高到低

执行效率从高到低

    开发效率从低到高   

  速度不是关键(瓶颈理论),开发效率高才是王道 

 #机器语言
由于计算机内部只能接受二进制代码,因此,用二进制代码0和1描述的指令称为机器指令,全部机器指令的集合构成计算机的机器语言,用机器语言编程的程序称为目标程序。只有目标程序才能被计算机直接识别和执行。但是机器语言编写的程序无明显特征,难以记忆,不便阅读和书写,且依赖于具体机种,局限性很大,机器语言属于低级语言。
用机器语言编写程序,编程人员要首先熟记所用计算机的全部指令代码和代码的涵义。手编程序时,程序员得自己处理每条指令和每一数据的存储分配和输入输出,还得记住编程过程中每步所使用的工作单元处在何种状态。这是一件十分繁琐的工作。编写程序花费的时间往往是实际运行时间的几十倍或几百倍。而且,编出的程序全是些0和1的指令代码,直观性差,还容易出错。除了计算机生产厂家的专业人员外,绝大多数的程序员已经不再去学习机器语言了。
机器语言是微处理器理解和使用的,用于控制它的操作二进制代码。
尽管机器语言好像是很复杂的,然而它是有规律的。
存在着多至100000种机器语言的指令。这意味着不能把这些种类全部列出来。
以下是一些示例:
指令部份的示例
代表 加载(LOAD)
代表 存储(STORE)
... 暂存器部份的示例
代表暂存器 A
代表暂存器 B
... 存储器部份的示例
代表地址为 0 的存储器
代表地址为 1 的存储器
代表地址为 16 的存储器
代表地址为 2^11 的存储器
集成示例 0000,0000,000000010000 代表 LOAD A, 16
0000,0001,000000000001 代表 LOAD B, 1
0001,0001,000000010000 代表 STORE B, 16
0001,0001,000000000001 代表 STORE B, 1[1] #汇编语言
汇编语言的实质和机器语言是相同的,都是直接对硬件操作,只不过指令采用了英文缩写的标识符,更容易识别和记忆。它同样需要编程者将每一步具体的操作用命令的形式写出来。汇编程序的每一句指令只能对应实际操作过程中的一个很细微的动作。例如移动、自增,因此汇编源程序一般比较冗长、复杂、容易出错,而且使用汇编语言编程需要有更多的计算机专业知识,但汇编语言的优点也是显而易见的,用汇编语言所能完成的操作不是一般高级语言所能够实现的,而且源程序经汇编生成的可执行文件不仅比较小,而且执行速度很快。
汇编的hello world,打印一句hello world, 需要写十多行,也是醉了。
; hello.asm
section .data ; 数据段声明
msg db "Hello, world!", 0xA ; 要输出的字符串
len equ $ - msg ; 字串长度
section .text ; 代码段声明
global _start ; 指定入口函数
_start: ; 在屏幕上显示一个字符串
mov edx, len ; 参数三:字符串长度
mov ecx, msg ; 参数二:要显示的字符串
mov ebx, 1 ; 参数一:文件描述符(stdout)
mov eax, 4 ; 系统调用号(sys_write)
int 0x80 ; 调用内核功能
; 退出程序
mov ebx, 0 ; 参数一:退出代码
mov eax, 1 ; 系统调用号(sys_exit)
int 0x80 ; 调用内核功能 #高级语言
高级语言是大多数编程者的选择。和汇编语言相比,它不但将许多相关的机器指令合成为单条指令,并且去掉了与具体操作有关但与完成工作无关的细节,例如使用堆栈、寄存器等,这样就大大简化了程序中的指令。同时,由于省略了很多细节,编程者也就不需要有太多的专业知识。
高级语言主要是相对于汇编语言而言,它并不是特指某一种具体的语言,而是包括了很多编程语言,像最简单的编程语言PASCAL语言也属于高级语言。
高级语言所编制的程序不能直接被计算机识别,必须经过转换才能被执行,按转换方式可将它们分为两类:
编译类:编译是指在应用源程序执行之前,就将程序源代码“翻译”成目标代码(机器语言),因此其目标程序可以脱离其语言环境独立执行(编译后生成的可执行文件,是cpu可以理解的2进制的机器码组成的),使用比较方便、效率较高。但应用程序一旦需要修改,必须先修改源代码,再重新编译生成新的目标文件(* .obj,也就是OBJ文件)才能执行,只有目标文件而没有源代码,修改很不方便。 编译后程序运行时不需要重新翻译,直接使用编译的结果就行了。程序执行效率高,依赖编译器,跨平台性差些。如C、C++、Delphi等
解释类:执行方式类似于我们日常生活中的“同声翻译”,应用程序源代码一边由相应语言的解释器“翻译”成目标代码(机器语言),一边执行,因此效率比较低,而且不能生成可独立执行的可执行文件,应用程序不能脱离其解释器(想运行,必须先装上解释器,就像跟老外说话,必须有翻译在场),但这种方式比较灵活,可以动态地调整、修改应用程序。如Python、Java、PHP、Ruby等语言。 机器语言、汇编语言、高级语言详解

编程语言详细介绍

2.安装Python解释器,实现多版本共存。

  Python目前已支持所有主流操作系统,在Linux,Unix,Mac系统上自带Python环境,在Windows系统上需要安装一下,超简单

  打开官网 https://www.python.org/downloads/windows/ 下载中心

    python 基础篇

  

#测试安装是否成功
windows --> 运行 --> 输入cmd ,然后回车,弹出cmd程序,输入python,如果能进入交互环境 ,代表安装成功。
#多版本共存演示
注意:在安装目录下找到python.exe,拷贝一份,命名为python2.exe或python3.exe,一定要保留原版,因为pip工具会调用它。

3.python运行的两种方式:

  方式一:交互模式

      优点:输入一行代码 则就会输出结果

      缺点:代码无法永久保存

  方式二(命令行):python D:\text.txt

    优点:以文件的方式把所有的代码保存了下来

    注意:

      1.运行Python程序是不考虑文件后缀的,但约定俗成,应该将D:\text.txt改为D:\text.py

      2.运行Python程序的三个步骤:

        1.首先启动Python解释器

        2.将Python程序中普通的文本文件读入内存

        3.python解释器解释执行刚刚读入内存的代码,开始识别python的语法

4.变量

  1.什么是变量?

#量指的是记录事物的状态
#变指的是事物的状态是可以改变的

  2.为什么要用变量

#程序执行的本质就是一系列状态的变化,变是程序执行的直接体现,所以我们需要有一种机制能够反映或者说是保存下来程序执行时状态以及状态的变化。

  3.如何定义变量

#变量名(相当于门牌号,指向值所在的空间),等号,变量值
name='ZhaoKang'
sex='male'
age=18
level=10

  4.变量的定义规范

#1. 变量名只能是 字母、数字或下划线的任意组合
#2. 变量名的第一个字符不能是数字
#3. 关键字不能声明为变量名['and', 'as', 'assert', 'break', 'class', 'continue', 'def', 'del', 'elif', 'else', 'except',
'exec', 'finally', 'for', 'from', 'global', 'if', 'import', 'in', 'is', 'lambda', 'not', 'or', 'pass', 'print', 'raise', 'return', 'try', 'while', 'with', 'yield']

  5. 定义方式:

#驼峰体
ZhaoKang = 56
#下划线(推荐使用)
zhao_kang = 56

  6.定义变量名不好的方式

#1. 变量名为中文、拼音
#2. 变量名过长
#3. 变量名词不达意

  7.定义变量会有:id,type,value

#1 等号比较的是value,
#2 is比较的是id #强调:
#1. id相同,意味着type和value必定相同
#2. value相同type肯定相同,但id可能不同,如下
>>> x='Info ZhaoKang:18'
>>> y='Info ZhaoKang:18'
>>> id(x)
62880928
>>> id(y)
61823240
>>>
>>> x == y
True
>>> x is y
False

5.内存管理

  垃圾回收机制:引用计数 

引用计数增加:
        age=18   #18的引用计数为1
        x=age   #18的引用计数为2
    引用计数减少:
        del age   #18的引用计数减1
        x=10    #18的引用计数为0