欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

shell 通過makefile傳參給c語言的實現(xiàn)示例

 更新時間:2023年03月22日 16:58:15   作者:肘子君  
本文主要介紹了shell 通過makefile傳參給c語言的實現(xiàn)示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

最近學習到的傳參過程,感覺很實用,稍加拓展可以實現(xiàn)一些有用的功能。
建立測試用例
建立一個文件夾,命名: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
#功能函數(shù),用來為inputinfo賦值,這段代碼測試時也可以寫在main中
function input_zgf_info()
{
	local lINFO="zhaoguanfeng666"
	inputinfo="ZGF_TEST_INFO=${lINFO}"
}
#main中為make傳遞ZGF_TEST_INFO參數(shù)的值
function main()
{
	echo "$0"
	input_zgf_info
	echo "input_zgf_info"
	#inputinfo不加括號和加大括號均可以實現(xiàn)變量替換
	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文件變?yōu)?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 "刪除完成"

代碼總體實現(xiàn)流程:

首先是在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中被實現(xiàn)的,通過腳本中的函數(shù)function input_zgf_info(),為ZGF_TEST_INFO賦值為zhaoguanfeng666,并在腳本的main函數(shù)中,執(zhí)行make時,將ZGF_TEST_INFO作為make的輸入?yún)?shù)傳遞給makefile,從而實現(xiàn)了為makefile中的ZGF_TEST_INFO變量賦值。最終ZGF_TEST_INFO的值被傳遞進了C中。

編譯運行結(jié)果:

在這里插入圖片描述

從編譯結(jié)果可以看出,ZGF_TEST_INFO已經(jīng)被順利傳遞進了makefile,如果傳遞失敗的話,第一個紅框中的ZGF_TEST_INFO后面是沒有值的。第二個紅框表示ZGF_TEST_INFO變量在腳本中被賦值成功。

在這里插入圖片描述

c文件運行結(jié)果,成功打印出傳遞進來的宏的值。

到此這篇關(guān)于shell 通過makefile傳參給c語言的實現(xiàn)示例的文章就介紹到這了,更多相關(guān)shell 通過makefile傳參給c內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評論