GCC功能及使用

标签: gcc 功能 | 发表时间:2013-11-22 00:25 | 作者:waldmer
出处:http://blog.csdn.net

功能:

预处理、编译、连接、汇编





编译过程(从源代码到可执行文件)

预处理:gcc -Ehello.c -o hello.i //生成预处理后的源文件
汇编:gcc -S hello.i //生成hello.s
目标代码生成:gcc -c hello.s //生成hello.o
连接:gcc hello.o -o hello //生成可以行文件hello




静态库、动态库:

方法一:将hello1.c和hello2.c编译成静态链接库.a
[[email protected] main5]#gcc -c hello1.c hello2.c   
  //将hello1.c和hello2.c分别编译为hello1.o和hello2.o,其中-c选项意为只编译不链接。
[[email protected] main5]#ar -r libhello.a hello1.o hello2.o   
//将hello1.o和hello2.o组合为libhello.a这个静态链接库
[[email protected] main5]#cp libhello.a /usr/lib     
//将libhello.a拷贝到/usr/lib目录下,作为一个系统共享的静态链接库
[[email protected] main5]#gcc -o hello hello.c -lhello  
//将hello.c编译为可执行程序hello,这个过程用到了-lhello选项,这个选项告诉gcc编译器到/usr/lib目录下去找libhello.a的静态链接库
以上的过程类似于windows下的lib静态链接库的编译及调用过程。
方法二:将hello1.o和hello2.o组合成动态链接库.so
[[email protected] main5]#gcc -c -fpic hello1.c hello2.c   
 //将hello1.c和hello2.c编译成hello1.o和hello2.o,-c意为只编译不链接,-fpic意为位置独立代码,指示编译程序生成的代码要适合共享库的内容这样的代码能够根据载入内存的位置计算内部地址。
[[email protected] main5]#gcc -shared hello1.o hello2.o -o hello.so 
  //将hello1.o和hello2.o组合为shared object,即动态链接库
[[email protected] main5]#cp hello.so /usr/lib  
  //将hello.so拷贝到/usr/lib目录下
[[email protected] main5]#gcc -o hello hello.c hello.so  
//将hello.c编译链接为hello的可执行程序,这个过程用到了动态链接库hello.so

作者:waldmer 发表于2013-11-21 16:25:35 原文链接
阅读:0 评论:0 查看评论

相关 [gcc 功能] 推荐:

GCC功能及使用

- - CSDN博客推荐文章
编译过程(从源代码到可执行文件). 预处理:gcc -Ehello.c -o hello.i //生成预处理后的源文件. 汇编:gcc -S hello.i //生成hello.s. 目标代码生成:gcc -c hello.s //生成hello.o. 连接:gcc hello.o -o hello //生成可以行文件hello.

GCC安装 配置

- - CSDN博客推荐文章
下载:  http://ftp.gnu.org/gnu/gcc/gcc-4.5.1/gcc-4.5.1.tar.bz2. 浏览:  http://ftp.gnu.org/gnu/gcc/gcc-4.5.1/. 查看Changes:  http://gcc.gnu.org/gcc-4.5/changes.htm.

GCC将用C++实现

- Chris - Solidot
Lwn.net报道,GCC(GNU Compiler Collection,GNU编译器套装)将从一个C语言实现变成C++语言实现. Mark Mitchell在官方邮件列表上宣布,GCC指导委员会和自由软件基金会(FSF)同意GCC本身的代码将使用C++语言编写. 此举是为了向用户提供一个更好的编译器,而不是因为C++代码库本身的原因.

RMS谈GCC、LLVM和Copyleft

- - Solidot
ESR(Eric S.Raymond)在GCC邮件列表上发贴预言,LLVM/Clang编译器将在3到5年内威胁到GCC的统治地位,认为GCC编译器的反插件政策正成为一大障碍. 虽然Clang尚未达到GCC的成熟度,但在某些方面它拥有比GCC更出色的特性,例如错误信息. ESR建议GCC应允许非自由的插件.

GCC、LLVM-GCC、DragonEgg和Clang编译性能对比

- allengaller - Solidot
Phoronix利用Phoronix Test Suite测试了GCC 4.2.1、4.3.0、4.4.0、4.5.0、GCC 4.6.0 2010-10-30开发预览版,以及LLVM-GCC 2.8、LLVM DragonEgg 2.8和Clang 2.8编译器的编译性能. 测试结果显示,与新贵LLVM-GCC和Clang相比,有二十多年历史的GCC编译器确实比较慢 虽然LLVM和Clang的新版本提供了完整的C++支持,并且能编译Linux kernel,但它们目前还达不到取代成熟GCC的程度,Clang或DragonEgg还无法完成某些常见任务的编译,性能也未能如意.

关于gcc、glibc和binutils模块之间的关系

- - 博客园_iTech's Blog
转自: http://www.mike.org.cn/articles/linux-about-gcc-glibc-and-binutils-the-relationship-between-modules/. 一、关于gcc、glibc和binutils模块之间的关系.   1、gcc(gnu collect compiler)是一组编译工具的总称.

如何利用GCC编译选项检测栈溢出

- - 极客范 - GeekFan.net
Stack smashing是堆栈缓冲区溢出(stack buffer overflow)的一个时髦称谓. 它表示利用代码中存在的缓冲区溢出bug而发起的攻击. 在早期,这完全是程序员的责任,他们要确保代码中不存在缓冲区溢出的问题. 但是随着时间推移,技术的不断发展,现在像gcc这样的编译器已经有编译选项用来确保缓冲区溢出问题不被攻击者利用来破坏系统或者程序.

gcc创建和使用动态库、静态库

- - CSDN博客综合推荐文章
本文以工程 libtest为例来说明用gcc创建和使用静态库、动态库的过程. libtest工程目录结构如下:. libtest/include/hello.h文件内容:. libtest/lib/hello.c文件内容:. libtest/src/main.c文件内容:. 1,进入libtest/lib目录,执行命令:.

linux下用gcc创建静态链接库和动态链接库

- - CSDN博客推荐文章
上一篇文章介绍了在windows下如何创建静态链接库和动态链接库( http://blog.csdn.net/love_cppandc/article/details/8502773),这一篇介绍一下在linux下如何创建静态链接库和动态链接库. 在linux下,静态库文件是.o结尾,动态库文件是.so结尾.

CentOS6.9完全离线升级安装gcc-5.4.0 - weixin_40420213的博客 - CSDN博客

- -
系统自带的gcc版本为4.4.7,升级至5.4.0版本,需要提前准备以下安装包:. gcc-5.4.0.tar.gz 安装包. gmp-4.3.2.tar.bz2 gcc依赖包. mpfr-2.4.2.tar.bz2 gcc依赖包. mpc-0.8.1.tar.gz gcc依赖包. 上面三个依赖包的版本依据,可以将gcc-5.4.0.tar.gz解压后在gcc-5.4.0/contrib/download_prerequisites文件中找到.