三、试题解释
1、2001年试题三
[程序说明]
子程序 DEHZ 用来对 HZ 编码的字串做解码处理。
HZ 编码是海外华人创造的一种将含有高位为 1 的汉字双字节字串转换成易于在网络中传输的ASCII 字符串的变换方式。编码过程中,被转换字符串中的原汉字子字符串各字节高位作清零处理,使之成为 ASCII 子字符串,并在其前后两端分别添加 ~{ 和 ~} 作为标记;而对于原 ASCII 子字符串,则将其中的 ~ 改写为 ~~,其余字符不变。
DEHZ 解码子程序则是 HZ 编码的复原过程。复原 ASCII 子字符串过程中遇有 ~~ 字符则改写为一个 ~ ,遇有 ~{ 则将其后直至 ~} 标记前的各字节高位置 1,复原为汉字子字符串,同时删除其前后标记。~的后续字符不属于以上情况均作为错误处理。
调用该子程序时, GR1 存放原始字符串首地址, GR2 存放还原后的目标字符串首地址。工作寄存器 GR3 用作处理汉字子字符串的识别标志,进入子程序时应初始化为处理 ASCII 子字符串。程序按照 CASL 语言的标准约定,字符串的每个字符只占用一个存储字的低八位。原始字符串和目标字符串均以 0 作为结束标志。
[程序]
|
START |
|
1 |
| DEHZ |
PUSH |
0,GR3 |
2 |
|
PUSH |
0,GR2 |
3 |
|
PUSH |
0,GR1 |
4 |
|
LEA |
GR3,0 |
5 |
| LOOP |
__(1)__ |
|
6 |
|
CPA |
GR0,MARK0 |
7 |
|
JNZ |
GOON |
8 |
|
LEA |
GR1,1,GR1 |
9 |
|
LD |
GR0,0,GR1 |
10 |
|
CPA |
GR0,MARK0 |
11 |
|
__(2)__ |
|
12 |
|
CPA |
GR0,MARK1,GR3 |
13 |
|
JNZ |
ERROR |
14 |
|
__(3)__ |
|
15 |
|
LEA |
GR1,1,GR1 |
16 |
|
JMP |
LOOP |
17 |
| ERROR |
OUT |
ERS1R,ERLEN |
18 |
|
JMP |
EXIT |
19 |
| GOON |
__(4)__ |
|
20 |
|
ST |
GR0,0,GR2 |
21 |
|
LEA |
GR2,1,GR2 |
22 |
|
LEA |
GR1,1,GR1 |
23 |
|
CPA |
GR0,VO |
24 |
|
__(5)__ |
|
25 |
| EXIT |
P0P |
GR1 |
26 |
|
P0P |
GR2 |
27 |
|
P0P |
GR3 |
28 |
|
RET |
|
29 |
| V1 |
DC |
1 |
30 |
| V0 |
DC |
O |
31 |
|
DC |
#0080 |
32 |
| MARK0 |
DC |
'~ ' |
33 |
| MARK1 |
DC |
'{ }' |
34 |
| ERSTR |
DC |
'ERROR!' |
35 |
| ERLEN |
DC |
6 |
36 |
|
END |
|
37 |
[解] 寄存器作用: GR1:源字符串地址指针,调用该子程序时,存放源字符串首地址。 GR2:目标字符串地址指针,调用该子程序时,存放目标字符串首地址。 GR3:用作处理汉字子字符串的识别标志。0 表示 ASCII 码(初始值),1 表示汉字。 GR0:工作寄存器,存放待处理的字符。(从第 7 行 "CPA GR0,MARK0" 看出) 分析: 1)从第 7 行 " CPA GR0,MARK0" 看出,GR0 中存放待处理的字符。所以第 6 行(__(1)__)必定是一条取数指令:"LD GR0,0,GR1" ,即把源字符串地址指针所指的字符取到 GR0 中。 2)从第7 行及第 8 行可知,第 9 行到第 17 行是处理碰到“~”的情况,即判断后一字符是否是“~”、“{ ”及“}”。若都不是,则出错。 3)从第11 行可知,要判断是否连续两个“~”情况,而后面是继续比较,所以第 12 行(__(2)__)应该是一条“JZE”指令,而且是转移到 GOON ,即把“~”存放到目标字符串中。 4)第 13 行“CPA GR0,MARK1,GR3”应该是比较“{ ”及“}”:在中文状态比较“}”(结束),在西文状态比较“{ ”(开始)。所以这里用的是变址寻址,即由 GR3 的值是 0 或 1,决定是比较“{ ”还是“}”。 5)第 12 行(__(3)__)应该是改变汉字子字符串的识别标志 GR3 的指令,即原来是 0 的变成 1,原来是 1 的变成 0,异或指令可以达到此目的。将 GR3 与常数 1 相异或,因 Casl 没有没有立即数运算指令,只能和常数 V1 异或:EOR GR3,V1 6)第 20 行(__(4)__)是 GR0 中存放的字符送到目标字符串前的处理工作:若是西文状态( GR3 的值是 0 ),保持原样;若是中文状态( GR3 的值是 1 ),字节最高位置 1,复原为汉字子字符串,将GR0 的内容与十六进制数 0080 相或,即能达到目的。所以这条指令应是:OR GR0,V0,GR3 。 7)第 24 行将 GR0 与 0 比较,是判断字符串结束标志 0 。若非 0(未结束),继续处理。故第 25 行(__(5)__)应是一条条件转移指令:JNZ LOOP 。 [1] [2] [3] [4] 下一页 |