C語言的可移植性為什麼比彙編好,C語言可移植性強具體指什麼?

時間 2022-02-11 23:25:03

1樓:

組合語言,是處理器的指令集, 不同類的機器有不同的組合語言。所以不同的平臺,彙編是不可移植的。

c語言,採取的是編譯的方法,不同的處理器用不同的編譯器將其編譯為自己的指令集,從而達到移植的效果。不同機器的c原始碼(主要是函式庫中的函式名和其引數)差別不大,所以移植性好。因此c語言在源**上的可移植性是通過編譯器來實現的。

cpu 的指令集就是彙編要寫的**,cpu的指令集是有擴充套件的,不過要有相對應的軟體支援。至於你說的那麼多型別的處理器都可以用同樣的作業系統,的確如此,但是作業系統本身會識別出硬體的種類,會載入不同的驅動。基本指令不是很多,也不會經常有變動。

這下應該明白了吧!

2樓:匿名使用者

.... 彙編是與當前硬體架構緊密相關的,比如你給x86 cpu寫的彙編是無法用在 arm 上面的(指令、暫存器等全都不一樣)。即時是相同的架構,給32位cpu的彙編也無法用在16位的cpu上。

彙編完全不具備可移植性。

c語言本身是硬體架構無關的,所以它是可以移植的。不同平臺下的c編譯器能將通用的c語言轉換成對應平臺(x86,arm,等等)下的組合語言。(比如常用的編譯器gcc可以用 gcc -s a.

c 就是將a.c轉換成對應的彙編a.s)

c語言可移植性強具體指什麼?

3樓:匿名使用者

它是vb,vc語言的基礎型,可適用於多種語言

4樓:匿名使用者

1、可以在任何機器上執行

2、可以在任何作業系統上執行

可移植性並不是指直接複製程式就可以用了,

指的是不用改變**便可以在另一臺機器上編譯執行。

c語言和組合語言的區別是什麼?

5樓:哇哎西西

區別如下:

1、效率不同

彙編效率高,c語言效率比較低。

2、對硬體的可操控性不同

彙編對硬體的可操控性強,c語言硬體可操控性比較差。

3、**體積大小不同

彙編目標**體積小,c語言目標**體積大。

4、維護性不同

彙編不易維護,c語言容易維護。

5、可移植性不同

彙編可移植性很差,c語言可移植性很好。

6樓:哇哎西西

1、兩者編譯組成不同。組合語言是將由0、1組成的機器語言用具有簡單語義的英文**表示,而c語言不但將許多相關的機器指令合成為單條指令,並且去掉了與具體操作有關但與完成工作無關的細節,例如使用堆疊、暫存器等。

2、兩者被計算機識別的路徑不同。組合語言通常用於對硬體的直接操控。而且c語言所編制的程式不能直接被計算機識別,必須經過轉換才能被執行。

3、兩者用處不同。組合語言通常用在程式中最核心的、控制硬體的**,一方面是安全,另一方面提高執行速度。而c語言通常用在計算機外用功能上。

7樓:會飛的小兔子

1、操作複雜程度的不同

c語言,與組合語言相比,c語言在更加接近人的一般思維,因此在程式的設計過程中比較容易操作,此外在進行一些複雜的操作,運算時,c語言比彙編就要簡單很多,尤其是c語言中的豐富的函式庫,可以直接實現一些原本很複雜的功能,並且從**量來說任意一個c語言程式,通過反彙編之後變成組合語言程式,其長度都可能要增加好幾倍。

2、使用範圍的不同

c語言程式的事件將會只是編寫組合語言程式的幾分之一,從編寫程式的效率上來說c語言無疑更高,此外c語言是高階程式語言因此可移植性較好,不太受到到硬體裝置的限制。

在實現一個功能時,組合語言可以直接奔著目標去,而c語言則是給你提供了一種對於對於這種問題的普遍處理辦法,不具有針對性,因此會有許多多餘的在這個問題中不需要的過程,因此可能回事程式較大,執行較慢。相對與組合語言,c語言更加適合一些較大型專案的開發。

3、執行的速度和效率不同

程式沒有了組合語言計算機直接就無法執行,因為組合語言是基於計算機底層硬體的程式設計,通過它實現了對cpu,記憶體,硬碟以及外界裝置的直接操作,因為直接所以組合語言在程式的大小,執行的速度與效率方面幾乎無可比擬,但是也是因為直接,所以彙編程式難以移植,且完成相同的操作**量太大,在進行一些大的專案是,單獨使用匯編進行程式設計幾乎不可能實現。

8樓:雄鷹耀

c語言和組合語言的指令集、定址方式不同,相當於兩個機器各有各的操作方式。第一、

