一. 编译型语言和解释型语言
A. 编译型语言
1. 编译器将源代码一次编译成为机器语言,且后续执行无须重新编译。
以C语言为例,用户输入源代码后,并将转换后的代码结果放在目标代码文件中,由链接器将目标代码,启动 代码和库代码合成为一个文件,即可执行代码。
2. 效率较高。因后续不需重新编译,而是直接运行生成的exe程序,消耗的内存少,速度更快。
3. 跨平台性差。因为当跨平台使用时,需要重新使用新系统所对应的编译器对源代码进行处理后方可运行。
4. 编译性语言的代表:
C,C++,Pascal/Object Pascal
B. 解释性语言
1. 源代码先翻译成中间代码,再由翻译器对中间代码进行解释运行。
2. 效率相比编译型语言较低。
解释型语言不需要编译,所以每次运行时都需要对源代码重新翻译,运行速度慢,占用了更多的CPU和内存。
3. 跨平台性好。因为解释性语言不需要编译,所以转换到其他平台,可以直接解释运行。
4. 解释性语言的代表:
Matlab,Python,JavaScrpt
二. 静态语言和动态语言
1. 静态语言
a. 特点:运行时结构不可变的语言。
b. 优点:结构规范,便于调试,不易出错。
c. 缺点:内容繁杂琐碎,不易理解和阅读。
2. 动态语言
a. 特点:可以中途改变结构,即新的函数可以被引进,已有的函数可以被删除等。
b. 优点:方便阅读,简洁明了。
c. 缺点:不方便调试,命名不规范会出现理解上的错误。
三.静态类型语言和动态类型语言
3. 动态类型语言
a. 特点:运行期间才会去检查数据类型的语言,即编写代码时可以不指定变量的数据类型。
b. 优点:灵活性和自由度高,更好将思考关注所开发的东西本身。
c. 举例:Python, Ruby, Perl, swift
4. 静态类型语言
a. 特点:在运行前(如编译时)检查数据类型的语言,即编写代码时必须明确变量的数据类型。
b. 优点:运行速度快。因为先前明确了变量的类型,可以更早的发现变量类型的错误而不需要去储存和
检测类型。
c. 缺点:过多的类型声明会增加更多的代码。
c. 举例:C, C++, C#, Java
四.强语言和弱语言
1. 强语言
a. 定义:一个指定类型的变量在运行期间除了强制转换以外,不可再变更类型。
b. 特点:编译时可以检查出错误的类型匹配,安全性较高,可以避免许多不必要的错误。
c. 举例: Java,C#, Python
2. 弱语言
a. 定义:数据类型可以忽略的语言。一个变量可以赋不同数据类型的值。
b. 优点:运行速度较强类型语言快。
c. 举例: JavaScript, PHP