二進位序列所寫的程式稱為“機器語言程式”,是電腦唯一能直接辨識並執行的低階語言;機器語言是直接用二進位程式碼指令表達的電腦語言,指令是用0和1組成的一串代碼,64個0和1可組成各種排列組合,透過線路變成電訊號,讓電腦執行各種不同的操作。
本教學操作環境:windows10系統、DELL G3電腦。
用二進位序列所寫的程式稱為機器語言程序,是電腦唯一能直接辨識並執行的低階語言。
機器語言是直接用二進位代碼指令表達的計算機語言,指令是用0和1組成的一串代碼,它們有一定的位數,並分成若干段,各段的編碼表示不同的意義,例如某台電腦字長為64位元(bit),即有64個二進位數組成一條指令或其它訊息。 64個0和1可組成各種排列組合,透過線路變成電訊號,讓電腦執行各種不同的操作。
機器語言是指電腦硬體能夠直接辨識的指令的集合,最早出現的電腦語言。機器語言從屬於硬體設備。不同的電腦設備有不同的機器語言,所以機器語言是一種面向機器的語言。
電腦指令系統中的指令是由"0” 和“1” 兩種符號組成的程式碼,並且能被機器直接理解執行,它們稱為機器指令。一個計算機的機器指令的集,就構成了該計算機的機器語言, 即計算機可以直接接受、理解的語言。
機器語言的簡單介紹
程式語言是用來定義電腦程式的形式語言,用來向電腦發出指令。電腦語言數量很多,每年都會產生大量新的程式語言。以層次來分,程式語言可分為3類:機器語言、組合語言和高階語言。機器語言由機器指令集構成,能夠直接被機器執行。機器語言寫的程式有不便於閱讀、難以記憶的問題。彙編語言本質上也是直接對硬體操作,由於採用了助記符,相比機器語言更方便書寫與閱讀。在高階語言中,將多條組譯程式語句合併成更簡潔的程式語句,同時自動完成一些如堆疊、暫存器分配管理等工作,更方便程式設計師開發程式 。
機器語言是用二進位程式碼表示的電腦能直接辨識和執行的一種機器指令的集合。它是電腦的設計者透過電腦的硬體結構賦予電腦的操作功能。機器語言具有靈活、直接執行和速度快等特點。不同型號的計算機其機器語言是不相通的,按著一種計算機的機器指令編制的程序,不能在另一種計算機上執行。
一條指令就是機器語言的一個語句,它是一組有意義的二進位代碼,指令的基本格式如,操作碼字段和地址碼字段,其中操作碼指明了指令的操作性質及功能,位址碼則給出了操作數或操作數的位址。
用機器語言寫程序,程式設計人員要先熟記所用電腦的全部指令碼和程式碼的涵義。手編程式時,程式設計師得自己處理每個指令和每一資料的儲存分配和輸入輸出,還要記住程式設計過程中每步驟所使用的工作單元處在何種狀態。這是一件十分繁瑣的工作。編寫程式所花費的時間往往是實際運行時間的幾十倍或幾百倍。而且,編出的程式全是些0和1的指令碼,直覺性差,還容易出錯。除了電腦生產廠商的專業人員外,絕大多數的程式設計師已經不再去學習機器語言了。
指令格式
機器語言指令是一種二進位程式碼,由操作碼和運算元兩部分組成。操作碼規定了指令的操作,是指令中的關鍵字,不能缺省。操作數表示該指令的操作對象。 [2] 計算機的指令格式與機器的字長、記憶體的容量及指令的功能都有很大的關係。從便於程式設計、增加基本操作並行性、提升指令功能的角度來看,指令中應包含多種資訊。但在有些指令中,由於部分資訊可能無用,這將浪費指令所佔的儲存空間,並增加了訪問次數,也許反而會影響速度。因此,如何合理、科學地設計指令格式,使指令既能給出足夠的信息,又使其長度盡可能地與機器的字長相匹配,以節省存儲空間,縮短取值時間,提高機器的性能,這是指令格式設計的重要問題。
計算機是透過執行指令來處理各種資料的。為了指出資料的來源、操作結果的去向及所執行的操作,一條指令必須包含下列資訊:
(1)操作碼。它具體說明了操作的性質及功能。一台電腦可能有數十條至幾百條指令,每一條指令都有一個對應的操作碼,電腦透過辨識該操作碼來完成不同的操作。
(2)操作數的位址。 CPU透過該位址就可以取得所需的操作數。
(3)操作結果的儲存位址。將操作數的處理所產生的結果保存在該位址中,以便再次使用。
(4)下條指令的位址。執行程序時,大多數指令依序從主記憶體取出執行,只有在遇到轉移指令時,程式的執行順序才會改變。為了壓縮指令的長度,可以用一個程式計數器(ProgramCounter,PC)來存放指令位址。每執行一條指令,PC的指令位址就會自動 1(設指令只佔一個主記憶體),指出將要執行的下一指令的位址。當遇到執行轉移指令時,則用轉移位址修改PC的內容。由於使用了PC,指令中就不必明顯地給出下一條將要執行指令的位址。
一條指令其實包含兩種訊息即操作碼和位址碼。操作碼(OperationCode,OP)用來表示該指令所要完成的操作(如加、減、乘、除、資料傳送等),其長度取決於指令系統中的指令條數。位址碼用來描述該指令的操作對象,它或直接給出操作數,或指出操作數的記憶體位址或暫存器位址(即暫存器名稱)。
指令包含操作碼域和位址域兩部分。根據位址域所涉及的位址數量,常見的指令格式有以下幾種。
三位址指令:一般位址域中A1、A2分別決定第一、第二運算元位址,A3決定結果位址。下一指令的位址通常由程式計數器依序給出。
二位址指令:位址域中A1決定第一運算元位址,A2同時決定第二運算元位址和結果位址。
單一位址指令:位址域中A 決定第一運算元位址。固定使用某個暫存器存放第二操作數和操作結果。因而在指令中隱含了它們的位址。
零位址指令:在堆疊型計算機中,運算元一般存放在下推堆疊頂的兩個單元中,結果又放入棧頂,位址均被隱含,因而大多數指令只有操作碼而沒有位址域。
可變位址數指令:位址域所涉及的位址的數量會隨操作定義而改變。如有的計算機的指令中的位址數可少至 0個,多至6個。
更多相關知識,請造訪常見問題欄位!
以上是二進位序列所寫的程式稱為什麼的詳細內容。更多資訊請關注PHP中文網其他相關文章!