大家好,今天小编关注到一个比较有意思的话题,就是关于翻译成c语言的问题,于是小编就整理了3个相关介绍翻译成c语言的解答,让我们一起看看吧。
高级语言编写的源程序必须经过______才能执行?
C
高级语言所编制的程序不能直接被计算机识别,必须经过转换才能被执行,按转换方式可将它们分为两类: 解释类:执行方式类似于我们日常生活中的“同声翻译”,应用程序源代码一边由相应语言的解释器“翻译”成目标代码(机器语言),一边执行,因此效率比较低,而且不能生成可独立执行的可执行文件,应用程序不能脱离其解释器,但这种方式比较灵活,可以动态地调整、修改应用程序。 编译类:编译是指在应用源程序执行之前,就将程序源代码“翻译”成目标代码(机器语言),因此其目标程序可以脱离其语言环境独立执行,使用比较方便、效率较高。但应用程序一旦需要修改,必须先修改源代码,再重新编译生成新的目标文件(* .OBJ)才能执行,只有目标文件而没有源代码,修改很不方便。现在大多数的编程语言都是编译型的,例如Visual C++、Visual Foxpro、Delphi等。
C语言是根据什么原理和机制生产汇编的?
用C/C++语言这类高级编程语言所编写的程序源码是利用一种叫做“编译原理”的技术,经过一些列的处理步骤,最终转变为汇编指令,再最后翻译机器指令。我们知道计算机只能处理和识别二进制指令,而我们所编写的程序包含各种较复杂的结构,例如 if语句、循环语句、继承、多态、虚函数等。其实,在很早的时候,计算机科学家们就已经在研究如何把接近人类语言的高级语言所编写的程序转换成机器指令了。这些研究成果都归属于“编译原理”领域,并且“编译原理”是计算机专业学生的必修课。
那么根据编译原理,C语言是怎么转换成汇编语言,总共分以下几个步骤:
1. 预处理 -> 2.词法分析 -> 3.语法分析 -> 4.语义分析 -> 5.优化 -> 6.链接
注意,我上面列出的过程是目前实际中真正***用的步骤,编译原理课程中可能没有把完整步骤列出来,只列举了核心的几个步骤。
上面每个步骤在编译原理课程中都有一个专门的章节来讲述。这里大概说一下每个步骤的作用吧。
1. 预处理:负责执行C语言中的#include, #if, #else 等预处理指令。注意,这里是去执行这些预处理指令。这些预处理指令的作用是根据你的系统环境配凑出最终版的源代码。
2. 词法分析:把你定义的函数名、变量名、预留的关键字等抽象化,用一个符号来代替,方便编译程序处理。例如上图中的main, return, printf等单词,都被看作一个符号,转换成M, R, P。在这个过程中,会检查你的变量名、函数名名称是否正确。
3. 语法分析:经过词法分析处理之后,程序代码已经变成一堆符号了,例如 I S T F ... M I R P(放心,人已经不认识了,但是计算机能认识)。这时的符号是打散的,语法分析负责把这些符号按照一定的结构组织起来,形成一个抽象语法树(这个结构跟你写的程序代码的结构是对应起来的)。
C语言是一种高级编程语言,它的代码需要通过编译器将其转化为汇编语言,再由汇编器将其转化为机器码,最终在计算机上运行。C语言中的每个语句都会被编译器翻译成一条或多条汇编指令。
在C语言中,每个变量都有一个内存地址,在程序中使用变量时,实际上是在操作这个内存地址。C语言的变量类型和内存分配方式都可以直接映射到底层的硬件结构上。
C语言与汇编之间的关系是通过编译器实现的。编译器将C代码转换为汇编代码时,会根据C语言的规则和约定来生成对应的汇编指令。而汇编指令则是直接操作计算机硬件的指令,它们可以被CPU直接执行。
总之,C语言通过编译器将高级代码转换成底层机器码执行,而这个过程中涉及到了许多底层原理和机制。
C语言、汇编语言、机器指令、CPU之间是怎么联系起来的?
***如你设计一个数字电路,包括一个[_a***_]器和一个乘法器。
你希望根据需要,有时对输入数据做加法,有时对输入做乘法,该怎样做呢?最早的计算机,是靠连线的,与其说是计算机,不如说是巨型面包板。直到冯洛伊曼的edvac计划把存储器引入计算机。
***设加法器和乘法器都具有使能端,两个使能端为01,就是加法器工作,是10,就是乘法器工作。
然后为了让电路根据要求的顺序做加法和乘法,你把一系列01、10存储起来,当你要做加法,加法,乘法,加法时,存储的就是01011001。你增加了一个时序电路,每次读出两个位,把高低电平加在两个使能端上,替代你的手工接线。01和10这两个数码能控制电路的行为,起名叫机器码。
然而这样二进制的东西并不好记忆。于是你给01起了个名字,叫add,10起名叫mul。你的这组运算就记为add,add,mul,add。
add,mul这种助记符,就叫代码,具体说是汇编代码;你会找一个悲催的助手,帮你把代码替换成01,10这种机械码。当然总有一些助手认为这个活动太没有人生价值,于是不甘心当花瓶的女助手葛丽丝·霍普(Grace Murray Hopper)设计了将代码翻译成机器码的代码,这个活儿以后就由机器来做,编译器出现了。
因此所谓cpu认识代码,是一种拟人化的修辞,偏文艺了。cpu只是一种根据高低电平输入,产生特定的高低电平输出的机器。代码不过是助记符。
后来你觉得add,add,add,add,add这类写法太烦,于是发明了五连加,7连乘之类的写法——高级语言代码诞生了。葛丽丝·霍普搞了cobol,约翰·巴科斯(John Warner Backus)搞了FORTRAN等等。
但是相对来说第一批的高级语言写起来比较烦,比如FORTRAN语言,子程序用function开头,用end结束。相信用过python的人都会觉得FORTRAN太学究气息了。
所以后来丹尼斯·里奇(Dennis Ritchie )在开发unix系统的同时,顺便设计了语法简单的c语言。main()可比function main()end简便多了。
到此,以上就是小编对于翻译成c语言的问题就介绍到这了,希望介绍关于翻译成c语言的3点解答对大家有用。