linux (CentOS 10)使用传统程序语言(C)进行编译---主,子程序连接:子程序的编译

1 主程序

cs 复制代码
root@localhost:~/testc/testlink3# cat thanks.c
#include <stdio.h>
// 声明子程序
void thanks_2(void);
int main(void)
{
        printf("Hello World\n");
        thanks_2();
}

2 子程序

cs 复制代码
root@localhost:~/testc/testlink3# cat thanks_2.c
#include <stdio.h>
void thanks_2(void)
{
        printf("Thank you!\n");
}

3

3.1 编译源文件

使用GCC分别编译每个源文件。这将为每个源文件生成一个目标文件(.o 文件)。

cs 复制代码
root@localhost:~/testc/testlink3# gcc -c thanks.c -o thanks.o
root@localhost:~/testc/testlink3# gcc -c thanks_2.c -o thanks_2.o

3.2 链接目标文件生成可执行文件

使用GCC链接这些目标文件,生成最终的可执行文件。

4 运行程序

bash 复制代码
root@localhost:~/testc/testlink3# gcc thanks.o thanks_2.o -o program
root@localhost:~/testc/testlink3# ./program 
Hello World
Thank you!

5 查看文件类型

bash 复制代码
root@localhost:~/testc/testfather_son# ls|xargs file -i 
program: application/x-executable; charset=binary
thx.c:   text/x-c; charset=iso-8859-1
thx.o:   application/x-object; charset=binary
thx_2.c: text/x-c; charset=us-ascii
thx_2.o: application/x-object; charset=binary

参考:

在Linux系统中使用GCC(GNU Compiler Collection)编译和链接C语言程序通常涉及以下几个步骤。我将通过一个简单的例子来说明如何将子程序(通常是多个源文件)和主程序链接在一起。

1. 创建源文件

首先,你需要创建两个C源文件:一个主程序文件和至少一个子程序文件。

main.c - 主程序文件

cs 复制代码
#include <stdio.h>
 
// 声明子程序
int add(int a, int b);
 
int main() {
    int result = add(5, 3);
    printf("Result: %d\n", result);
    return 0;
}

math_functions.c - 子程序文件

cs 复制代码
#include <stdio.h>
 
// 实现加法函数
int add(int a, int b) {
    return a + b;
}

2. 编译源文件

使用GCC分别编译每个源文件。这将为每个源文件生成一个目标文件(.o 文件)。

cs 复制代码
gcc -c main.c -o main.o
gcc -c math_functions.c -o math_functions.o

3. 链接目标文件生成可执行文件

使用GCC链接这些目标文件,生成最终的可执行文件。

cs 复制代码
gcc main.o math_functions.o -o program

4. 运行程序

现在你可以运行生成的可执行文件了。

bash 复制代码
./program

完整命令行示例

将上述步骤合并为一条命令行操作,如下所示:

bash 复制代码
gcc -o program main.c math_functions.c

这条命令会直接编译和链接所有指定的源文件,生成一个名为program的可执行文件。这种方法适用于源文件较少且不频繁修改的情况下。对于大型项目,建议分开编译和链接以加快编译速度并便于管理。

使用Makefile进行项目管理(推荐)

对于大型项目,使用Makefile可以更有效地管理编译和链接过程。以下是一个简单的Makefile示例:

bash 复制代码
CC=gcc           # 设置编译器为gcc
CFLAGS=-Wall     # 设置编译器选项,例如开启所有警告信息
TARGET=program   # 设置目标可执行文件名
SOURCES=main.c math_functions.c  # 设置源文件列表
OBJECTS=$(SOURCES:.c=.o)  # 将源文件名转换为对象文件名,例如 main.c -> main.o
 
all: $(TARGET)   # 默认目标为$(TARGET)(即program)
 
$(TARGET): $(OBJECTS)  # 目标$(TARGET)依赖于所有对象文件$(OBJECTS)
    $(CC) $(CFLAGS) $(OBJECTS) -o $(TARGET)  # 链接对象文件生成可执行文件
 
%.o: %.c  # 模式规则,用于编译源文件生成对象文件
    $(CC) $(CFLAGS) -c $< -o $@  # $< 表示依赖的第一个文件,$@ 表示目标文件(例如 main.o)
 
clean:  # 清理目标,删除所有对象文件和可执行文件
    rm -f $(OBJECTS) $(TARGET)  # 删除所有对象文件和可执行文件(如果有的话)

使用Makefile可以简化编译和清理过程,特别是在项目变得复杂时。你可以通过在终端中运行make命令来编译项目,或者使用make clean来清理构建产物。

相关推荐
安顾里23 分钟前
Linux命令-iostat
linux·运维·服务器
100编程朱老师1 小时前
面试:什么叫Linux多路复用 ?
linux·运维·服务器
miracletiger1 小时前
uv 新的包管理工具总结
linux·人工智能·python
enyp801 小时前
麒麟系统(基于Ubuntu)上使用Qt编译时遇到“type_traits文件未找到”的错误
linux·qt·ubuntu
struggle20252 小时前
LinuxAgent开源程序是一款智能运维助手,通过接入 DeepSeek API 实现对 Linux 终端的自然语言控制,帮助用户更高效地进行系统运维工作
linux·运维·服务器·人工智能·自动化·deepseek
无敌小茶3 小时前
Linux学习笔记之动静态库
linux·笔记
程序员JerrySUN4 小时前
驱动开发硬核特训 · Day 21(上篇) 抽象理解 Linux 子系统:内核工程师的视角
java·linux·驱动开发
雨声不在4 小时前
debian切换用户
linux·服务器·debian
不知名。。。。。。。。4 小时前
Linux—— 版本控制器Git
linux·运维·git
内网渗透5 小时前
OpenWrt 与 Docker:打造轻量级容器化应用平台技术分享
linux·docker·容器·openwrt·软路由