计算机识别高级语言为什么是逐层编译?
C语言是高级语言,小甲鱼老师说是计算机要看得懂C语言,得先把C语言编译成汇编语言,在把汇编语言编译成机器码,那这样是不是相当于翻译了两次,那机器为什么不一步到位,直接把C语言编译成机器码呢{:5_94:} 我可不可以这样认为,无论是用汇编语言还是高级语言写的程序,其最终都将被翻译成机器码来让机器执行,用高级语言翻译成的机器码 和 用汇编语言翻译成的机器码没有任何区别,有区别的是编译的过程,汇编语言只需要编译一次,,高级语言需要编译两次,只是在编译效率耗时上存在区别 直接把C语言编译成机器码编译成哪个机器的机器码?
i386的还是x86_64的?
arm的还是riscv的?
stc89c52rc的还是STM32F407ZGT6 ?
编译成哪个的?
一个机器写一个C语言编译器? C语言的词法分析、语法分析、语义分析、中间代码生成,中间代码优化,这部分是和机器无关的,为什么要在每一个机器上都写一遍这些东西?
人造人 发表于 2022-4-30 17:21
直接把C语言编译成机器码
编译成哪个机器的机器码?
i386的还是x86_64的?
不同类型的机器其CPU架构不一样,所以每一种机器都有自己独有的指令集,写出来的汇编指令及其生成机器码也只能被自己识别,其他类型的机器无法识别,而高级语言能够移植是在源代码层面移植,在编译和执行上则需要经过自己的指令集来翻译成自己能识别的机器码,是这个意思吗? 竹逸 发表于 2022-4-30 18:13
不同类型的机器其CPU架构不一样,所以每一种机器都有自己独有的指令集,写出来的汇编指令及其生成机器码 ...
对,所以要分开 人造人 发表于 2022-4-30 19:54
对,所以要分开
好的,谢谢{:5_108:}
页:
[1]