組合語言是低階語言,在編寫程式的時候會把根據不同的情況指定使用不同的定址方式,能夠對記憶體和cpu裡的通用暫存器直接操縱。不同的計算機系列會有不同的組合語言;而c語言是高階語言,可以實現跨平臺。編寫程式無需指定cpu的指令執**況,一段程式可以在不同體系結構的計算機上使用。

第二、c語言是一種比較高階的語言,作者可以直接命令計算機在不考慮硬體的情況下實現這種控制效果。組合語言是語言對硬體的直接控制,硬體間接實現了一定的控制效果。換句話說,組合語言更關注描述過程,而高階語言(比如c)更側重於描述結果。

第三、例如,組合語言中變數的賦值語句是mov a b,可以解釋為將暫存器中的值複製到b暫存器。在c語言中,b=a直接表示,這被解釋為使b=一個由柵極電路組成的晶片。有一個斷點,對應於計算機**中的二進位制1或0。

第四、如果您有一個直接的人機對話,您只能輸入包含0和1的**來進行通訊。這段**太長,很難記住。因此人們想出了一種相互協議的方式,人們可以很容易地閱讀特定的方式來表達特定的計算機**,然後翻譯成計算機可以直接讀取二進位制**的表示式。

這樣一組方便的表示式被稱為計算機語言。

9樓:匿名使用者

組合語言屬低階語言,而c語言是高階語言,所謂高階語言就是更容易被人們理解的語言,其實組合語言能實現的功能往往也能通過c語言來實現,甚至用c語言會更簡單,但是組合語言有一個優勢是其他任何語言所不具備的,這也是為什麼組合語言一直能在程式設計中佔有一席之地,那就是組合語言對硬體的直接控制,也就是說他能直接對硬體操作,可以繞過作業系統等等之類。雖然有的領域其他程式設計也能實現,但是在很多地方往往是組合語言能更加簡單,更加完美的完成。而且學好了組合語言你就能對cpu是怎麼工作的有了清晰的認識,所以學計算機專業的一般都會學組合語言。

10樓:啦啦啦額

組合語言與c語言的區別:

1、在組合語言中,為一個處理器編寫的程式不能在另一種型別的處理器上執行。在c語言程式中,程式獨立於處理器型別執行。

2、組合語言**的效能和準確性優於c**。

3、c語言必須提供額外的指令來在計算機上執行**。

4、組合語言**比c**難以理解和除錯。

5、 一個或兩個c語言語句擴充套件為許多組合語言**。

6、組合語言可以比c別更好地進行通訊某些型別的硬體操作只能通過組合語言執行。

7、在組合語言中,我們可以直接讀取實體地址上的指標,這在c別是不可能的。

8、在組合語言中使用位更容易。

9、彙編程式用於在組合語言中轉換**,而編譯器用於在c編譯**。

10、c語言的可執行**大於組合語言**,因此執行時間較長。

11、由於長的可執行**,c程式的效率低於組合語言程式。

12、與彙編程式設計師相比,c語言程式設計師不需要知道處理器中的暫存器等 硬體細節。

13、最c的語言**首先自動轉換為彙編**。

11樓:匿名使用者

c語言是高階語言,可移植性較高,與裝置相關性較低。

組合語言是低階語言,可以移植性較低,與cpu具有極強的相關性。

12樓:匿名使用者

組合語言是用語言直接控制硬體,由硬體間接達到某種控制效果。而c語言是一種比較高階的語言,編寫者可以不用去考慮硬體而直接去命令計算機達到這種控制效果。換而言之,組合語言對描述過程更注重,c語言之類的高階語言更注重描述結果。

例如組合語言中變數的賦值語句為 mov a b 可以解釋為將a暫存器中的值複製至b暫存器。而c語言中直接表示為 b=a,解釋為使b=a 晶片都是由閘電路構成。門有通有斷,對應在計算機**裡是二進位制的1或0。

如果直接進行人機對話,只能輸入由0和1組成的**才能交流。這樣的**太長,而且難記。所以人們想出一個辦法,相互約定,用人們易讀懂的特定表達方式去表達特定的計算機**,再將此表達方式翻譯成計算機能直接讀懂的二進位制**。

這樣的一套方便人們表達的表達方式被稱為計算機語言。

13樓:沙裡波特

語言又是怎麼回事?

------

語言是怎麼回事,你都不懂?

那麼,你還是別來瞎問了。

大家都告訴你「c和彙編的區別」了,你肯定還是弄不懂。

14樓:柱子小柱子

