实验5Linux编程环境 gcc与make.doc
《实验5Linux编程环境 gcc与make.doc》由会员分享,可在线阅读,更多相关《实验5Linux编程环境 gcc与make.doc(11页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、湖北经济学院 电子工程系 嵌入式Linux系统实验五:Linux编程环境 gcc与make1 实验目的通过实验掌握Linux中的gcc 和 make2 实验设备硬件:PC机一台软件:Windows98/XP/2000系统,VMware Workstation6.0,Red Hat Linux 3 实验内容(1) Linux命令gcc和make4 实验预习要求仔细阅读参考书:【1】鸟哥的Linux私房菜 基础学习篇 第三版,人民邮电出版社,鸟哥【2】嵌入式Linux系统开发标准教程,人民邮电出版社,华清远见嵌入式培训中心【3】嵌入式Linux应用程序开发标准教程,人民邮电出版社,华清远见嵌入式培
2、训中心关于Linux编程环境部分。5 实验步骤(1)熟悉Red Hat Enterprise Linux系统。(2)根据实验重点内容测试。6 实验重点:gcc的用法(1)简单的示例程序示例程序 hello.c 见 gccexample-hello在默认的状态下,如果直接以 gcc 编译源代码,并且没有加上任何参数,则执行文件的文件名会被自动设置为 a.out 这个文件名! 所以能够直接执行 ./a.out 这个可执行文件!如果想要产生目标文件 (object file) 来进行其他的操作,而且可执行文件的文件名也不要用默认的 a.out ,步骤:rootwww # gcc -c hello.c
3、 rootwww # ll hello* -rw-r-r- 1 root root 72 Jun 5 02:40 hello.c -rw-r-r- 1 root root 868 Jun 5 02:44 hello.o =就是被生成的目标文件 rootwww # gcc -o hello hello.o rootwww # ll hello* -rwxr-xr-x 1 root root 4725 Jun 5 02:47 hello =这就是可执行文件!-o 的结果 -rw-r-r- 1 root root 72 Jun 5 02:40 hello.c -rw-r-r- 1 root root
4、 868 Jun 5 02:44 hello.o rootwww # ./hello Hello World这个步骤主要是利用 hello.o 这个目标文件生成出一个名为 hello 的可执行文件。我们可以得到 hello 及 hello.o 两个文件, 真正可以执行的是 hello 这个二进制文件。为什么要先制作目标文件再做成可执行文件呢?(2)主、子程序链接:子程序的编译如果我们在一个主程序里面又调用了另一个子程序呢?这是很常见的一个程序写法,因为可以简化整个程序的易读性!在如下的例子当中,我们以 thanks.c 这个主程序去调用 thanks2.c 这个子程序,见程序gcc-examp
5、le-thanks# 开始将源代码编译成为可执行的 二进制文件 : rootwww # gcc -c thanks.c thanks2.c rootwww # ll thanks* -rw-r-r- 1 root root 76 Jun 5 16:13 thanks2.c -rw-r-r- 1 root root 856 Jun 5 16:13 thanks_2.o =编译产生的! -rw-r-r- 1 root root 92 Jun 5 16:11 thanks.c -rw-r-r- 1 root root 908 Jun 5 16:13 thanks.o =编译产生的! rootwww
6、# gcc -o thanks thanks.o thanks_2.o #最终结果会产生thanks#执行一下这个文件: rootwww # ./thanks Hello World Thank you!为什么要制作出目标文件?由于我们的源代码文件有时并非仅只有一个文件,所以我们无法直接进行编译。 这个时候就需要先产生目标文件,然后再以链接制作成为 binary 可执行文件。另外,如果更新了 thanks2.c 这个文件的内容,则只要重新编译 thanks2.c 来产生新的 thanks2.o ,然后再以链接制作出新的 binary 可执行文件即可!而不必重新编译其他没有更改过的源代码文件。
7、这对于软件开发者来说,这是一个很重要的功能,因为有时候要将很大的源代码全部编译完成,会花很长的一段时间!(3)调用外部函数库:加入链接的函数库示例程序中使用了三角函数库中的sin()方法。见程序gcc-example-sin直接使用gcc sin.c 会报错。这是因为 C 语言里面的 sin 函数是写在 libm.so 这个函数库中,而我们并没有在源代码里面将这个函数库功能加进去, 所以当然就需要在编译和链接的时候将这个函数库链接到可执行文件中我们可以这样做: 编译时加入额外函数库链接的方式rootwww # gcc sin.c -lm -L/lib -L/usr/lib =重点在 -lm r
8、ootwww # ./a.out 1.000000特别注意,使用 gcc 编译时所加入的那个 -lm 是有意义的,他可以拆开成两部份来看: -l :是“加入某个函数库(library)“的意思, m :是 libm.so 函数库,其中,lib与扩展名(.a 或 .so)不需要写 所以 -lm 表示使用 libm.so (或 libm.a) 这个函数库的意思,后面的-L表示: “所要的函数库 libm.so 到 /lib 或 /usr/lib 里面查找!“,要注意的是,由于 Linux默认是将函数库放置在 /lib 或 /usr/lib 中,所以没有写 -L/lib 或-L/usr/lib 也没
9、有关系!但是,如果使用的函数库并非放置在这两个目录下,那么 -L/path 就很重要了!否则会找不到函数库! 除了链接的函数库之外,在 sin.c 当中第一行 #include ,这个文件其实是放置在 /usr/include/stdio.h 中的!那么万一这个文件并非放置在这里呢?那么我们就可以使用下面的方式来定义出要读取的 include 文件放置的目录: gcc sin.c lm I/usr/include-I/path 后面接的路径( Path )就是要去查找相关的 include 文件的目录!不过,同样的,默认值是放置在 /usr/include 下,除非所 include 文件放置
10、在其他路径,否则也可以略过这个选项!(4)gcc的一些例子# 仅将源代码编译成为目标文件,并不制作链接等功能: rootwww # gcc -c hello.c # 会自动的产生 hello.o 这个文件,但是并不会产生 binary 执行文件。# 在进行二进制文件 制作时,将连结的函数库与相关的路径填入 rootwww # gcc sin.c -lm -L/usr/lib -I/usr/include # 这个指令在最终连结成二进制文件 的时候,-lm 指的是 libm.so 或 libm.a 这个函数库文件;-L后面接的路径是刚刚上面那个函数库的搜寻目录; # -I 后面接的是源代码内的
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 实验5Linux编程环境 gcc与make 实验 Linux 编程 环境 gcc make
限制150内