摘要: 編寫一個(gè)子程序,將包含任意字符,以0結(jié)尾的字符串中的小寫字母轉(zhuǎn)變成大寫字母,描述如下。
名稱:letterc
功能:將以0結(jié)尾的字符串中的小寫字母轉(zhuǎn)變成大寫字母
參數(shù):ds:si指向字符串首地址
閱讀全文
摘要: 總結(jié):
1、程序?qū)崿F(xiàn)中基本都用到了棧,主要用于暫存寄存器數(shù)據(jù)。不過在子程序dtoc和ddtoc中,我還用棧存放參數(shù)%10的值,因?yàn)樾纬勺址畷r(shí)需要逆序?qū)懙絻?nèi)存。
2、在dtoc和ddtoc中,為了區(qū)分保存的寄存器數(shù)據(jù)和十進(jìn)制數(shù)的ascii值,特意往棧中壓入一個(gè)0,作為“樁”。
3、主程序中在循環(huán)跳轉(zhuǎn)的loop語句被注釋掉:“;loop show ;報(bào)錯(cuò):jump destination too far ,所以自己手動(dòng)判斷cx來跳轉(zhuǎn)。”,原因正如說明,偏移超過了一個(gè)字節(jié),所以我自己修改判斷cx而利用jmp(jmp near)來實(shí)現(xiàn)跳轉(zhuǎn)。因?yàn)樗杏袟l件跳轉(zhuǎn)都是短轉(zhuǎn)移,是不是把循環(huán)中間的一些內(nèi)容也寫到子程序來減少偏移更好?
4、對(duì)顯示時(shí)的起始行和列偏移的數(shù)據(jù),我都統(tǒng)一放在數(shù)據(jù)段中,可以很方便的修改來查看效果。
閱讀全文
摘要: 編程:在屏幕中間分別顯示綠色、綠底紅色、白底藍(lán)色的字符串"welcome to masm!"。
1、這種實(shí)現(xiàn)是我的第二個(gè)版本,第一個(gè)版本是將要顯示的字符和字符的顏色屬性都一起定義,然后就是從偏移地址讀取寫到顯存,比如,綠色顯示的定義如下:
db 'w',82h,'e',82h,'l',82h,'c',82h,'o',82h,'m',82h,'e'...
但是這樣的話,首先'welcome to masm!'要重復(fù)3次,然后顏色屬性就要重復(fù)更多了。既占用內(nèi)存,修改也很麻煩。所以就將字符串和顏色屬性分開定義,在邏輯處理時(shí)來寫內(nèi)存。
2、對(duì)字符顏色屬性,可以很方便的通過修改“db 82h,0ach,0f9h”一句來查看不同的效果。
3、關(guān)于行偏移和列偏移的計(jì)算,我在代碼中已經(jīng)給出了詳細(xì)的說明,應(yīng)該很清楚了。同樣的,我也將這些數(shù)據(jù)單獨(dú)定義在數(shù)據(jù)段,可以很方便的修改以查看效果。
閱讀全文
摘要: 實(shí)驗(yàn)7 尋址方式在結(jié)構(gòu)化數(shù)據(jù)訪問中的應(yīng)用
本題設(shè)計(jì)的好處就在于:
1、年份year是用ascii表示,所以要4個(gè)字節(jié)。而公司收入又是一個(gè)dd類型,也是4個(gè)字節(jié)。所以這兩個(gè)數(shù)據(jù)可以共用一個(gè)寄存器表偏移,我的程序用的是si。
2、讀入收入時(shí),就有意用dx存高位,用ax存低位;讀入雇員數(shù)時(shí),用bx來存儲(chǔ),這樣就能直接用div求人均收入,也就不需要額外的寄存器轉(zhuǎn)存的過程。
3、故意將table段地址用ss存,這樣就順理成章的用bp作為table段的偏移。就不需要顯式標(biāo)出段寄存器了。
基于以上設(shè)計(jì),也就不需要額外弄堆棧,寄存器等,而且一個(gè)循環(huán)就能實(shí)現(xiàn)了。
閱讀全文
摘要: 仔細(xì)觀察圖3.19中的實(shí)驗(yàn)過程,然后分析:為什么2000:0~2000:f中的內(nèi)容會(huì)發(fā)生改變?
可能要再做些實(shí)驗(yàn)才能發(fā)現(xiàn)其中的規(guī)律。如果你在這里就正確回答了這個(gè)問題,那么要恭喜你,因?yàn)槟阌泻芎玫奈蛐浴4蠖鄶?shù)的學(xué)習(xí)者對(duì)這個(gè)問題還是比較迷惑的,不過不要緊,因?yàn)殡S著課程的進(jìn)行,這個(gè)問題的答案將逐漸變得顯而易見。
閱讀全文
摘要: 閱讀別人的代碼作為開發(fā)人員是一件經(jīng)常要做的事情。一個(gè)是學(xué)習(xí)新的編程語言的時(shí)候通過閱讀別人的代碼是一個(gè)最好的學(xué)習(xí)方法,另外是積累編程經(jīng)驗(yàn)。
閱讀全文
摘要: 本文不是描述怎樣編寫dll程序,也不是說明dll在windows系統(tǒng)的意義。我們的目的是確認(rèn)dll加載到進(jìn)程空間的一些模糊的概念。
一、程序加載dll的兩種情況:
二、從MSDN文檔來研究操作dll的API
三、關(guān)于引用計(jì)數(shù)遞減到0會(huì)導(dǎo)致模塊卸載映射的問題
閱讀全文
摘要: 動(dòng)態(tài)鏈接庫DLL
閱讀全文
摘要: 本文研究eSNACC的C運(yùn)行時(shí)庫動(dòng)態(tài)內(nèi)存管理。
eSNACC的運(yùn)行時(shí)庫和代碼生成用的內(nèi)存管理函數(shù)用的是統(tǒng)一的宏定義原型,但是支持用戶自己配置內(nèi)存管理方案。eSNACC本身提供兩種內(nèi)存管理方案:
一個(gè)是mem.h/c定義的直接分配;另一個(gè)是nibble-alloc.h/c定義的Nibble memory系統(tǒng)。
閱讀全文