久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 1733|回復(fù): 0
收起左側(cè)

微機原理與接口技術(shù)實驗-字符串搜索與匹配

[復(fù)制鏈接]
ID:1078860 發(fā)表于 2023-5-21 12:06 | 顯示全部樓層 |閱讀模式
介紹了一個使用x86指令集的匯編語言仿真實驗,實驗具體要求和仿真結(jié)果如下:1、實驗任務(wù)要求

2、設(shè)計思路
分析實驗要求,我們要完成四個功能:
1)從一個已知字符串str中找到匹配字符串substr的起始位置;
2)從起始位置開始,比對兩個字符串,確定兩個字符串確實一樣,由此便可認(rèn)為已知字符串中出現(xiàn)了匹配字符串;
3)在找到匹配字符串后,設(shè)置標(biāo)志為單元found;
4)在找到匹配字符串后,把匹配位置存放到pos中。
明確需要完成的功能,然后設(shè)計算法:
1)使用‘while’循環(huán),遍歷字符串str,找到匹配字符串substr的起始位置;
2)找到起始位置后,再用LOOP循環(huán)對兩個字符串比對。循環(huán)次數(shù)是substr長度再減一(第一次已經(jīng)在while中完成);
3)4)完成循環(huán)后,設(shè)置標(biāo)志位found,把匹配位置存放到pos中。

注意到str可能不包含substr,當(dāng)遍歷str沒有找到substr時,程序終止。
圖片1.png
下面是程序思路流程圖:

算法流程圖

算法流程圖

3、運行結(jié)果
設(shè)置字符串str和匹配字符串substr如圖:

字符串設(shè)置

字符串設(shè)置

運行結(jié)果如下:

仿真結(jié)果

仿真結(jié)果


本實驗的匯編語言源代碼見博客末尾:
  1. ;Finding substr from string

  2. DATA SEGMENT
  3.     str DB '2020210827 Liqiwen', 00H
  4.     substr DB 'Liqiwen', 00H
  5.     N EQU $-substr
  6.     found DB 00H
  7.     pos DW ?
  8. DATA ENDS

  9. CODE SEGMENT
  10.     ASSUME CS:CODE, DS:DATA
  11. START:
  12.     MOV AX, DATA
  13.     MOV DS, AX
  14.    
  15.     LEA SI, str
  16.     XOR AX, AX
  17.     MOV AL, [SI]    ;Using AL as the container of [SI]
  18.     XOR CX, CX
  19.     MOV CX, N-1     ;LOOP times: N-1
  20. BACK:LEA DI, substr
  21. SHIFT:
  22.     CMP AL, 00H     ;str doesn't contain substr, program terminated.
  23.     JE FINISH
  24.     CMP AL, [DI]
  25.     JE COMP         ;If [SI] euqals the first chart of substr, comparation will begin.
  26.     INC SI
  27.     MOV AL, [SI]   
  28.     JMP SHIFT
  29. COMP:
  30.     INC SI          ;Shift to the next chart
  31.     INC DI
  32.     MOV AL, [SI]
  33. L1:
  34.     CMP AL, [DI]
  35.     JNE BACK        ;If [DI] doesn't euqal [SI], clarifying substr didn't appare, instruction will go back.
  36.     INC SI
  37.     INC DI
  38.     MOV AL, [SI]
  39.     LOOP L1
  40.    
  41.     MOV AL, 0FFH
  42.     MOV found, AL
  43.     LEA BX, SI-8    ;BX deposits the beginning position.
  44.     MOV [pos], BX
  45.      
  46. FINISH:   
  47.     MOV AH, 4CH
  48.     INT 21H
  49. CODE ENDS
  50. END START
復(fù)制代碼
回復(fù)

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規(guī)則

小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術(shù)交流QQ群281945664

Powered by 單片機教程網(wǎng)

快速回復(fù) 返回頂部 返回列表
主站蜘蛛池模板: 国产日韩久久 | 国产在线一区二区 | 国产在线观看免费 | 欧美精品二区三区四区免费看视频 | 黄色福利 | 亚洲一区在线看 | 欧美又大又硬又粗bbbbb | 午夜在线观看免费视频 | 欧美精品在线观看 | 中文字幕在线观看一区二区三区 | 手机av在线免费观看 | 97av在线| av网址在线播放 | 日韩久久网 | 天天躁日日躁bbbbb | 一区二区三区影视 | 国产999视频 | 蜜桃精品一区二区三区 | 三级在线免费观看 | 久久久久久久久久一区二区三区 | 中文字幕综合网 | 中文字幕在线观看日本 | 中文字幕不卡在线观看 | 中文有码在线 | 亚洲激情视频在线观看 | 国产欧美精品一区二区三区 | 免费黄网站 | 欧美三级韩国三级日本三斤在线观看 | 99re在线观看| 久久久久久久久国产 | 一级做a爱片性色毛片 | 日韩一区二区三区免费 | 国产日韩在线视频 | 国产一级在线 | 欧洲精品一区二区 | 午夜视频在线免费观看 | 97精品在线视频 | 亚洲视频一区二区 | 四级黄色片 | 哦┅┅快┅┅用力啊┅aps | 久久久久久久综合 |