HelloWorld.c

既然是从头开始学,那就从经典的HelloWorld开始吧!
先在桌面上创建HelloWorld.c文件,再编写代码,写完后保存

//C代码
#include <stdio.h>

int main(void){
    printf("Hello World!\n");
    return 0;
}

打开命令行窗口,输入命令后回车(输入命令前将当前目录切换到桌面上:$ cd Desktop)

gcc HelloWorld.c

这时你会发现你的桌面中多了一个a.out文件
这个a.out文件是你运行上面命令后编译产生的可执行文件,这时再执行命令

./a.out

这时命令行窗口就打印出HelloWorld!简单的入门程序就执行完毕了!
编译文件时可控制输出文件名

gcc HellloWorld.c -o HelloWorld

桌面上就会出现一个HelloWorld文件之后执行命令

./HelloWorld

以下是对用户提供的 Makefile 进行的检查与优化,确保其符合语法规范、逻辑正确,并具有良好的可维护性。 ### Makefile 问题分析 原始 Makefile 内容如下: ```makefile helloworld:helloworld.o; gcc helloworld.o -o helloworld; helloworld.o:helloworld.c; gcc -c helloworld.c; clean; rm *.o; rm helloworld ``` 该内容存在以下问题: 1. **命令行未使用 Tab 缩进** Makefile 要求命令必须以 Tab 字符开头,而不是空格或分号连接多个命令。使用分号会破坏 Makefile 的结构,导致执行顺序混乱或报错。 2. **目标和依赖之间缺少换行** 每个目标及其命令应单独成行,命令部分应换行并以 Tab 开头。 3. **clean 目标没有依赖** `clean` 应该是一个伪目标(phony target),避免与同名文件冲突。 4. **变量未使用,缺乏可维护性** 可以通过变量定义源文件、目标文件和编译器,提升代码复用性和可读性。 5. **编译过程未分离,难以扩展** 将编译和链接分开,便于后续扩展多个源文件或添加调试选项。 ### 优化后的 Makefile ```makefile CC = gcc CFLAGS = -Wall -Wextra -g SRC = helloworld.c OBJ = helloworld.o TARGET = helloworld all: $(TARGET) $(TARGET): $(OBJ) $(CC) $(CFLAGS) $(OBJ) -o $(TARGET) $(OBJ): $(SRC) $(CC) $(CFLAGS) -c $(SRC) clean: rm -f $(OBJ) $(TARGET) ``` ### 优化说明 - **使用变量定义编译器和参数** `CC` 定义为 `gcc`,`CFLAGS` 包含警告和调试选项,提升代码健壮性[^3]。 - **目标 `all` 作为默认入口** 默认执行 `make` 时构建 `$(TARGET)`,即最终的可执行程序。 - **将编译和链接分开** 分别定义 `$(OBJ)` 和 `$(TARGET)` 的构建规则,便于扩展多个源文件。 - **`clean` 设置为伪目标** 使用 `rm -f` 避免删除不存在的文件报错,并添加 `-f` 提升安全性。 - **命令行前使用 Tab** 所有命令行前使用 Tab 字符,确保 Makefile 语法正确[^2]。 ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值