1. 編譯是在程序運行的時候還是在程序開發的時候。
編譯在程序運行之前,用於生成可執行文件。
但注意有部分解釋執行的語言不需要編譯
2. c語言為何需要編譯和連接才能運行
的文件(也稱為源代碼)而已,需要經過1定的處理才能轉換成機器上可運行的可履行文件。
我們將對C語言的這類處理進程稱為編譯與鏈接。
3. java語言在被設計的時候為什麼會加上 編譯 這一步
java語言在被設計的時候為什麼會加上編譯這一步,其實主要的考慮因素是性能,靜態語言的執行效率比動態語言要高得多。所以需要編譯。
4. 運行java程序時,為什麼要先編譯再運行,編譯運行一起進行不行嗎
java講究的是 一次編譯 處處運行,也就是提高了程序的一致性。java的程序之所在不同的操作系統上的運行結果是一樣的,是因為java虛擬機。
所以要運行java都要裝一個叫jdk的東西,裡面有java的虛擬機。這個虛擬機就是來解釋我們寫的代碼。通過這個虛擬機,就實現了代碼的移植。
我們寫好的程序,通過虛擬機,編譯成class文件,然後在運行。但是我們只需要編譯一次即可。
5. 為什麼高級程序語言需要編譯程序
計算機語言是人與計算機之間交流的媒介,其種類非常多,但大體上分為機器語言、匯編語言、高級語言三大類。
計算機不能直接理解高級語言,只能直接理解機器語言,因此必須將高級語言翻譯成機器語言,翻譯的過程分為兩種,一種是解釋,一種是編譯。兩種方式的區別在於翻譯的時間,編譯是在程序運行之前,需要一個專門的過程,將程序編譯成為機器語言的文件,比如EXE文件,以後要運行的話就不用再重新編譯了,直接使用之前的編譯結果就行了,因為只翻譯一次,運行時不需要再翻譯,所以編譯型語言的程序執行效率高。
解釋性語言則不同,解釋性語言不需要編譯,其程序在運行時才翻譯,每個語句都是執行時才翻譯。這樣解釋性語言每執行一次就要翻譯一次,其執行效率則相對較低。
另外,編譯型語言以二進制形式保存,源代碼不可見;解釋性語言以代碼形式保存。
6. 為什麼每次運行程序之前,VS都要先編譯的解決方法
這是因為程序運行過快的原因,程序運行結果就會顯示後立即消失。解決方法:加一個輸入函數。
7. 為什麼需要匯編程序,編譯程序或解釋程序
編譯程序是必須的,用戶用高級語言或匯編語言編寫的程序,計算機是不能執行的,必須要由編譯程序翻譯成機器碼程序,計算機才能識別和執行。否則,人們寫的各種程序都是無用的。
匯編程序並不是必須的,只是有些場合要用匯編語言寫程序,或部分人還用匯編語言寫程序,再由匯編程序(其實也是編譯程序)來翻譯。但現在,可以不用匯編語言寫程序了。
至於解釋程序,現在幾乎不用了。這是在早期的計算機上,用高級語言寫的程序,並不用編譯成機器碼,而是可以直接運行高級語言程序,然後由解釋程序逐條進行翻譯,一邊翻譯一邊執行。這樣的執行程度是很慢的。
8. 為什麼要對C源程序進行編譯、鏈接
首先要說的是C語言屬於高級語言,不能直接被計算機識別而執行,所以需要一些操作來轉化。。一開始是編譯預處理,對宏,包含指令,編譯指令等進行處理,然後是詞法語法分析,將源代碼翻譯成中間代碼(一般是匯編),接著優化代碼,,然後將中間代碼翻譯成機器語言(目標文件),機器語言是計算機的基層語言,能被計算機直接識別。。接著鏈接目標文件,生成可以執行文件。。。大概就是這樣。。詳細的LZ可看這個總結。。http://bbs.zdnet.com.cn/thread-1614727-1-1.html
9. 為什麼c/c++開源庫使用前需要編譯
這樣可以運行,但有兩個問題:
每個新程序要使用開源庫中的api,都需要重新編譯部分甚至整個開源庫源代碼,這會浪費大量的時間;
如果有多個程序同時使用同一個庫,每個程序都將生成一份這個庫的二進制文件,這會浪費大量的磁碟空間;當這些程序同時運行時,每個程序的內存中都會裝載一份庫的二進制代碼,這會浪費大量的內存空間。
因此,直接將第三方庫的源代碼包含到當前程序的代碼中編譯是效率非常低下的方式,實際中除非極特殊情況,不會考慮使用這種方式,而是將開源庫源代碼編譯成二進制的動態鏈接庫,其他程序要使用其中的API時,只需要指定動態鏈接庫的入口點,程序運行時載入動態鏈接庫 並找到其中的函數入口點就可以調用開源庫API。並且,當有多個程序調用此動態鏈接庫時,只會佔用一份內存空間。
10. 調試時,對C語言源程序進行編譯的目的是什麼
建議看看編譯原理。
我們的PC機,只能認識機器碼,不認識C語言的。編譯,就是讓C語言變得讓機器認識。
編譯過程,一般是:
C語言-->匯編語言-->2進制文件。
2進制文件由操作系統裝載,並調度運行。