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来清理构建产物。

相关推荐
万象.3 小时前
Linux传输层TCP,UDP相关内容
linux·tcp/ip·udp
MaximusCoder3 小时前
等保测评命令——Centos Linux
linux·运维·经验分享·python·安全·centos
万象.3 小时前
Linux数据链路层通信原理及报文格式
linux·网络·网络协议
卷Java4 小时前
Linux服务器Docker部署OpenClaw:腾讯云/阿里云/VPS安装避坑指南
linux·运维·服务器
雅欣鱼子酱4 小时前
Type-C供电PD协议取电Sink芯片ECP5702,可二端头分开供电调整亮度,适用于LED灯带户外防水超亮灯条方案
c语言·开发语言
原来是猿6 小时前
Linux-【动静态库】
linux·运维·服务器
Yungoal6 小时前
B/S和C/S架构在服务端接收请求
c语言·开发语言·架构
九皇叔叔8 小时前
CentOS 7.5/RHEL 7.x 配置 YUM 源(阿里云镜像+本地源双方案)
linux·阿里云·centos
91刘仁德9 小时前
C++ 内存管理
android·c语言·数据结构·c++·经验分享·笔记·算法
chinesegf9 小时前
DNS 验证验证SSL证书
linux·服务器·网络