真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

如何理解C++編譯器編譯功能

如何理解C++編譯器編譯功能,針對(duì)這個(gè)問題,這篇文章詳細(xì)介紹了相對(duì)應(yīng)的分析和解答,希望可以幫助更多想解決這個(gè)問題的小伙伴找到更簡單易行的方法。

專注于為中小企業(yè)提供成都網(wǎng)站設(shè)計(jì)、做網(wǎng)站服務(wù),電腦端+手機(jī)端+微信端的三站合一,更高效的管理,為中小企業(yè)麗水免費(fèi)做網(wǎng)站提供優(yōu)質(zhì)的服務(wù)。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動(dòng)了上千家企業(yè)的穩(wěn)健成長,幫助中小企業(yè)通過網(wǎng)站建設(shè)實(shí)現(xiàn)規(guī)模擴(kuò)充和轉(zhuǎn)變。

下面深度講解C++中的大規(guī)模C++編譯器,C++編譯器具有很強(qiáng)的復(fù)雜性,并且源程序的行數(shù)也是非常多,所以,在進(jìn)行C++編譯器編譯時(shí),一定要定一個(gè)計(jì)劃表,這樣才能更好的對(duì)C++編譯器進(jìn)行操作。

接著再跟著編譯運(yùn)行的主線來分析它的源程序。下面先看一下簡單的C++例子,如下:

#001 #include  #002   #003 int main(void)  #004 {  #005  int nTest1 = 1;  #006  int nTest2 = 2;  #007  int nTest3;  #008  int i;  #009    #010  nTest3 = nTest1 + nTest2;  #011  printf("nTest3 = %d\r\n",nTest3);  #012    #013  for (i = 0; i < 5; i++)  #014  {  #015         printf("%d\r\n",nTest3+i);  #016  }  #017    #018  printf(__TIME__" "__DATE__"\r\nhello world\n");  #019  return 0;  #020 }  #021

上面的程序就是用來說明編譯器工作的例子,它在***行里包含了頭文件stdio.h,由于后面調(diào)用printf函數(shù)輸出顯示到屏幕里。第二行空行,第三行是main函數(shù),它是C程序的入口函數(shù)。在main函數(shù)里,定義了幾個(gè)局部變量,分別第5,6,7,8行的變量。第10行作兩個(gè)變量nTest1和nTest2的加法,然后賦值給變量nTest3。第11行顯示變量nTest3的值,是用10進(jìn)制輸出顯示。在第13到16行是5次輸出nTest3+i值。在第18行里輸出編譯這個(gè)程序的時(shí)間和hello world的字符串。

C++編譯器的任務(wù),就是把上面的源程序變換到匯編代碼輸出,或者變成其它中間代碼輸出。在這里L(fēng)CC編譯器是輸出匯編代碼的,所以就不介紹其它的中間代碼輸出。那么LCC把上面的源程序變成什么樣的匯編輸出呢?下面就先把它的目標(biāo)代碼看一下,如下:

#001 [global $main]  #002 [section .text]  #003 $main:  #004 push ebx  #005 push esi  #006 push edi  #007 push ebp  #008 mov ebp, esp  #009 sub esp, 16  #010 mov dword [ebp + -12], 1  #011 mov dword [ebp + -16], 2  #012 mov edi, dword [ebp + -12]  #013 mov esi, dword [ebp + -16]  #014 lea edi, [esi + edi]  #015 mov dword [ebp + -8], edi  #016 mov edi, dword [ebp + -8]  #017 push dword edi  #018 lea edi, [$L2]  #019 push dword edi  #020 call $printf  #021 add esp, 8  #022 mov dword [ebp + -4], 0  #023 $L3:  #024 mov edi, dword [ebp + -8]  #025 mov esi, dword [ebp + -4]  #026 lea edi, [esi + edi]  #027 push dword edi  #028 lea edi, [$L7]  #029 push dword edi  #030 call $printf  #031 add esp, 8  #032 $L4:  #033 inc dword [ebp + -4]  #034 cmp dword [ebp + -4], 5  #035 jl near $L3  #036 lea edi, [$L8]  #037 push dword edi  #038 call $printf  #039 add esp, 4  #040 mov eax, 0  #041 $L1:  #042 mov esp, ebp  #043 pop ebp  #044 pop edi  #045 pop esi  #046 pop ebx  #047 ret  #048 [extern $printf]  #049 [section .data]  #050 times ($-$$) & 0 nop  #051 $L8:  #052 db '00:30:28 Apr 07 2007', 13, 10, 'hello world', 10, 0  #053 times ($-$$) & 0 nop  #054 $L7:  #055 db '%d', 13, 10, 0  #056 times ($-$$) & 0 nop  #057 $L2:  #058 db 'nTest3 = %d', 13, 10, 0  #059

LCC是可以生成很多目標(biāo)代碼的C++編譯器,在這里主要介紹生成X86的NASM匯編的代碼。上面的匯編代碼就是NASM的匯編格式,可以使用NASM編譯生成目標(biāo)文件,然后再用連接程序生成可執(zhí)行文件。如果不能看懂上面的NASM匯編,就需要去看NASM手冊(cè)了,這個(gè)手冊(cè)在網(wǎng)上有下載。如果想更深入理解匯編生成機(jī)器碼的過程,當(dāng)然也可以深入分析NASM的程序?qū)崿F(xiàn)。

從上面的C++和匯編也可以看出,匯編代碼比C++代碼要復(fù)雜,行數(shù)也比較多,還分了數(shù)據(jù)段和代碼段。所以使用C++編譯器是可以大大地提高生產(chǎn)效率的,并且更容易理解,這樣就容易降低軟件的成本,容易開發(fā)大規(guī)模的軟件工程。

關(guān)于如何理解C++編譯器編譯功能問題的解答就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道了解更多相關(guān)知識(shí)。


文章題目:如何理解C++編譯器編譯功能
文章網(wǎng)址:http://weahome.cn/article/pioeoj.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部