• gcc -o hello hello.c 执行过程


    GCC编译器驱动程序读取源程序文件hello.c,并将它翻译成一个可执行目标文件hello。这个翻译的过程可分为四个阶段。

    1.预处理阶段

    预处理器(cpp)根据以字符#开头的命令,修改原始的c程序。比如hello.c中第1行的#include<stdio.h>命令告诉预处理器读取系统头文件stdio.h的内容,并将它直接插入到程序文本中。结果就得到了另一个C程序,通常是以 .i 作为文件扩展名。

    gcc -E hello.c -o hello.i

    2.编译阶段

    编译阶段将文本文件hello.i 翻译成文本文件hello.s,它包含一个汇编语言程序。汇编语言程序中的每条语句都以一种标准的文本格式确切地描述了一条低级程序机器语言指令。汇编语言是非常有用的,应为它为不同的高级语言的不同编译器提供了通用的输出语言。例如,c编译器和Fortran编译器产生的输出文件用的都是一样的汇编语言。

    gcc -S hello.i -o hello.s

    3.汇编阶段

    接下来,汇编器将hello.s 翻译成机器语言指令,把这些指令打包成一种叫做可重定位目标程序的格式,并将结果保存在目标文件hello.o 中。hello.o文件时一个二进制文件,它的字节编码是机器语言指令而不是字符。

    gcc -c hello.s -o hello.o

    4.链接阶段

    请注意,hello调用了printf函数,它是每个c编译器都会提供的标准C库中的一个函数。printf 函数存在于一个名为printf.o 的单独的预编译好了的目标文件中,而这个文件必须以某种方式合并到我们的hello.o 程序中。链接器就负责处理这种合并。结果就得到hello文件,它是一个可执行目标文件(或者简称可执行文件),可以被加载到内存中,由系统执行。

    gcc hello.o -o hello

    -o <file>  Write output to <file>

    -o 是输出

  • 相关阅读:
    layui学习--tab选项卡
    json过滤不需要的字段
    转载 http协议无状态中的 "状态" 到底指的是什么?
    正则表达式30分钟入门教程--转载
    Hadoop 部署之 HBase (四)
    Hadoop 部署之 Hadoop (三)
    Hadoop 部署之 ZooKeeper (二)
    Hadoop 部署之环境准备(一)
    Kubernetes 集群日志管理 Elasticsearch + fluentd(二十)
    Kubernetes 监控方案之 Prometheus Operator(十九)
  • 原文地址:https://www.cnblogs.com/alway-july/p/7953986.html
Copyright © 2020-2023  润新知