• 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

  • 相关阅读:
    Web 组件是什么
    amazeui学习笔记二(进阶开发2)--Web组件简介Web Component
    .less为后缀的文件是什么
    amazeui学习笔记二(进阶开发1)--项目结构structure
    html中的瀑布流是什么
    HTML5 API 是什么
    epoll使用具体解释(精髓)
    DataTable.AcceptChanges方法有何用处
    cer, pfx 创建,而且读取公钥/密钥,加解密 (C#程序实现)
    超赞的.NET办公软件库
  • 原文地址:https://www.cnblogs.com/fanweisheng/p/11105582.html
Copyright © 2020-2023  润新知