zoukankan      html  css  js  c++  java
  • arm-linux-gcc 的使用

    1. 编译 C 文件,生成 elf 可执行文件 h1.c 源文件

    #include <stdio.h> void hellofirst(void)

    {

    printf("The first hello! ");

    }

    h2.c 源文件

    #include <stdio.h> void hellosecond(void)

    {

    printf("The second hello! ");

    }

    hello.c 源文件

    #include  <stdio.h> void hellosecond(void); void hellofirst(void);

    int main(int argc, char *argv[])

    {

    hellofirst(); hellosecond(); return(0);

    }

    编译以上 3 个文件,有如下几种方法:

    方法 1:

    [arm@localhost gcc]#arm­linux­gcc ­c h1.c [arm@localhost gcc]#arm­linux­gcc ­c h2.c

    [arm@localhost gcc]#arm­linux­gcc ­o hello hello.c h1.o h2.o

    方法 2:

    [arm@localhost gcc]#arm­linux­gcc ­c h1.c h2.c [arm@localhost gcc]#arm­linux­gcc ­o hello hello.c h1.o h2.o 方法 3:

    [arm@localhost gcc]#arm­linux­gcc ­c ­o h1.o h1.c

    [arm@localhost gcc]#arm­linux­gcc ­c ­o h1.o h1.c [arm@localhost gcc]#arm­linux­gcc ­o hello hello.c h1.o h2.o 方法 4:

    [arm@localhost gcc]#arm­linux­gcc ­o hello hello.c h1.c h2.c

    ­c: 只编译不连接。

    ­o: 编译且连接。

    2. 产生一个预处理文件 当要看一个宏在源文件中产生的结果时,比较合适。

    [arm@localhost gcc]#arm­linux­gcc ­E h1.i h1.c

    ­E: 产生一个预处理文件.

    3. 产生一个动态库

    动态库是在运行时需要的库。

    [arm@localhost gcc]#arm­linux­gcc ­c ­fpic h1.c h2.c [arm@localhost gcc]#arm­linux­gcc ­shared h1.o h2.o ­o hello.so [arm@localhost gcc]#arm­linux­gcc ­o hello hello.c hello.so

    把 hello.so 拷贝到目标板的/lib 目录下,把可执行文件拷贝目标板的/tmp 目录下,在目标板上运行 hello.

    #/tmp/hello

    或把 hello.so 和 hello 一起拷贝到/tmp 目标下,并设置 LD_LIBRARY_PATH 环境变量

    #export LD_LIBRARY_PATH =/tmp:$LD_LIBRARY_PATH

    #/tmp/hello

  • 相关阅读:
    java类加载全过程
    pyAggr3g470r 3.6 发布,新闻聚合器
    fourinone分布式协调设计解析
    修改openJDK7的javac,使得java支持单引号字符串
    SabreDAV 1.8.0 发布,集成 WebDAV 系统
    openSUSE 12.3 里程碑 1 发布
    GroupOffice 4.0.123 发布
    nagios总结与基本配置模板
    Zorin OS 6.1 发布,基于Ubuntu的Linux
    Ehcache 2.6.2 发布,Java 缓存框架
  • 原文地址:https://www.cnblogs.com/fanweisheng/p/11105582.html
Copyright © 2011-2022 走看看