一、python编程语言的基础概念

编程预言的分类

编程语言主要从以下几个角度为进行分类,编译型和解释型、静态语言和动态语言、强类型定义语言和弱类型定义语言,每个分类代表什么意思呢,我们一起来看一下。

编译型和解释型

编译器是把源程序的每一条语句都编译成机器语言,并保存成二进制文件,这样运行时计算机可以直接以机器语言来运行此程序,速度很快;

解释器则是只在执行程序时,才一条一条的解释成机器语言给计算机来执行,所以运行速度是不如编译后的程序运行快.

这是因为计算机不能直接认识并执行我们写的语句,它只能认识机器语言(是二进制的形式)
在这里插入图片描述

编译型vs解释型
编译型
优点:编译器一般会有预编译的过程对代码进行优化。因为编译只做一次,运行时不需要编译,所以编译型语言的程序执行效率高。可以脱离语言环境独立运行。
缺点:编译之后如果需要修改就需要整个模块重新编译。编译的时候根据对应的运行环境生成机器码,不同的操作系统之间移植就会有问题,需要根据运行的操作系统环境编译不同的可执行文件。

解释型
优点:有良好的平台兼容性,在任何环境中都可以运行,前提是安装了解释器(虚拟机)。灵活,修改代码的时候直接修改就可以,可以快速部署,不用停机维护。
缺点:每次运行的时候都要解释一遍,性能上不如编译型语言。

既然编译型与解释型各有优缺点又相互对立,所以一批新兴的语言都有把两者折衷起来的趋势,例如Java语言虽然比较接近解释型语言的特征,但在执行之前已经预先进行一次预编译,生成的代码是介于机器码和Java源代码之间的中介代码,运行的时候则由JVM(Java的虚拟机平台,可视为解释器)解释执行。它既保留了源代码的高抽象、可移植的特点,又已经完成了对源代码的大部分预编译工作,所以执行起来比“纯解释型”程序要快许多。

动态语言和静态语言

通常我们所说的动态语言、静态语言是指动态类型语言和静态类型语言。
动态类型语言:动态类型语言是指在运行期间才去做数据类型检查的语言,也就是说,在用动态类型的语言编程也不用给任何变量指定数据类型,该语言会在你第一次赋值给变量时,在内部将数据类型记录下来。Python和Ruby就是一种典型的动态类型语言

静态类型语言:静态类型语言与动态类型语言刚好相反,它的数据类型是在编译其间检查的,也就是在用静态态类型的语言编程时要声明所有变量的数据类型,C/C++是静态类型语言的典型代表,其他的静态类型语言还有C#、JAVA等。

强类型定义语言和弱类型定义语言

强类型定义语言:强制数据类型定义的语言。也就是说,一旦一个变量被指定了某个数据类型,如果不经过强制转换,那么它就永远是这个数据类型了。举个例子:如果你定义了一个整型变量a,那么程序根本不可能将a当作字符串类型处理。强类型定义语言是类型安全的语言。

弱类型定义语言:数据类型可以被忽略的语言。它与强类型定义语言相反, 一个变量可以赋不同数据类型的值。

强类型定义语言在速度上可能略逊色于弱类型定义语言,但是强类型定义语言带来的严谨性能够有效的避免许多错误。另外,“这门语言是不是动态语言”与“这门语言是否类型安全”之间是完全没有联系的!

Python是动态语言、强类型定义语言

什么是pyc文件

python和java类似,也是一门基于虚拟机的语言,可以先编译后解释,先编译为介于高级语言和机器语言之间的语言。
当python程序运行时,编译结果保存在内存中的PyCodeObject中,当Python程序运行结束时,Python解释器将PyCodeObject中的写回pyc文件中。pyc文件和python程序的名字相同,当python程序二次运行时,首先程序比较pyc文件和同名python程序文件,两者的时间戳。若python程序更新,则重新先编译后解释。若pyc文件更新,则直接利用pyc文件进行解释。
此方法加速python程序运行。

变量

变量是内存中的一个单元,此单元的数据会变动。
变量名的规则

  1. 变量名只能是 字母、数字或下划线的任意组合。
  2. 变量名的第一个字符不能是数字,更不能全是数字。
  3. 区分大小写
  4. 以下关键字不能声明为变量名
    [‘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’]

建议使用驼峰样式或者下划线来分隔变量的多个单词。

字符编码

python解释器在加载 .py 文件中的代码时,会对内容进行编码转换(python3默认UTF-8)
编码:是用以将人类能看懂的字符转换为机器能弄的0和1;
解码:是将机器使用的一串0和1转换为人类能懂的字符串;
编码格式就好比一个密码本,因为编码格式不同那么同一段0和1的数据流,可能被翻译成不同的字符。
在中国有很多的中文字符,建议使用UTF-8编码。
各编码格式之间的互相不认识,会出现乱码。

发布了40 篇原创文章 · 获赞 2 · 访问量 2084

猜你喜欢

转载自blog.csdn.net/weixin_42155272/article/details/93751645