-E 仅作预处理,不进行编译、汇编和链接
-S 编译到汇编语言,不进行汇编和链接
-c 编译、汇编到目标代码,不进行链接
-o <文件> 输出到 <文件>
预编译#include,含有<stdio.h>等头文件,自己建立一个头文件welcome.h
#ifndef _WELCOME_H
#define _WELCOME_H
void welcome();
#endif
然后建立welcome.c
#include<stdio.h>
#include "welcome.h"
void welcome()
{
printf("welcome to my code world!\n");
}
int main()
{
welcome();
return 0;
}
gcc -E welcome.c
预编译就是对头文件以及头文件涉及的库先处理编译的过程。
gcc -S 就是把c经过预编译后,转化为汇编语言的过程
gcc -S welcome.c
.file "welcome.c"
.section .rodata
.LC0:
.string "welcome to my code world!"
.text
.globl welcome
.type welcome, @function
welcome:
.LFB0:
.cfi_startproc
pushq %rbp
.cfi_def_cfa_offset 16
.cfi_offset 6, -16
movq %rsp, %rbp
.cfi_def_cfa_register 6
movl $.LC0, %edi
call puts
popq %rbp
.cfi_def_cfa 7, 8
ret
.cfi_endproc
.LFE0:
.size welcome, .-welcome
.ident "GCC: (Ubuntu/Linaro 4.6.3-1ubuntu5) 4.6.3"
.section .note.GNU-stack,"",@progbits
-c 编译、汇编到目标代码,不进行链接
gcc -c welcome.c
目标代码是什么?分为已连接的目标代码(目标程序)和没链接的目标代码(一堆乱码还不能运行)
ELF>8@@
UH����]�welcome to my code world!GCC: (Ubuntu/Linaro 4.6.3-1ubuntu5) 4.6.3zRx
K�A�C
.symtab.strtab.shstrtab.rela.text.data.bss.rodata.comment.note.GNU-stack.rela.eh_frame @�0
&PP1P90j+B�W�R�
�ax
���
welcome.cwelcomeputs
gcc welcome.c -o welcome
./welcome
welcome to my code world!
gcc -o 目标文件的过程:预编译-编译到汇编语言-汇编-链接
我说的很浅显,但这是初步认识的编译过程和命令。