㈠ C語言源程序到運行程序經過哪幾個步驟
1、預處理
在這一階段,源碼中的所有預處理語句得到處理,例如:#include語句所包含的文件內容替換掉語句本身,所有已定義的宏被展開。
根據#ifdef,#if等語句的條件是否成立取捨相應的部分,預處理之後源碼中不再包含任何預處理語句。
GCC預處理階段可以生成.i的文件,通過選項-E可以使編譯器在預處理結束時就停止編譯。例如:gcc -E -o hello.i hello.c
2、編譯
這一階段,編譯器對源碼進行詞法分析、語法分析、優化等操作,最後生成匯編代碼。這是整個過程中最重要的一步,因此也常把整個過程稱為編譯。
可以通過選項-S使GCC在進行完編譯後停止,生成.s的匯編程序。例如:gcc -S -o hello.s hello.c
3、匯編
這一階段使用匯編器對匯編代碼進行處理,生成機器語言代碼,保存在後綴為.o的目標文件中。
當程序由多個代碼文件構成時,每個文件都要先完成匯編工作,生成.o目標文件後,才能進入下一步的鏈接工作。
目標文件已經是最終程序的某一部分了,只是在鏈接之前還不能執行。可以通過-c選項生成目標文件:gcc -c -o hello.o hello.c
4、鏈接
經過匯編以後的機器代碼還不能直接運行。為了使操作系統能夠正確載入可執行文件,文件中必須包含固定格式的信息頭,還必須與系統提供的啟動代碼鏈接起來才能正常運行,這些工作都是由鏈接器來完成的。gcc -o hello hello.c
5、運行:執行.EXE文件,得到運行結果。
㈡ Linux中源碼編譯安裝程序包括哪些基本步驟
第一步:創建編譯腳本
進入到源碼目錄 執行 ./configure --prefix=/.../.....(--prefix=後面是想要安裝到的目錄)
第二部:編譯
執行 make
第三部:安裝
執行 make install
當然上面這幾部都是最基本的步驟,如果想優化編譯,要在./configure 後面加參數,或者configure之後手動修改Makefile文件 如O2(優化等級) FLAGS 等編譯參數的修改。
--------------------------------------------------------------------------------------------------------------
以上都是源碼包的編譯
如果是自己寫的C代碼 直接 用gcc編譯即可。
例如 編譯test.c
執行 gcc -o test test.c即可將test.c編譯為可執行的文件 test
自己打出來的 要採納啊!
㈢ 綆榪癮ndroid婧愪唬鐮佺殑緙栬瘧榪囩▼
緙栬瘧android婧愪唬鐮佹槸涓涓鐩稿瑰嶆潅鐨勮繃紼嬶紝娑夊強澶氫釜姝ラゅ拰宸ュ叿銆備笅闈㈡垜灝嗛栧厛綆瑕佹傛嫭緙栬瘧榪囩▼錛岀劧鍚庤︾粏瑙i噴姣忎釜姝ラゃ
綆瑕
Android婧愪唬鐮佺殑緙栬瘧榪囩▼涓昏佸寘鎷鑾峰彇婧愪唬鐮併佽劇疆緙栬瘧鐜澧冦侀夋嫨緙栬瘧鐩鏍囥佸紑濮嬬紪璇戜互鍙婂勭悊緙栬瘧緇撴灉絳夋ラゃ
1. 鑾峰彇婧愪唬鐮侊細緙栬瘧Android婧愪唬鐮佺殑絎涓姝ユ槸浠庡畼鏂規笭閬撹幏鍙栨簮浠g爜銆傞氬父錛岃繖鍙浠ラ氳繃浣跨敤Git宸ュ叿浠嶢ndroid Open Source Project錛圓OSP錛夌殑瀹樻柟浠撳簱鍏嬮殕浠g爜鏉ュ畬鎴愩傚懡浠ょず渚嬶細`git clone https://android.googlesource.com/platform/manifest`銆
2. 璁劇疆緙栬瘧鐜澧冿細鍦ㄧ紪璇戜箣鍓嶏紝闇瑕侀厤緗鍚堥傜殑緙栬瘧鐜澧冦傝繖閫氬父娑夊強瀹夎呯壒瀹氱殑鎿嶄綔緋葷粺錛堝俇buntu鐨勬煇浜涚増鏈錛夛紝瀹夎呭繀瑕佺殑渚濊禆欏癸紙濡侸ava寮鍙戝伐鍏峰寘鍜孉ndroid Debug Bridge錛夛紝浠ュ強閰嶇疆鐗瑰畾鐨勭幆澧冨彉閲忕瓑銆
3. 閫夋嫨緙栬瘧鐩鏍囷細Android鏀鎸佸氱嶈懼囧拰閰嶇疆錛屽洜姝ょ紪璇戞椂闇瑕佹寚瀹氱洰鏍囥傝繖鍙浠ラ氳繃閫夋嫨鐗瑰畾鐨勮懼囬厤緗鏂囦歡錛堝傞拡瀵筆ixel鎵嬫満鐨刞aosp_arm64-eng`錛夋垨浣跨敤閫氱敤閰嶇疆鏉ュ畬鎴愩傞夋嫨鐩鏍囧悗錛岀紪璇戠郴緇熷皢鐭ラ亾闇瑕佹瀯寤哄摢浜涚粍浠跺拰鍙樼嶃
4. 寮濮嬬紪璇戱細璁劇疆濂界幆澧冨苟閫夋嫨浜嗙紪璇戠洰鏍囧悗錛屽氨鍙浠ュ紑濮嬬紪璇戣繃紼嬩簡銆傚湪婧愪唬鐮佺殑鏍圭洰褰曚笅錛屽彲浠ヤ嬌鐢ㄥ懡浠`make -jN`鏉ュ惎鍔ㄧ紪璇戱紝鍏朵腑`N`閫氬父璁劇疆涓虹郴緇熸牳蹇冩暟鐨1鍀2鍊嶏紝浠ュ苟琛屽勭悊緙栬瘧浠誨姟錛屽姞蹇緙栬瘧閫熷害銆傜紪璇戣繃紼嬩腑錛岀郴緇熷皢鏍規嵁Makefile鏂囦歡鍜屽叾浠栨瀯寤鴻剼鏈錛岃嚜鍔ㄤ笅杞芥墍闇鐨勯勬瀯寤轟簩榪涘埗鏂囦歡錛屽苟緙栬瘧婧愪唬鐮併
5. 澶勭悊緙栬瘧緇撴灉錛氱紪璇戝畬鎴愬悗錛屽皢鍦ㄨ緭鍑虹洰褰曪紙閫氬父鏄痐out/`鐩褰曪級涓鐢熸垚緙栬瘧緇撴灉銆傝繖鍖呮嫭鍙鐢ㄤ簬妯℃嫙鍣ㄧ殑緋葷粺闀滃儚銆佸彲鐢ㄤ簬瀹為檯璁懼囩殑OTA鍖呮垨瀹屾暣鐨勭郴緇熼暅鍍忕瓑銆傛牴鎹闇瑕侊紝鍙浠ヨ繘涓姝ュ勭悊榪欎簺杈撳嚭鏂囦歡錛屽傛墦鍖呫佺懼悕絳夈
鍦ㄦ暣涓緙栬瘧榪囩▼涓錛岃繕鍙鑳介亣鍒板悇縐嶄緷璧栭棶棰樺拰緙栬瘧閿欒錛岄渶瑕佹牴鎹閿欒淇℃伅榪涜岃皟璇曞拰瑙e喅銆傜敱浜嶢ndroid婧愪唬鐮佸簽澶т笖澶嶆潅錛屽畬鏁寸殑緙栬瘧鍙鑳介渶瑕佹暟灝忔椂鐢氳嚦鏇撮暱鏃墮棿錛屽洜姝よ愬績鍜屽悎閫傜殑紜浠墮厤緗涔熸槸鎴愬姛緙栬瘧鐨勯噸瑕佸洜緔犮
㈣ 簡述java程序的編輯編譯和運行過程
第一步(編譯): 創建完源文件之後,程序會先被編譯為.class文件。Java編譯一個類時,如果這個類所依賴的類還沒有被編譯,編譯器就會先編譯這個被依賴的類,然後引用,否則直接引用,這個有點象make。
如果java編譯器在指定目錄下找不到該類所其依賴的類的.class文件或者.java源文件的話,編譯器話報「cant find symbol」的錯誤。
第二步(運行):java類運行的過程大概可分為兩個過程:1、類的載入 2、類的執行。需要說明的是:JVM主要在程序第一次主動使用類的時候,才會去載入該類。也就是說,JVM並不是在一開始就把一個程序就所有的類都載入到內存中,而是到不得不用的時候才把它載入進來,而且只載入一次。
特別說明:java類中所有public和protected的實例方法都採用動態綁定機制,所有私有方法、靜態方法、構造器及初始化方法<clinit>都是採用靜態綁定機制。而使用動態綁定機制的時候會用到方法表,靜態綁定時並不會用到。
(4)簡述源碼包編譯的三個步驟擴展閱讀:
Java整個編譯以及運行的過程相當繁瑣,本文通過一個簡單的程序來簡單的說明整個流程。
Java代碼編譯:是由Java源碼編譯器來完成;
Java位元組碼的執行:是由JVM執行引擎來完成
Java程序從源文件創建到程序運行要經過兩大步驟:
1、源文件由編譯器編譯成位元組碼(ByteCode)
2、位元組碼由java虛擬機解釋運行。因為java程序既要編譯同時也要經過JVM的解釋運行,所以說Java被稱為半解釋語言( "semi-interpreted" language)。
㈤ 緙栬瘧紼嬪簭宸ヤ綔榪囩▼
緙栬瘧紼嬪簭鐨勫伐浣滆繃紼嬫秹鍙婃簮紼嬪簭鐨勫垎鏋愬拰鐩鏍囩▼搴忕殑鐢熸垚銆傞栧厛錛岀▼搴忎細榪涜屾簮浠g爜鐨勬鏌ワ紝灝嗗叾鍒嗚В涓哄熀鏈鎴愬垎錛屽傛爣璇嗙︺佺被鍨嬪拰榪愮畻絎︾瓑銆傚湪榪欎釜闃舵碉紝緙栬瘧鍣ㄤ細鏃呯己鍒涘窞閿寤虹﹀彿琛錛屽瓨鍌ㄦ簮紼嬪簭涓鐨勬爣璇嗙﹀強鍏跺睘鎬э紝濡傚彉閲忋佹暟緇勩佺粨鏋勭瓑鐨勭嶇被鍜岀被鍨嬶紝浠ュ強鐩鏍囩▼搴忔墍闇鐨勯濆栦俊鎮鍐岄晣宸с傚父鏁拌〃鍒欒板綍婧愮▼搴忎腑鐨勫父鏁板強鍏跺湪鐩鏍囩▼搴忎腑鐨勫瓨鍌ㄤ綅緗銆
鎺ヤ笅鏉ワ紝緙栬瘧紼嬪簭浼氬皢婧愪唬鐮佽漿鎹涓轟竴縐嶄腑闂磋璦褰㈠紡錛屽傛嘗鍏拌〃紺恆佷笁鍏冪粍鎴栧洓鍏冪粍錛屼互渚誇簬鍚庣畫鐨勫垎鏋愬拰緇煎悎鎿嶄綔銆傝繖涓闃舵典嬌鐢ㄧ殑鏁版嵁緇撴瀯涓昏佸寘鎷絎﹀彿琛ㄣ佸父鏁拌〃鍜屼腑闂磋璦紼嬪簭銆
鍒嗘瀽闃舵靛垎涓鴻瘝娉曞垎鏋愩佽娉曞垎鏋愬拰璇涔夊垎鏋愪笁涓姝ラゃ傝瘝娉曞垎鏋愬櫒錛屾垨縐頒負鎵鎻忓櫒錛岃礋璐h瘑鍒婧愪唬鐮佷腑鐨勫崟璇嶏紝鏋勯犵﹀彿琛ㄥ拰甯告暟琛錛屽苟灝嗘簮浠g爜杞鎹涓虹紪璇戝櫒鑳藉勭悊鐨勫唴閮ㄥ艦寮忋傝娉曞垎鏋愬櫒鏄鍏抽敭鐜鑺傦紝瀹冩牴鎹璇璦瑙勫垯媯鏌ヤ唬鐮佺殑璇娉曟g『鎬э紝鐢熸垚涓闂磋璦鐨勭粨鏋勩傝涔夊垎鏋愬櫒鍒欑『淇濈▼搴忕殑璇涔夋g『錛岄獙璇佹爣璇嗙﹀拰甯告暟鐨勪嬌鐢錛屽苟鏀墮泦鐩稿叧淇℃伅錛岃繘琛岀浉搴旂殑璇涔夊勭悊銆
鎬葷殑鏉ヨ達紝緙栬瘧紼嬪簭閫氳繃涓緋誨垪澶嶆潅鐨勮繃紼嬶紝浠庢簮紼嬪簭鍑哄彂錛岄氳繃絎﹀彿琛ㄥ拰涓闂磋璦錛屾渶緇堢敓鎴愮洰鏍囩▼搴忥紝紜淇濈▼搴忕殑姝g『鎬у拰鍙鎵ц屾с
㈥ 簡述將源程序編譯成可執行程序的過程
一個源程序到一個可執行程序的過程:預編譯、編譯、匯編、鏈接。其中,編譯是主要部分,其中又分為六個部分:詞法分析、語法分析、語義分析、中間代碼生成、目標代碼生成和優化。
預編譯:主要處理源代碼文件中的以「#」開頭的預編譯指令。處理規則如下:
1、刪除所有的#define,展開所有的宏定義。
2、處理所有的條件預編譯指令,如「#if」、「#endif」、「#ifdef」、「#elif」和「#else」。
3、處理「#include」預編譯指令,將文件內容替換到它的位置,這個過程是遞歸進行的,文件中包含其他文件。
4、刪除所有的注釋,「//」和「/**/」。
5、保留所有的#pragma 編譯器指令,編譯器需要用到他們,如:#pragma once 是為了防止有文件被重復引用。
6、添加行號和文件標識,便於編譯時編譯器產生調試用的行號信息,和編譯時產生編譯錯誤或警告是能夠顯示行號。
(6)簡述源碼包編譯的三個步驟擴展閱讀:
編譯過程中語法分析器只是完成了對表達式語法層面的分析,語義分析器則對表達式是否有意義進行判斷,其分析的語義是靜態語義——在編譯期能分期的語義,相對應的動態語義是在運行期才能確定的語義。
其中,靜態語義通常包括:聲明和類型的匹配,類型的轉換,那麼語義分析就會對這些方面進行檢查,例如將一個int型賦值給int*型時,語義分析程序會發現這個類型不匹配,編譯器就會報錯。