zoukankan      html  css  js  c++  java
  • Linux程序在预处理、编译、汇编、链接、运行步骤的作用

    创建一个hello.c文件,按步骤操作:

    一、预编译 <生成 hello.i文件 >

    操作步骤:gcc -E hello.c -o hello.i

    1.将所有的#define删除,并展开所有的宏定义; 

    2.处理所有的预编译指令,例如:#if,#elif,#else,#endif; 

    3.处理#include预编译指令,将被包含的文件插入到预编译指令的位置; 

    4.添加行号信息文件名信息,便于调试; 

    5.删除所有的注释:// /**/; 

    6.保留所有的#pragma编译指令,因为在编写程序的时候,我们经常要用到#pragma指令来设定编译器的状态或者是指示编译器完成一些特定的动作。 

    生成.i文件。

    包括(1)去注释 (2)宏替换 (3)头文件展开 (4)条件编译
    二、编译(高级语言——>汇编语言)<生成hello.s文件>

    操作步骤:gcc -S hello.i -o hello.s   

    主要作用:1.扫描(词法分析),2.语法分析,3.语义分析,4.源代码优化(中间语言生成),5.代码生成,目标代码优化。

    三、汇编(汇编语言——>二进制文件)<生成hello.o文件>

    操作步骤:gcc -c hello.s -o hello.o

    主要作用:汇编器是将汇编代码转变成可以执行的指令,生成 目标文件。

    四、链接(生成exe文件)

    操作步骤:gcc hello.o -o hello

    主要作用:链接过程主要包括:地址和空间的分配,符号决议和重定位。

    地址和空间:系统给函数、变量分配地址和空间。

    符号决议:也可以说地址绑定,分动态链接和静态链接,

    重定位:假设此时又两个文件:A,B。A需要B中的某个函数mov的地址,未链接前将地址置为0,当A与B链接后修改目标地址,完成重定位

    五、运行

    操作步骤:./hello

    主要功能:运行程序

  • 相关阅读:
    21-MySQL-Ubuntu-快速回到SQL语句的行首和行末
    2- SQL语句的强化
    1-数据准备
    20-MySQL-Ubuntu-数据表的查询-子查询(九)
    19-MySQL-Ubuntu-数据表的查询-自关联(八)
    18-MySQL-Ubuntu-数据表的查询-连接(七)
    17-MySQL-Ubuntu-数据表的查询-分页(六)
    16-MySQL-Ubuntu-数据表的查询-分组与聚合(五)
    15-MySQL-Ubuntu-数据表的查询-聚合函数(四)
    14-MySQL-Ubuntu-数据表的查询-范围查询(三)
  • 原文地址:https://www.cnblogs.com/single-dont/p/11315980.html
Copyright © 2011-2022 走看看