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)文章
CCKiller:Linux輕量級CC攻擊防御工具,秒級檢查、自動拉黑和釋放
這篇文章主要介紹了CCKiller:Linux輕量級CC攻擊防御工具,秒級檢查、自動拉黑和釋放,需要的朋友可以參考下2016-02-02shell腳本實現(xiàn)公司項目部署交付環(huán)境預檢查的思路
這篇文章主要介紹了shell腳本實現(xiàn)公司項目部署交付環(huán)境預檢查的思路,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-09-09Shell腳本判斷Linux系統(tǒng)是32位還是64位的幾種方法分享
這篇文章主要介紹了Shell腳本判斷Linux系統(tǒng)是32位還是64位的幾種方法分享,本文共給出了4種方法實現(xiàn)系統(tǒng)位數(shù)在判斷,需要的朋友可以參考下2014-12-12Shell腳本實現(xiàn)監(jiān)控kingate并自動啟動
這篇文章主要介紹了Shell腳本實現(xiàn)監(jiān)控kingate并自動啟動,本文直接給出實現(xiàn)代碼,需要的朋友可以參考下2014-12-12