1.組合語言實質上是機器語言的助記符。 cpu只能執行它所支援的指令集,而這些指令集當中的每條指令都是一些二進位制數的序列,也就是「0」和「1」的有序組合;「0」和「1」的組合不便於程式設計師的記憶因此有了「mov a 0x40」等這樣的助記符。

2.c語言編寫完程式後,需要通過編譯器將c語言編譯成與相應cpu指令集對應的機器語言。組合語言與機器語言是一一對應的。

c語言的語法是固定的,c語言編寫的程式要編譯成cpu能讀懂的機器語言指令沒辦法一一對應,因此需要有編譯規則了,所以執行效率低一些。

c語言是一門通用計算機程式語言,應用廣泛。c語言的設計目標是提供一種能以簡易的方式編譯、處理低階儲存器、產生少量的機器碼以及不需要任何執行環境支援便能執行的程式語言。

儘管c語言提供了許多低階處理的功能,但仍然保持著良好跨平臺的特性,以一個標準規格寫出的c語言程式可在許多電腦平臺上進行編譯,甚至包含一些嵌入式處理器(微控制器或稱mcu)以及超級電腦等作業平臺。

組合語言是彙編指令集、偽指令集和使用它們規則的統稱,使用具有一定含義的符號為助憶符,用指令助憶符、符號地址等組成的符號指令稱為彙編格式指令。

組合語言是一門重要的程式設計語言。下面列舉了至少4本名叫《組合語言》的圖書和教材,並簡要介紹了高校計算機相關專業在開設「組合語言」課程方面的一些情況。

15樓:蓋辜苟

c語言和組合語言的區別在於他們之間優缺點幾乎是相反的。

c語言和組合語言的優缺點:以c來舉例

優點:c的執行效率高;

c可以實現硬體的直接訪問;

c**的移植性好;

缺點:c的**複用性差;

c的**維護性差;

c的擴充套件性差,即如果想增加新功能,需要修改較多的**;

c語言的可讀性差;

c語言是一門通用計算機程式語言,應用廣泛。c語言的設計目標是提供一種能以簡易的方式編譯、處理低階儲存器、產生少量的機器碼以及不需要任何執行環境支援便能執行的程式語言;儘管c語言提供了許多低階處理的功能,但仍然保持著良好跨平臺的特性,以一個標準規格寫出的c語言程式可在許多電腦平臺上進行編譯,甚至包含一些嵌入式處理器(微控制器或稱mcu)以及超級電腦等作業平臺。

組合語言:是一種用於電子計算機、微處理器、微控制器或其他可程式設計器件的低階語言,亦稱為符號語言。在組合語言中,用助記符(mnemonics)代替機器指令的操作碼,用地址符號(symbol)或標號(label)代替指令或運算元的地址。

在不同的裝置中,組合語言對應著不同的機器語言指令集,通過彙編過程轉換成機器指令。普遍地說,特定的組合語言和特定的機器語言指令集是一一對應的,不同平臺之間不可直接移植。

c和彙編的選擇:

若只有較簡單的邏輯操作、邏輯演算法、簡單運算,使用匯編會得到較為精準的**,但用c也同樣可以做到。

若摻有複雜運算、浮點運算、非線性方程等,彙編恐怕無能為力了(最起碼難度很大)。

微控制器種類繁多,各自的彙編語法大都不一樣,若僅使用匯編,可擴充性、可移植性都很差,用c就會好的多。

關於組合語言移植性的問題,關於組合語言中的LOOP指令

兄弟,你理解錯了,首先你要明白,組合語言是一種針對具體機器的低階語言,這裡說的不同機器一般來講是指cpu指令系統不相相容的兩種機器,比如常用的8086與51,dsp,arm,等等,他們的指令系統都不是通用的。自然移植到別的機器上不行,舉個例子來說吧,假如51,的p0埠可以用來點亮一盞燈,但是對808...

這道C語言的答案為什麼是這樣,看一道C語言程式答案,為什麼會這樣?

1 能整除形參x且不是偶數的各整數 是說求 各整數 這個 各整數 滿足兩個特徵 能整除形參x 不是偶數 這兩個特徵寫成 就是 x i 0 i 2 2 這些除數的個數通過形參n返回 是通過形參返回,而不是返回值返回。如果用return就 是函式的返回值。形參是n,兩條語句 n 0 和 n 即為將形參n...

c語言中!10的值為0,為什麼,c語言中a 1 0 的值是什麼

ch陳先生 計算機記憶體儲存的時候認為規定了,只有0,沒有 0。c語言是一門程序導向的 抽象化的通用程式設計語言,廣泛應用於底層開發。c語言之所以命名為c,是因為c語言源自kenthompson發明的b語言,而b語言則源自bcpl語言。1967年,劍橋大學的martinrichards對cpl語言進...