編譯和調(diào)試的區(qū)別
編譯和調(diào)試的區(qū)別
編譯和調(diào)試都是寫(xiě)程序的重要環(huán)節(jié)。它們兩者有什么區(qū)別呢?下面,學(xué)習(xí)啦小編跟大家分享一下編譯和調(diào)試的區(qū)別。
1.編譯和調(diào)試的區(qū)別
編譯是編譯器在你程序沒(méi)有運(yùn)行的時(shí)候幫你檢查錯(cuò)誤。
調(diào)試是你用調(diào)試器在程序運(yùn)行以后,根據(jù)運(yùn)行狀況來(lái)檢查錯(cuò)誤。
這兩者的不可逆的,首先得編譯通過(guò),你才能調(diào)試啊,編譯正確后,會(huì)生成exe文件,IDE中啟動(dòng)程序,可以進(jìn)行調(diào)試。
編譯是把源代碼變成二進(jìn)制obj的過(guò)程(鏈接后成為可執(zhí)行文件),當(dāng)然會(huì)先幫你檢查有無(wú)簡(jiǎn)單的語(yǔ)法問(wèn)題,要不編譯器人家不認(rèn)識(shí),你自己說(shuō)的有無(wú)邏輯就和編譯器無(wú)關(guān)了。
調(diào)試首先需要生成二進(jìn)制代碼,所以需要首先進(jìn)行編譯和鏈接,然后到斷點(diǎn)后,調(diào)試器會(huì)幫你加int 3中斷,就停住了。
編譯關(guān)注語(yǔ)法錯(cuò)誤,調(diào)試關(guān)注邏輯錯(cuò)誤。也就是說(shuō)編譯關(guān)注的是syntax(語(yǔ)法)方面的問(wèn)題,調(diào)式關(guān)注的是semantics(語(yǔ)義)方面的問(wèn)題。
2.編譯詞法分析
詞法分析的任務(wù)是對(duì)由字符組成的單詞進(jìn)行處理,從左至右逐個(gè)字符地對(duì)源程序進(jìn)行掃描,產(chǎn)生一個(gè)個(gè)的單詞符號(hào),把作為字符串的源程序改造成為單詞符號(hào)串的中間程序。執(zhí)行詞法分析的程序稱(chēng)為詞法分析程序或掃描器。
源程序中的單詞符號(hào)經(jīng)掃描器分析,一般產(chǎn)生二元式:單詞種別;單詞自身的值。單詞種別通常用整數(shù)編碼,如果一個(gè)種別只含一個(gè)單詞符號(hào),那么對(duì)這個(gè)單詞符號(hào),種別編碼就完全代表它自身的值了。若一個(gè)種別含有許多個(gè)單詞符號(hào),那么,對(duì)于它的每個(gè)單詞符號(hào),除了給出種別編碼以外,還應(yīng)給出自身的值。
詞法分析器一般來(lái)說(shuō)有兩種方法構(gòu)造:手工構(gòu)造和自動(dòng)生成。手工構(gòu)造可使用狀態(tài)圖進(jìn)行工作,自動(dòng)生成使用確定的有限自動(dòng)機(jī)來(lái)實(shí)現(xiàn)。
3.編譯語(yǔ)法分析
編譯程序的語(yǔ)法分析器以單詞符號(hào)作為輸入,分析單詞符號(hào)串是否形成符合語(yǔ)法規(guī)則的語(yǔ)法單位,如表達(dá)式、賦值、循環(huán)等,最后看是否構(gòu)成一個(gè)符合要求的程序,按該語(yǔ)言使用的語(yǔ)法規(guī)則分析檢查每條語(yǔ)句是否有正確的邏輯結(jié)構(gòu),程序是最終的一個(gè)語(yǔ)法單位。編譯程序的語(yǔ)法規(guī)則可用上下文無(wú)關(guān)文法來(lái)刻畫(huà)。
語(yǔ)法分析的方法分為兩種:自上而下分析法和自下而上分析法。自上而下就是從文法的開(kāi)始符號(hào)出發(fā),向下推導(dǎo),推出句子。而自下而上分析法采用的是移進(jìn)歸約法,基本思想是:用一個(gè)寄存符號(hào)的先進(jìn)后出棧,把輸入符號(hào)一個(gè)一個(gè)地移進(jìn)棧里,當(dāng)棧頂形成某個(gè)產(chǎn)生式的一個(gè)候選式時(shí),即把棧頂?shù)倪@一部分歸約成該產(chǎn)生式的左鄰符號(hào)。
4.代碼優(yōu)化
代碼優(yōu)化是指對(duì)程序進(jìn)行多種等價(jià)變換,使得從變換后的程序出發(fā),能生成更有效的目標(biāo)代碼。所謂等價(jià),是指不改變程序的運(yùn)行結(jié)果。所謂有效,主要指目標(biāo)代碼運(yùn)行時(shí)間較短,以及占用的存儲(chǔ)空間較小。這種變換稱(chēng)為優(yōu)化。
有兩類(lèi)優(yōu)化:一類(lèi)是對(duì)語(yǔ)法分析后的中間代碼進(jìn)行優(yōu)化,它不依賴(lài)于具體的計(jì)算機(jī);另一類(lèi)是在生成目標(biāo)代碼時(shí)進(jìn)行的,它在很大程度上依賴(lài)于具體的計(jì)算機(jī)。對(duì)于前一類(lèi)優(yōu)化,根據(jù)它所涉及的程序范圍可分為局部?jī)?yōu)化、循環(huán)優(yōu)化和全局優(yōu)化三個(gè)不同的級(jí)別。
4.編譯出錯(cuò)處理
如果編譯過(guò)程中發(fā)現(xiàn)源程序有錯(cuò)誤,編譯程序應(yīng)報(bào)告錯(cuò)誤的性質(zhì)和錯(cuò)誤的發(fā)生的地點(diǎn),并且將錯(cuò)誤所造成的影響限制在盡可能小的范圍內(nèi),使得源程序的其余部分能繼續(xù)被編譯下去,有些編譯程序還能自動(dòng)糾正錯(cuò)誤,這些工作由錯(cuò)誤處理程序完成。
需要注意的是,一般上編譯器只做語(yǔ)法檢查和最簡(jiǎn)單的語(yǔ)義檢查,而不檢查程序的邏輯。邏輯錯(cuò)誤要通過(guò)調(diào)試。
小編總結(jié):
看完了上面的比較,你現(xiàn)在還能區(qū)別編譯與調(diào)試嗎?其實(shí),只要記住這句話:“編譯關(guān)注語(yǔ)法錯(cuò)誤,調(diào)試關(guān)注邏輯錯(cuò)誤,先有編譯,后有調(diào)試”,就不會(huì)忘了兩者的區(qū)別了。