不同的编译器工具链做不同的事情。正如在对您最初问题的注释中所讨论的,一些编译器将源代码直接转换为机器代码,而另一些编译器将源代码转换为汇编代码(作为中间表示),然后通过汇编器运行该汇编代码以生成机器代码。我的经验主要是使用做前者的编译器,但Peter Cordes正确地指出GCC做后者。实际的实现大多是无关紧要的,除非您正在处理编译器本身。任何一个都将产生正确的结果,并且都不会对使用编译器的人产生任何相关的影响。
实际上,在这两个模型之间还有另一个概念上适合的替代方案。Clang(更具体地说,LLVM)就是一个例子。它将源代码编译成中间语言,但它不使用特定于体系结构的汇编语言作为中间表示,而是使用IR(中间表示)。事实上,这是LLVM编译模型的一大创新。该工具链分三个阶段实现:前端将源代码解析为IR代码,优化器对IR代码进行优化传递,后端将IR代码转换为特定CPU的机器代码。
这种设计允许为各种源语言编写各种前端,以及针对任何CPU的各种后端。然而,位于中间的优化器在所有情况下都是相同的,因为它处理的是始终相同的中间IR代码。
顾名思义,机器代码是特定于机器的。机器码的x86将只运行在x86处理器上;ARM机器码只在ARM处理器上运行;等等。
这是由编译器作为输出的最后阶段生成的。它生成一个目标文件,其中包含目标代码,而目标代码实际上只是打包到目标文件中的机器代码。然而,目标文件通常不仅仅包含机器代码--它们还包含内部和外部符号的表、常量数据、调试信息等。链接器在从这些目标文件生成最终的可执行映像时会使用所有这些。
虽然您没有特别询问它,但汇编代码只是机器代码的人类可读形式。机器代码是二进制格式,可以由处理器直接执行,而汇编代码使用助记符,程序员更容易读写。例如,在x86上,目标代码可能包含字节0x74,但在汇编语言中,这将由助记符je
表示(或者等效地,jz
)。汇编程序是将汇编语言助记符转换成二进制机器代码的程序。
问题- 蒙克喜欢在数组上预制不同的操作,因此作为哈克地球学校的校长,他给他的新学生米什基布置了一个任务。Mishki将被提供一个大小为N的整数数组A和一个整数K,在这里她需要将数组向正确的方向旋转K步,然后打印结果数组。由于她是新来的,请帮助她完成任务。 输入: 第一行将由一个表示测试用例数的整数T组成。对于每个测试用例: 第一行由两个整数N和K组成,N是数组中的元素数,K表示旋转的步数。 下一行
远程类加载是指加载未在执行位置显示的类。 例如,JavaApplet需要将类从服务器加载到本地并在本地执行。 一些包含URLClassLoader的程序需要从网络加载类,并在本地执行。 RMI怎么样?我找到了一个名为RMIClassLoader的类?是远程类加载吗?
问题内容: 该函数将与关联的终结器设置为。 默认情况下会终结哪种对象? 默认情况下终结那些对象会导致哪些意外陷阱? 问题答案: 默认情况下,完成以下对象: os。File:当对象被垃圾回收时,文件自动关闭。 os。流程:完成将释放与流程相关的任何资源。在Unix上,这是空操作。在Windows上,它关闭与进程关联的句柄。 在Windows上,程序包似乎可以自动关闭网络连接。 除了上述对象之外,Go
我想知道Java中的一些情况(或者更广泛地说:在编程中),在布尔表达式中,使用无条件的()而不是条件版本()是可取的。 我知道它们是如何工作的,但我无法考虑使用单个是否值得。
问题内容: 我正在评估JOOQ是否可在仍在开发中的新系统中使用。我想避免在与应用程序一起开发数据库时生成代码,而只是为该应用程序起持久存储的作用。因此,预计数据库模式定义将由Java代码(java中的表定义)驱动。 JOOQ是否适合上述用例?是否有用于模式定义的Java DSL? 问题答案: JOOQ是否适合上述用例? 是的,许多jOOQ用户仅使用运行时库,而没有代码生成器。入门指南中提供了示例。
我正在评估JOOQ在一个仍在开发中的新系统中的使用情况。当数据库与应用程序一起开发时,我希望避免代码生成,而只是在这个应用程序中扮演持久存储的角色。因此,数据库模式定义应该由Java代码(Java中的表定义)驱动。 JOOQ是否适用于上述用例?是否有用于模式定义的JavaDSL?