linux gcc编译好C文件后生成.o目标文件,但是在执行中($./test)出现没有那个文件或目录,请大神帮忙?

.o文件是不能被执行的, c的源码要经过编译和链接才能生成可执行文件,你只是编译了,没有链接,这个文件相当于Windows下的test.obj而已。gcc -Wall test.c -o test

Linux的gcc是怎么用的?

在终端中输入 gcc 文件名 -o 目标文件名然后 ./目标文件名 就行了,没有目标文件名,自动存为 a执行 ./a 就行了。在使用Gcc编译器的时候,我们必须给出一系列必要的调用参数和文件名称。GCC编译器的调用参数大约有100多个,其中多数参数我们可能根本就用不到,这里只介绍其中最基本、最常用的参数。  GCC最基本的用法是∶gcc   其中options就是编译器所需要的参数,filenames给出相关的文件名称。  -c,只编译,不连接成为可执行文件,编译器只是由输入的.c等源代码文件生成.o为后缀的目标文件,通常用于编译不包含主程序的子程序文件。  -o output_filename,确定输出文件的名称为output_filename,同时这个名称不能和源文件同名。如果不给出这个选项,gcc就给出预设的可执行文件a.out。  -g,产生符号调试工具(GNU的gdb)所必要的符号资讯,要想对源代码进行调试,我们就必须加入这个选项。  -O,对程序进行优化编译、连接,采用这个选项,整个源代码会在编译、连接过程中进行优化处理,这样产生的可执行文件的执行效率可以提高,但是,编译、连接的速度就相应地要慢一些。  -O2,比-O更好的优化编译、连接,当然整个编译、连接过程会更慢。  -Idirname,将dirname所指出的目录加入到程序头文件目录列表中,是在预编译过程中使用的参数。C程序中的头文件包含两种情况∶  A)#include <myinc.h>  B)#include “myinc.h”  其中,A类使用尖括号(< >),B类使用双引号(“ ”)。对于A类,预处理程序cpp在系统预设包含文件目录(如/usr/include)中搜寻相应的文件,而B类,预处理程序在目标文件的文件夹内搜索相应文件。 GCC执行过程示例  示例代码 a.c:  #include <stdio.h>  int main()  {  printf(“hellon”);  }  预编译过程:  这个过程处理宏定义和include,并做语法检查。  可以看到预编译后,代码从5行扩展到了910行。  gcc -E a.c -o a.i  cat a.c | wc -l  5  cat a.i | wc -l  910  编译过程:  这个阶段,生成汇编代码。  gcc -S a.i -o a.s  cat a.s | wc -l  59  汇编过程:  这个阶段,生成目标代码。  此过程生成ELF格式的目标代码。  gcc -c a.s -o a.o  file a.o  a.o: ELF 64-bit LSB relocatable, AMD x86-64, version 1 (SYSV), not stripped  链接过程:  链接过程。生成可执行代码。链接分为两种,一种是静态链接,另外一种是动态链接。使用静态链接的好处是,依赖的动态链接库较少,对动态链接库的版本不会很敏感,具有较好的兼容性;缺点是生成的程序比较大。使用动态链接的好处是,生成的程序比较小,占用较少的内存。  gcc a.o -o a  程序运行:  ./a  hello编辑本段GCC编译简单例子  编写如下代码:  #include <stdio.h>  int main()  {  printf(“hello,world!n”);  }  执行情况如下:  gcc -E hello.c -o hello.i  gcc -S hello.i -o hello.s  gcc -c hello.s -o hello.o  gcc hello.c -o hello  ./hello  hello,world!

Linux下gcc编译提示错误。在函数_start中main未定义的引用?

你是不是在编译静态库或者动态库?也就是没有main函数。

如果是,再参考一下下边的提示。-c 参数表示将源文件编译成object(目标文件)。即 gcc -c foo.c 会编译成 foo.o gcc 不加参数时会编译且尝试链接成可执行文件,然而 foo.c 的代码中没有main函数的定义,所以最终无法成功链接,故报错。

在linux中,怎么用gcc编译文件?

编译方法:格式 gcc 常用的选项最简单的是:gcc hello.c默认的情况下将生成a.out的可执行性文件,只需要在终端上输入./a.out就可以看到执行的结果,如果你想指定生成目标文件的名字那么你可以加上 -o选项,命令如下:gcc -o hello hello.c命令:gcc -c hello hello.c

扩展资料:

gcc命令的基本用法gcc 其中,filenames为文件名;options为编译选项。当不使用任何编译选项编译hello.c时,gcc将会自动编译产生一个a.out的可执行文件:# ls hello.c # gcc hello.c # ls a.out hello.c 执行:# ./a.out Hello, World! 使用-o编译选择,可以为编译后的文件指定一个名字:# ls a.out hello.c # gcc hello.c -o hello # ls a.out hello hello.c 执行:# ./hello Hello, World! 注意:使用-o选项时,-o后面必须跟一个文件名,即:-o outfile。为了便于描述后面的选项,删除hello和a.out可执行文件。

arm-linux-gcc-3.4.5-glibc-2.3.6是什么意思?

是一个交叉编译软件。为什么必须要安装呢?

因为我们编写C语言是在我们自己的PC上linux操作系统下利用GCC编写的,而我们的应用程序最终是要装载到ARM芯片上,所以这中间需要转换。就用的arm-linux-gcc来编译生成目标文件。

如果只是用gcc虽然在个人PC编译正确,但是下载到目标芯片却是错误的,原因就在运行的环境不一样。