实验四LINUX下C语言使用、编译与调试实验2.doc
下载提示(请认真阅读)1.请仔细阅读文档,确保文档完整性,对于不预览、不比对内容而直接下载带来的问题本站不予受理。
2.下载的文档,不会出现我们的网址水印。
3、该文档所得收入(下载+内容+预览)归上传者、原创作者;如果您是本文档原作者,请点此认领!既往收益都归您。
文档包含非法信息?点此举报后获取现金奖励!
下载文档到电脑,查找使用更方便
12.9
积分
还剩页未读,继续阅读
关 键 词:Linux下C语言
编译与调试实验
Linux 下 C 语言
LINUX下C语言使用
LINUX 下 C 语言使用
linux 下c
LINUX 下C语言使用
LINUX下
linux下面
资源描述:
实验四:LINUX 下C语言使用、编译与调试实验
一、目的:
1、 练习并掌握Linux提供的vi编辑器来编译C程序
2、 学会利用gcc、gdb编译、调试C程序
3、 学会使用make工具
二、内容
1、 编写C语言程序,用gcc编译并观察编译后的结果,运行生成的可执行文件。
2、 利用gdb调试程序。
3、 学习编写makefile,并进行编译。
三、操作
1、文件编辑器vi
进入vi,直接执行vi编辑程序。
例:# vi test.c
显示器出现vi的编辑窗口,同时vi会将文件复制一份至缓冲区(buffer)。vi先对缓冲区的文件进行编辑,保留在磁盘中的文件则不变。编辑完成后,使用者可决定是否要取代原来旧有的文件。
1) vi的工作模式
(1)输入模式
输入以下命令即可进入vi输入模式:
a
在光标之后加入资料
A
在该行之末加入资料
i
在光标之前加入资料
I
在该行之首加入资料
o
新增一行于该行之下
O
新增一行于该行之上
(2)命令模式
在输入模式下,按ESC可切换到命令模式。命令模式下,可选用下列指令离开vi:
:q!
离开vi,并放弃刚在缓冲区内编辑的内容
:wq
将缓冲区内的资料写入磁盘中,并离开vi
ZZ
同wq
:x
同wq
:w
将缓冲区内的资料写入磁盘中,但并不离开vi
:q
离开vi,若文件被修改过,则要被要求确认是否放弃修改的内容,此指令可与:w配合使用
(3)命令模式下光标的移动
h
左移一个字符
j
下移一个字符
k
上移一个字符
l
右移一个字符
0(零)
移至该行的行首
$
移至该行的行尾
^
移至该行的第一个字符处
H
移至窗口的第一行
M
移至窗口中间那一行
L
移至窗口的最后一行
G
移至该文件的最后一行
W, w
下一个单词 (W 忽略符号)
B, b
上一个单词 (B 忽略符号)
(4) 命令模式下的编辑命令
dd
删除当前光标所在行
yy
复制当前光标所在行
p
将复制的内容粘贴在光标所在的位置后
P
将复制的内容粘贴在光标所在的位置前
x
删除当前光标字符
X
删除当前光标之前字符
u
撤消
·
重做
2、GNU C编译器
1) 使用gcc
通常后跟一些选项和文件名来使用gcc编译器。gcc命令的基本用法如下:
gcc [options] [filenames]
命令行选项指定的编译过程中的具体操作
2) gcc常用选项
当不用任何选项编译一个程序时,gcc将建立(假定编译成功)一个名为a.out的可执行文件。
选项含义:
-o FILE 指定输出文件名,在编译为目标代码时,这一选项不是必须的。如果FILE 没
有指定,默认文件名是a.out.
例如,
# gcc test.c
编译成功后,当前目录下就产生了一个a.out文件。
也可用-o选项来为即将产生的可执行文件指定一个文件名来代替a.out。
例如:
#gcc –o count count.c
此时得到的可执行文件就不再是a.out,而是count。
-c GCC 仅把源代码编译为目标代码。默认时GCC 建立的目标代码文件有一个.o 的
扩展名。
-E 对文件进行预处理
-S 对文件进行编译,生成汇编代码。
-O 对源代码进行基本优化。这些优化在大多数情况下都会使程序执行得更快。
-g 在可执行程序中包含标准调试信息。
-Wall 允许发出GCC 能提供的所有有用的警告,也可以用-W(warning)来标识指定的
警告。
-l name链接静态库
-L dir 库文件的搜索路径
3) 执行文件
格式: ./可执行文件名
例:
# ./a.out
# ./count
4) 例子
mypow.c:定义mypow()函数
unsigned long long mypow(unsigned int x, unsigned int y)
{
unsigned long long res=1;
if (y==0)
res = 1;
else if (y==1)
res = x;
else
res = x * mypow(x, y-1);
return res;
}
powtest.c:调用mypow()函数
#include #include int main(int argc, char *argv[])
{
unsigned int x, y;
unsigned long long res;
if ((argc<3) || (sscanf(argv[1], "%u", &x)) != 1 || (sscanf(argv[2], "%u", &y)) != 1 )
{
printf("Usage:pow base exponent\n");
exit(1);
}
res = mypow(x, y);
printf("%u ^ %u = %u\n", x, y, res);
return 0;
}
编译过程:
# gcc -c mypow.c
# ar rcsv libpow.a mypow.o
a - mypow.o
# gcc -o powtest powtest.c -L. -lpow
# ./powtest
Usage:pow base exponent
# ./powtest 2 10
2 ^ 10 = 1024
3、gdb调试工具
1) 调试编译代码
为了使gdb正常工作,必须使你的程序在编译时包含调试信息。调试信息里包含你程序里的每个变量的类型和在可执行文件里的地址映射以及源代码的行号。gdb利用这些信息使源代码和机器码相关联。
在编译时用 –g 选项打开调试选项。
2) gdb基本命令
命 令
描 述
file
装入欲调试的可执行文件
kill
终止正在调试的程序
list
列出产生执行文件的源代码部分
next
执行一行源代码但不进入函数内部
step
执行一行源代码并进入函数内部
run
执行当前被调试的程序
quit
终止gdb
watch
监视一个变量的值而不管它何时被改变
break
在代码里设置断点,使程序执行到这里时被挂起
make
不退出gdb就可以重新产生可执行文件
shell
不离开gdb就执行UNIX shell 命令
3) 调试程序
(1) 源程序gdbtest1.c,分析程序的功能,如果出错,要求用gdb进行调试并给出修改方案。
基本步骤:
¨ 编译:gcc -g -o gdbtest1 gdbtest1.c
¨ 运行:./gdbtest1
¨ 开始调试:gdb gdbtest1
#include int add_range(int low, int high)
{
static int i,sum;
for(i=low; i<=high; i++)
sum = sum +i;
return sum;
}
int main(void)
{
int result[100];
result[0] = add_range(1,10);
result[1] = add_range(1,100);
printf("result[0]=%d\nresult[1]=%d\n",result[0],result[1]);
return 0;
}
(2) 源程序greet.c,功能:按照正序和逆序输出给定的字符串。要求用gdb进行调试,,分析出错的原因并给出修改方案。
#include #include #include void my_print (char *string);
void my_print2 (char *string);
int main()
{
char my_string[] = "hello there";
my_print (my_string);
my_print2 (my_string);
return 0;
}
void my_print (char *string)
{
printf ("The string is %s\n", string);
}
void my_print2 (char *string)
{
char *string2;
int size, i;
size = strlen (string);
string2 = (char *) malloc (size + 1);
for (i = 0; i < size; i++)
string2[size - i] = string[i];
string2[size + 2] = '\0';
printf ("The string printed backward is %s\n", string2);
}
4、make的使用
(1)用vi编辑以下程序,程序清单:
main.c
function1.h
function1.c
function2.h
function2.c
//main.c
#include "function1.h"
#include "function2.h"
int main(int argc, char **argv)
{
function1_print("hello");
function2_print("world");
return 0;
}
//function1.h
void function1_print(char *str);
//function1.c
#include "function1.h"
void function1_print(char *str)
{
printf("This is function1 print %s\n", str);
}
//function2.h
void function2_print(char *str);
//function2.c
#include "function2.h"
void function2_print(char *str)
{
printf("This is function2 print %s\n", str);
}
实验要求:
(1)画出各个源程序、目标文件以及最终的目标文件之间的依赖关系图。
(2)编辑makefile文件
(3)利用make命令进行上述程序的编译,生成可执行代码并运行。
(4)修改其中一个源文件,重新make,察看编译过程。
(5)通过使用makefile变量和隐含规则,对makefile文件进行简化
四.试验总结
写出详细的试验过程及其试验结果。
展开阅读全文
温馨提示:
1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
2: 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
3.本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
人人文库网所有资源均是用户自行上传分享,仅供网友学习交流,未经上传用户书面授权,请勿作他用。
关于本文
本文标题:实验四LINUX下C语言使用、编译与调试实验2.doc
链接地址:https://www.renrendoc.com/p-16490423.html