• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            newplan

            阿基米德在洗澡時發現浮力原理,高興得來不及穿上褲子,跑到街上大喊:Eureka(我找到了)。
            posts - 39, comments - 26, trackbacks - 0, articles - 4
              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理
            datarea segment
             keyword      db    
            5,?,5 dup(?)
             sentence     db    
            50,?,50 dup(?)
             accesstalk1  db    
            'Enter keyword:','$'
             accesstalk2  db    13,10,'Enter Sentence:','$'
             answer1      db    13,10,'Match At location:','$'
             answer3      db    'H of the sentence.','$'
             answer4      db    13,10,'No Macthed!','$'
            datarea ends
            ;
            ****************************************************
            codearea segment
                assume  cs:codearea , ds:datarea , es:datarea
            main  proc far

                  push ds
                  
            sub ax,ax
                  push ax
                  mov ax,datarea
                  mov ds,ax
                  mov es,ax
                  ;
                  lea dx,accesstalk1
                  mov ah,09h
                  
            int 21h
                  ;
                  lea dx,keyword
                  mov ah, 0ah
                  
            int 21h
                  ;
             start:
                  lea dx,accesstalk2
                  mov ah, 09h
                  
            int 21h
                  ;
                  lea dx ,sentence
                  mov ah, 0ah
                  
            int 21h
                  ;
                  lea si ,sentence
            +2;這里是被比較的句子的起始位置,之所以要+2,是因為存放句子的空間中第一位存放的是句子可輸入的最大長度,      ;第二位存放的是有效實際長度,從sentence+2開始才是實際的要比較的字符串
                  mov dl, sentence
            +1;注意了,這里sentence+1中的內容是字節類型的,DL是字節類型的,DX是字類型的,因為類型要匹配,所以DL
                  mov dh, 
            0
                  mov cl, keyword
            +1;這里面存放的是關鍵字的有效長度
                  mov ch,
            0
                  
            sub dx,cx;見實驗指導書中最多需要比較的次數
                  inc dx
                  lea bx,sentence
            +2;bx里面放的是被比較句子的開始位置
                  ; 
             
            next:
                  mov si ,bx;從這里開始循環比較,每次回過來的時候都要把si的值變成新的下一個字符的位置,見下面的BX,每次循環都要被加一
                  lea di ,keyword
            +2
                  mov cl ,keyword
            +1
                  mov ch ,
            0
                  cld
                  repz cmpsb;循環比較字符串是否匹配
                  jz compare;當找到相同的字符串的時候時跳到compare里面
                  dec dx;循環次數減一
                  jz allover;當循環次數被減到等于零的時候呢,就要跳到allover里面去了,就是找遍了整個句子還是沒有找到匹配的,跳轉
                  inc bx ;這邊就是對BX加一,使得地址不斷的往前移動
                  jmp 
            next;這邊是循環的實現,跳到上面的next
                  ;
            compare:
                 
                  lea dx,answer1
                  mov ah,09h
                  
            int 21h
                  ; 
                  lea si ,sentence
            +2
                  
            sub bx,si
                  inc bx;這里的bx等于bx比較完的時候的值,也就是地址,減去sentence
            +2的標注的地址,得到的數值加上1就是第一個匹配位置
                  
            call change;調用子函數,十進制到十六進制的轉化
                  lea dx,answer3
                  mov ah,09h
                  
            int 21h
                  jmp start 
                 ;      
            allover:
                  lea dx ,answer4;小心使用的寄存器必須是DX,此次實驗失敗的原因是這里使用SI寄存器了!FUCK
                  mov ah ,09h
                  
            int 21h
                  jmp start
             ret
             main    endp
            change  proc  near
                    push  ax
                    push  bx
                    push  cx
                    push  dx
                    mov   ch,
            4
            rotate:
                    mov   cl,
            4
                    rol   bx,cl
                    mov   al,bl
                    
            and   al,0fh
                    add   al,30h
                    cmp   al,3ah
                    jl    print
                    add   al,7h
            print:
                    mov   dl,al
                    mov   ah,
            2
                    
            int   21h
                    dec   ch
                    jnz   rotate
                    pop   dx
                    pop   cx
                    pop   bx
                    pop   ax
                    ret
            change  endp
                    codearea ends
                    
            end main
            ;
            ****************************************************
            久久精品国产99久久无毒不卡| 久久精品极品盛宴观看| 久久夜色精品国产亚洲| 伊色综合久久之综合久久| 亚洲精品无码久久毛片| 精品久久久久久无码专区| 国产精品永久久久久久久久久| 久久国产香蕉视频| 一本久久a久久精品亚洲| 久久精品成人免费网站| 久久久无码精品午夜| 人妻丰满AV无码久久不卡| 精品久久久无码中文字幕| 国产人久久人人人人爽| 狠狠色伊人久久精品综合网 | 久久99久国产麻精品66| 97久久精品午夜一区二区| 伊人色综合久久天天人手人婷| av无码久久久久久不卡网站| 无码任你躁久久久久久老妇| 国内精品久久久久久久亚洲| 性欧美大战久久久久久久久| yy6080久久| 国内精品久久久久影院网站 | 国产成人无码精品久久久久免费| 亚洲精品综合久久| 国产精品亚洲美女久久久| 999久久久无码国产精品| 成人午夜精品无码区久久| 四虎影视久久久免费| 国产精品久久久久乳精品爆| 国内精品久久久久久野外| 99精品久久久久久久婷婷| 欧美伊人久久大香线蕉综合69 | 久久国产劲爆AV内射—百度| 狠狠色丁香婷婷综合久久来来去| 青青草国产精品久久| www亚洲欲色成人久久精品| 精品久久8x国产免费观看| 久久久久久久97| 久久精品国产91久久综合麻豆自制|