博客
关于我
GCC编译过程与链接过程
阅读量:564 次
发布时间:2019-03-09

本文共 3827 字,大约阅读时间需要 12 分钟。

编译与链接工具使用指南

编译 adalah bagian penting dalam pengembangan perangkat lunak, terutama dalam bahasa C/C++. Seperti yang disebutkan dalam dokumen di atas, proses dari UGuest begin with preprocessing, diikuti oleh kompile, assembly, dan link.

  • Preprocessing: Sebagai langkah pertama, compiler melakukan pengurutan input dan memasukkan file eksternal yang diperlukan. Ini menggunakan perintah seperti #include, #define, dan kondisi compile seperti #if, #ifdef, dan lainnya. Di dalam proses ini, perintah seperti arm-linux-cpp digunakan untuk mengelompokkan file ke dalam “.i” file yang siap diproses selanjutnya.

  • Compile: Setelah hasil preprocessing exited, compiler mengubah kode C/C++ menjadi kode assembler dengan menggunakan alat seperti ccl. Kode assembler disimpan dalam file “.s”.

  • Assembly: Kode assembler kemudian diubah ke dalam kode mesin yang dapat dijalankan dengan menggunakan alat seperti arm-linux-as. Ini menghasilkan file objek “.o” yang siap digunakan selanjutnya.

  • Link: Terakhir, linker menggabungkan file objek “.o” dengan library sistem dan file objek lainnya untuk membuat eksekutabel yang dapat dijalankan. Alat seperti arm-linux-ld digunakan untuk tujuan ini.


  • Gcc adalah alat populer untuk compile C/C++ kode. Berikut cara menggunkannya secara efektif:

    Ayncronous Options:

    • -o: Mengatur nama file output. Pastikan nama file tidak sama dengan input.
    • -E: Hanya melakukan preprocess without compile/assemble/link.
    • -S: Hanya compile without assemble/link.
    • -c: Compile dan assemble tanpa link.

    流程 Compile:

  • Input file biasanya disimpan di “.i” setelah preprocessing.
  • Setelah itu, compiler membuat “.s” file.
  • “.s” file kemudian di-compile menjadi “.o” file.
  • Akhirnya, “.o” file di-link ke eksekutabel.
  • utable Constraints:

    • Input file dan opsi yang digunakan mempengaruhi langkah mana yang dilakukan.
    • Jika tidak menggunakan opsi seperti -E, -S, atau -c, proses akhir adalah link.

    三种常用方法:

    1.直接 compile到 obj file:

    gcc -c -o hello.o hello.cgcc -o hello hello.o
    1. 分阶段 compile:
    2. gcc -E -o hello.i hello.cgcc -S -o hello.s hello.igcc -c -o hello.o hello.sgcc -o hello hello.o
      1. 使用常用快捷方式:
      2. gcc -c -o hello.o hello.cgcc -o hello hello.o

        makalah ini menunjukkan bahwa gcc default sudah melakukan preprocess sebelum compile. -c mengindikasikan compile dan assemble, sementara -o menggabungkan semua langkah ke dalam file eksekutabel.


        Linking Process:Linking adalah proses menggabungkan kode objek ke dalam eksekutabel. Ini melibatkan file objek local, library sistem, dan file objek pihak ketiga. Terutama untuk kode C/C++, beberapa file juga diperlukan seperti crt1.o, crt0.o, dan lainnya.

        Beberapa catatan tentang linking:

        • “-l” digunakan untuk menambahkan library seperti libc yang berisi fungsi seperti printf.
        • Menggunakan gcc -v akan menampilkan detail seluruh proses.
        • Untuk kode yang tidak memerlukan file standard, seperti boot loader atau kernel,使用-nostdlib option.

        Verbose Linking:

        gcc -v -o hello hello.o

        Output menunjukkan proses menggabungkan file objek dengan library sistem dan file crt.

        Dynamic vs Static Linking:

        • Dynamic linking menggunakan library yang di-load saat runtime, memungkinkan program lebih cepat tapi tergantung library presesensi.
        • Static linking memasukkan semua kode ke dalam program, memastikan ketergurusan tapi menghasilkan file yang lebih besar.

        Comparison:

        gcc -o hello_shared hello.cgcc -static -o hello_static hello.c

        Perbedaan utama antara hello_shared dan hello_static adalah ukuran file yang besar di Static linkage.


        Deskripsi lengkap mengenai proses compile dan linking C/C++ kode donna酷hati kena pahami sederhana kuatir.

        Sebagai seorang teknisi, proses ini adalah daily task yang perlu dipahami untuk mengoptimalkan kinerja leader-stage dan debugging dengan baik.

        Hasil optimasi ini akan memberikan pemahaman yang lebih baik tentang tools compiler, linkage, dan proses dasar dalam sistem operasi.

    转载地址:http://tpxpz.baihongyu.com/

    你可能感兴趣的文章
    Nginx配置实例-负载均衡实例:平均访问多台服务器
    查看>>
    NHibernate学习[1]
    查看>>
    NIFI1.21.0_Mysql到Mysql增量CDC同步中_日期类型_以及null数据同步处理补充---大数据之Nifi工作笔记0057
    查看>>
    NIFI1.21.0_NIFI和hadoop蹦了_200G集群磁盘又满了_Jps看不到进程了_Unable to write in /tmp. Aborting----大数据之Nifi工作笔记0052
    查看>>
    NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增删改数据分发及删除数据实时同步_通过分页解决变更记录过大问题_02----大数据之Nifi工作笔记0054
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置binlog_使用处理器抓取binlog数据_实际操作01---大数据之Nifi工作笔记0040
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
    查看>>
    NIFI同步MySql数据_到SqlServer_错误_驱动程序无法通过使用安全套接字层(SSL)加密与SQL Server_Navicat连接SqlServer---大数据之Nifi工作笔记0047
    查看>>
    Nifi同步过程中报错create_time字段找不到_实际目标表和源表中没有这个字段---大数据之Nifi工作笔记0066
    查看>>
    NIFI大数据进阶_离线同步MySql数据到HDFS_02_实际操作_splitjson处理器_puthdfs处理器_querydatabasetable处理器---大数据之Nifi工作笔记0030
    查看>>
    NIFI大数据进阶_连接与关系_设置数据流负载均衡_设置背压_设置展现弯曲_介绍以及实际操作---大数据之Nifi工作笔记0027
    查看>>
    NIFI数据库同步_多表_特定表同时同步_实际操作_MySqlToMysql_可推广到其他数据库_Postgresql_Hbase_SqlServer等----大数据之Nifi工作笔记0053
    查看>>
    NIFI汉化_替换logo_二次开发_Idea编译NIFI最新源码_详细过程记录_全解析_Maven编译NIFI避坑指南001---大数据之Nifi工作笔记0068
    查看>>
    NIFI集群_内存溢出_CPU占用100%修复_GC overhead limit exceeded_NIFI: out of memory error ---大数据之Nifi工作笔记0017
    查看>>
    NIFI集群_队列Queue中数据无法清空_清除队列数据报错_无法删除queue_解决_集群中机器交替重启删除---大数据之Nifi工作笔记0061
    查看>>
    NIH发布包含10600张CT图像数据库 为AI算法测试铺路
    查看>>
    Nim教程【十二】
    查看>>
    Nim游戏
    查看>>
    NIO ByteBuffer实现原理
    查看>>
    Nio ByteBuffer组件读写指针切换原理与常用方法
    查看>>