匯編 --- 棧結構的妙用

在js中雙重循環,代碼如下:

for(let i =0; i < l1;i++){for(let j=0; j< l2;j++){// todo...}
}

以上代碼在匯編中是如何實現的呢.

  • 匯編中用cx和loop來代表一次循環
	mov cx, 4
s:	mov ax,1loop s
  • 但是如果使用如下方法實現雙重循環將會出錯
assume cs:codesg, ds:datasgdatasg segment
db	'ibm             '
db	'dec			 '
db	'dos			 '
db	'vax			 '
datasg endscodesg	segment
start:	mov	ax, datasgmov ds,	axmov bx,	0		; 用BX來定位行mov	cx,	4s0:	mov	si,	0		; 用si來定位列mov	cx,	3s:	mov	al,	[bx+si]and	al,	11011111bmov	[bx+si], alinc siloop s		    ; 此時的 cx 已經為0add	bx, 16loop s0			; cx = cx -1 , 再判斷 cx 為是否為0mov ax, 4c00hint 21hend codesg
end start
  • 原因如下:
    • 每當執行 loop 語句時, 實際是執行 cx = cx -1 然后判斷 cx 是否為0. 于是在內層循環后(loop s), cx =0 , 然后再到 loop s0時,此時先執行 cx = cx - 1, 即此時 cx = FFFF 因此會陷入死循環
  • 改進辦法.用寄存器dx來保存進入內層循環的cx,然后再內存循環結束時,將寄存器dx中的值賦給cx
start:	mov ax,	datasgmov ds,	axmov bx,	0mov cx, 4s0:	mov dx, cxmov	si, 0mov cx, 3s:		mov al, [bx+si]and	al,	11011111bmov	[bx+si],	alinc siloop sadd bx, 16mov cx, dxloop s0mov ax, 4c00hint 21h
  • 以上方法可以解決兩層循環的問題,但是CPU中的寄存器畢竟是有限的,當循環次數多的時候,寄存器將不夠用.
  • 考慮到內存,可以將寄存器cx的值存入內存中.然后在內存循環結束后,在從內存中讀取值給cx
assme cs:codesg, ds: datasgdatasg segment
; 其他代碼略
dw 	0			; 定義一個字單元, 用來保存cx
datasg endscodesg segment
start:		mov ax, datasgmov ds, ax				; 匯編中用ds來定位數據地址mov bx, 0				; 偏移量為0mov cx, 4				; 外層循環為4s0:		mov ds:[40H], cx		; 將外層循環的次數保存到內存datasg:40H單元中mov si, 0mov cx, 3s:		mov al, [bx+si]and al, 11011111bmov [bx+si], alinc siloop sadd bx, 16				; 移到下一個字單元mov cx, ds:[40H]		; 從內存中取出當前循環的次數loop s0mov ax,	4c00hint 21h
end codesg
end start
  • 以上方法可以解決CPU中寄存器不夠用的情況,但對于保存的多個數據,程序猿們必須要記住數據保存在哪個內存單元中.當代碼量大的時候,需要寫很多注釋,也不利于閱讀與維護
  • 看VC++ 6.0編譯器是如何處理的
    在這里插入圖片描述
  • 通過反編譯,查看匯編源碼可以發現.
  • 在遇到函數時,編譯器將當前環境push進一個棧中,當執行完畢,將棧中的環境pop出來
  • 于是上面的代碼可以改為如下:
stack segment			; 棧空間dw 0,0,0,0,0,0,0,0	; 16字節(根據需要定)
stack endscodesg segment
start:	mov ax, stacksgmov ss, axmov sp,	16		; 匯編中ss 指向棧端, sp代表偏移量為16mov ax, datasgmov ds, axmov bx, 0mov cx, 4s0:	push cxmov si,0mov cx, 3s:	mov al, [bx+si]and al, 11011111bmov [bx+si], alinc siloop sadd bx, 16pop cxloop s0mov ax, 4c00hint 21h
codesg ends
end start

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/250651.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/250651.shtml
英文地址,請注明出處:http://en.pswp.cn/news/250651.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

PHP 安全編程建議

PHP 安全編程建議 簡介 要提供互聯網服務&#xff0c;當你在開發代碼的時候必須時刻保持安全意識。可能大部分 PHP 腳本都對安全問題都不在意&#xff0c;這很大程度上是因為有大量的無經驗程序員在使用這門語言。但是&#xff0c;沒有理由讓你因為對你的代碼的不確定性而導致不…

day2-列表、元組、字典、字符串

1.列表&#xff08;list&#xff09; names[悟空,艾瑪,克林,龜仙人,天津飯,餃子,烏龜] print(names)---》列表&#xff0c;然后打印。 names[悟空,艾瑪,克林,龜仙人,天津飯,餃子,烏龜]# list section section1names[0] #下標從0開始 #print(section1) #結果為悟空seciton2names…

開漏輸出、推挽輸出的區別

推挽輸出:可以輸出高,低電平,連接數字器件。 輸出 0 時&#xff0c;N-MOS 導通&#xff0c;P-MOS 高阻&#xff0c;輸出0。 輸出 1 時&#xff0c;N-MOS 高阻&#xff0c;P-MOS 導通&#xff0c;輸出1&#xff08;不需要外部上拉電路&#xff09;。 開漏輸出:輸出端相當于三極管…

羅馬數字

古羅馬帝國開創了輝煌的人類文明&#xff0c;但他們的數字表示法的確有些繁瑣&#xff0c;尤其在表示大數的時候&#xff0c;現在看起來簡直不能忍受&#xff0c;所以在現代很少使用了。之所以這樣&#xff0c;不是因為發明表示法的人的智力的問題&#xff0c;而是因為一個宗教…

匯編 --- 從磁盤(扇區2到18)上讀取數據到內存中

下面代碼讀取柱面:0,磁頭:0,扇區從2到18的數據到內存 0x8200~0xa3ff處 需要明白以下幾點: 給定柱面,磁頭,一個扇形區域是512字節,對應的物理可以理解為512個燈泡組(一個燈泡組有8個小燈泡)確定讀取到內存中的位置 為什么是0x8200:因為0x8000~0x81ff這512個字節要留給啟動區.為…

那些值得思考的PHP問題

那些值得思考的PHP問題 1、關于弱類型 函數strpos是返回字符串str2在str1的位置&#xff0c;沒有找到則返回false&#xff0c;然而如果在實際應用上返回的位置是0&#xff0c;在if語句中0也被當作false&#xff0c;所以我們需要對false做類型判斷&#xff0c; $str1 yabadaba…

Lvs Tun隧道模式配置

######## TUN是IP Tunneling &#xff0c;IP隧道的簡稱&#xff0c;它將調度器收到的IP數據包封裝在一個新的IP數據包中&#xff0c;轉交給應用服務器&#xff0c;然后實際服務器的返回數據會直接返回給用戶。 工作原理&#xff1a; 用戶請求負載均衡服務器&#xff0c;當IP數…

mysql-常用sql

記錄下工作中常用的sql 刪除重復數據 delete from student where id not in (select min(id) from student group by name); -- 該語句在mysql下會報錯&#xff0c; -- 執行報錯&#xff1a;1093 - You cant specify target table student for update in FROM clause -- 原因是…

優雅的使用Laravel之phpstorm配置

優雅的使用Laravel之phpstorm配置 先打開一個Laravel 項目&#xff0c;然后在project tool 窗口選擇根節點、然后右鍵->Composer | Init composer 。 如果你的電腦里沒有composer.phar&#xff0c;可以點擊鏈接來下載。然后點擊項目 composer->add denpendency.. 搜索ba…

算法 --- 求兩個集合的并集

const unionL (l1, l2)>{for(let i0; i <l1.length; i){if(l2.indexOf(l1[i]) -1){l2.push(l1[i])}}return l2 }let l1 [1,2,3,4]; let l2 [1,2,5]; console.log(unionL(l1,l2)); //[1, 2, 5, 3, 4]

java實驗四——找鞍點

package hello;public class 實驗四 {public static void main(String[] args) {// TODO Auto-generated method stubint[][] a {{9,8,6},{2,3,1},{8,5,2}};System.out.println("二維數組為&#xff1a;");for(int i0;i<a.length;i){for(int j0;j<a[i].length;…

BZOJ 4551樹題解

好吧&#xff0c;洛谷的數據比較水暴力就可以過。。。。&#xff08;而且跑到飛快&#xff09; 不過&#xff08;BZ水不過去&#xff09;還是講講正規的做法。 其實一眼可以看出可以樹剖&#xff0c;但是&#xff0c;碼起來有點麻煩。 其實有一種更簡單的離線做法。 我們很容易…

es6 --- 使用Symbol保護私有變量

定義一個人物類 假設其屬性有姓名和性別我們希望,性別在聲明后就固定不變 傳統方法 var Person (function(){var _gender ;function P(name, gender){this.name name;_gender gender;}P.prototype.getGender function(){return _gender;}return P; })();var p1 new Pe…

組合數

long long factorial(int n) {long long m 1;for(int i1;i<n;i)m*i;return m; } long long C(int n,int m) {return factorial(n)/(factorial(m)*factorial(n-m));//可能會溢出 } 正解&#xff1a; long long C(int n,int m) {if(m<n-m) m n-m;long long ans 1;for(in…

Mysql中的聯合索引、前綴索引、覆蓋索引

Mysql中的聯合索引、前綴索引、覆蓋索引 索引 索引是一種特殊的文件&#xff0c;它們包含著對數據表里所有記錄的引用指針。更通俗的說&#xff0c;數據庫索引好比是一本書前面的目錄&#xff0c;能加快數據庫的查詢速度。 聯合索引 又名復合索引&#xff0c;由兩個或多個列…

LVM邏輯卷管理

什么是邏輯卷&#xff1f;因為可以將文件系統像卷一樣伸長或縮短之故。 LVM做法&#xff0c;將幾個物理分區或磁盤&#xff0c;通過軟件組合成為一塊看起來是獨立的大磁盤&#xff08;VG&#xff09;&#xff0c;然后將這塊大磁盤再經過分成可使用分區&#xff08;LV&#xff0…

es6 --- 自制迭代器

對象 對象如下 const obj {left: 100,top: 200 }不可迭代 for(let attr of obj){console.log(attr); }迭代規則 可迭代,所具有的屬性[Symbol.iterator] 需要自己給obj添加迭代規則 obj[Symbol.iterator] () >{// 獲取obj的所有鍵let keys Object.keys(obj);let len …

軟件工程的實踐項目課程的自我目標

對實踐項目完成后學習到的能力的預期&#xff1a;這算是自己第一次參加的團隊合作的軟件實踐吧&#xff0c;以前自己搞的小“玩意”&#xff0c;實難登大雅之堂&#xff0c;期待實踐項目后--->1、自己的代碼能力能夠有較明顯的提高&#xff0c;代碼更加規范。 2、提升團隊合…

[Shell] swoole_timer_tick 與 crontab 實現定時任務和監控

手動完成 "任務" 和 "監控" 主要有下面三步&#xff1a; 1. mission_cron.php&#xff08;定時自動任務腳本&#xff09;&#xff1a; <?php /*** 自動任務 定時器 (5s 執行).** swoole_timer_tick 解決秒級定時&#xff1b;* 如需調整&#xff0c;注意…

關于項目調研

一、檸檬時代app 1、作品內容&#xff1a; 該作品主要為每一所高校的大學生量身定制的手機生活助手&#xff0c;由您自主運營的校園手機客戶端。開放的自定義平臺&#xff0c;匯聚本校周邊所有生活服務、外賣商家、娛樂休閑、新鮮事兒、知名社團、周邊商鋪、校園達人等欄目。 …