最近学习到的传参过程,感觉很实用,稍加拓展可以实现一些有用的功能。
建立测试用例
建立一个文件夹,命名:zgftest
zgftest中包含的文件:makefile、mk.sh、rules.make、zgftest.c

以下分别是每个文件下的测试代码:

rules.make

ZGF_INFO    = -DZGF_TEST_INFO=\"$(ZGF_TEST_INFO)\"
GLOBAL_FLAG = $(ZGF_INFO)

mk.sh

#!/bin/sh
#功能函数,用来为inputinfo赋值,这段代码测试时也可以写在main中
function input_zgf_info()
{
	local lINFO="zhaoguanfeng666"
	inputinfo="ZGF_TEST_INFO=${lINFO}"
}
#main中为make传递ZGF_TEST_INFO参数的值
function main()
{
	echo "$0"
	input_zgf_info
	echo "input_zgf_info"
	#inputinfo不加括号和加大括号均可以实现变量替换
	make $inputinfo
	# make ${inputinfo}
	echo "$inputinfo"
}
main $@

zgftest.c

#include <stdio.h>
//简单测试ZGF_TEST_INFO宏是否传递成功
int main(int argc,char **argv)
{
	fprintf(stdout,"%s\n",ZGF_TEST_INFO);
	return 0;
}

makefile

#!/bin/bash
include ./rules.make

CC =gcc
VERSION :=1.1

VPATH =.

#获取所有的.c文件
SOURCE =$(foreach dir,$(VPATH),$(wildcard $(dir)/*.c))        
#将source中所有.c文件变为.o文件
OBJ = $(patsubst %.c, %.o, $(SOURCE))

GLOBAL_FLAG ?=ERROR
ifeq ($(GLOBAL_FLAG), ERROR)
	$(error make error! GLOBAL_FLAG not defined,"rules.make" must be wrong!!!)
endif

CFLAGS = $(GLOBAL_FLAG)

TARGET = main

$(TARGET) :$(OBJ)
	@echo "删除output文件夹"
	rm -rf ./output
	@echo "重建output文件夹"
	mkdir ./output
	@echo "开始链接......"
	$(CC) $(OBJ) -o ./output/$@.$(VERSION)
	@echo "编译链接完成"
	
%.o: %.c  
	@echo "开始编译......"
	#在编译时将CFLAGS所代表的变量传递给C
	$(CC) $(CFLAGS) -c $< -o $@ $(INCLUDES) 

.PHONY :clean
clean :
	@echo "开始删除......"
	rm -rf $(OBJ) ./output
	@echo "删除完成"

代码总体实现流程:

首先是在rules.make文件中,ZGF_INFO = -DZGF_TEST_INFO=*****这句代码就是通过make向C传递ZGF_TEST_INFO的意思,只是目前-DZGF_TEST_INFO=*****语句还只是赋值给了ZGF_INFO。然后将ZGF_INFO赋值给了GLOBAL_FLAG。

makefile中,包含了rules.make文件,并将GLOBAL_FLAG赋值给了CFLAGS,最终在$(CC) $(CFLAGS) -c $< -o $@ $(INCLUDES) 语句中,CFLAGS会展开,-DZGF_TEST_INFO=*****语句就会被放置到make后面,最终将ZGF_TEST_INFO变量作为宏传递给C。

但是实际上当前的ZGF_TEST_INFO变量里面是没有值的,因为还没有赋值,实际的赋值操作是在mk.sh中被实现的,通过脚本中的函数function input_zgf_info(),为ZGF_TEST_INFO赋值为zhaoguanfeng666,并在脚本的main函数中,执行make时,将ZGF_TEST_INFO作为make的输入参数传递给makefile,从而实现了为makefile中的ZGF_TEST_INFO变量赋值。最终ZGF_TEST_INFO的值被传递进了C中。

编译运行结果:

shell 通过makefile传参给c语言的实现示例

从编译结果可以看出,ZGF_TEST_INFO已经被顺利传递进了makefile,如果传递失败的话,第一个红框中的ZGF_TEST_INFO后面是没有值的。第二个红框表示ZGF_TEST_INFO变量在脚本中被赋值成功。

shell 通过makefile传参给c语言的实现示例

c文件运行结果,成功打印出传递进来的宏的值。

原文地址:https://blog.csdn.net/qq_16981075/article/details/119041438

相关文章: