登录注册
社区应用 最新帖子 精华区 社区服务 会员列表 统计排行
主题 : [ZT]我和电脑亲密接触的心路历程
伍胥之 离线
级别: 军区司令员

显示用户信息 
60楼  发表于: 2015-08-29   
初见中文版HTML类语言 }(I DPaJ  
%SFR.U0}yK  
l]=$<   
大约在93或94年的时候,四通MS2401已经在打字社用得不多了,学校印刷厂用华光激光照排系统。 weadY,-H8  
`D4'`Or-U  
学校里有一个研究所出一个小杂志,自己有台电脑可以用这个华光/方正的排版系统,我不知道是华光[在山东潍坊]和北大方正是谁山寨谁,不过,反正都是王选他们搞出来的。 3$f5][+U  

( w  
够复杂吧? 8pt <)Rs}  
,'DrFlI  
但是它可以排出我们在中文书本上的所有格式,很神奇。直接就是一门语言。 dllf~:b  
MM$" 6Jor  
确实, 人家就叫BD排版语言。我猜是代表北大吧!
杺栫杣杊椌柮栬,䒴蓉艿芖。
伍胥之 离线
级别: 军区司令员

显示用户信息 
61楼  发表于: 2015-08-29   
一般的文字还是比较简单的,就是如【HT4K】汉字4号楷体【HT5XBS】汉字5号小标宋  这样的东东。 3Ya6yz  
RLX^'g+P  
Eu~wbU"%  
此为小样,可以用任何文字编辑器,然后经过一次扫描,生成一个文件,再经二次扫描生成一个可以由专门显示程序显示的实际格式,此为大样。 rZ4<*Zegv  
"lb!m9F{  
在没有所见即所得的年代,打字员完全在脑子里想像它最终的格式。结果不理想再回去重新编辑。 JNCtsfd  
[:'?}p  
杺栫杣杊椌柮栬,䒴蓉艿芖。
伍胥之 离线
级别: 军区司令员

显示用户信息 
62楼  发表于: 2015-08-29   
我也想玩玩它了。 Tz~ ftf  
*dgN pJ 9  
但是,它有一个硬件加密卡,插在电脑里面的ISA总线接口上。 !Hj)S](F  
Qn&^.e9I  
没有它,扫描1程序就不work. X}^gmu<Vla  
(ZsR=:9(  
肿么办呢?里面有啥秘密呢? 1<e%)? G  
cYS+XBz  
一个假期里,人家不上班的时候,我找一个相熟的女打字员偷偷借出来了,她电脑坏了也常找我修修补补。 k= 1+mG  
xGk4KcxKs  
aBLb i  
我家里那时候没有电脑啊! ]`9K|v  
'~a$f;: Dv  
带着它去了门口的LQ公司,自己组装了一台286兼容机。 8 z7,W3b  
&cE,9o%FZ  
那个时候我连ISA总线接口规范也不懂,只是知道一点,它里面绝对没有通过DMA总线访问的存贮器。因为电脑开机后,从0-640KB RAM中没有它的地方,而从A000:0 - F000:0FFF的ROM中可以看到除了固有的BIOS外,没有别的。实模式下就这些东东。 a}hM}U!  
1"PE@!]  
先DEBUG找找有没有小虫再说吧! Ux]@p rAq  
S*:w\nXP~  
72小时!!!! 3o^ M%  
^Z+D7Q  
整 整 3天,我跟踪了它2天半! 店里给我准备了水和方便面,下班就把我关在里面。 >x gd<  
#E)]7!_XG  
发现它总是在扫描1时写入1个特定的端口,然后从另一端口读出点东东。 8"^TWzg}L  
z*1K<w8  
然后,不管三七二十一,把pass1全部反汇编成一个巨大的文本文件,找出了所有IN 和 OUT 指令。这个好办,咱有DOS的FIND命令,那时叫管道或过滤操作。   9hpM*wt  
*&MkkI#  
type  pass1.txt | find "IN 7E" >in.txt     yBKlp08 J  
type  pass1.txt | find "OUT 7F" >out.txt  I ^92b  
L@GD$F=<0  
再看看它们是不是真的 in 和 out 指令,因为许多字符也会被反汇编成莫名其妙的指令。debug比较笨,不会反汇编伪指令,所以它是不会给我反汇编成类似    db "this is a string other than a series of 8086 instruction$"这样的东东的。 ^2@~AD`&h  
``Rb-.Fq,  
其实,那个年代实际上是有专门的反汇编程序的,能根据内容反汇编出不同的段,类似于: o|C{ s   
_.LWc^Sg  
Identfier1 segment C>ZeG Vq  
   msg01 db "this is a data segment", 0dh,0ah I%xJ)fIK  
ends ! .}{ f;Ls  
[GM<Wt0  
但是,俺不是圈内人,不知道有这好东东啊! Z_+No :F7I  
mr.DP~O:9p  
ywte \}  
不管如何,我找到了它的读写端口的真实指令和地址。 4/_|Qy  
f d5~'2  
再跟踪它就好办了,直接运行了所有读写 7E和7F端口的地方。看看它到底读出了什么东东。 v21?  
(DAJ(r~  
Ry3 f'gx  
!~v>&bCG>9  
;O>fy :$'  
杺栫杣杊椌柮栬,䒴蓉艿芖。
伍胥之 离线
级别: 军区司令员

显示用户信息 
63楼  发表于: 2015-08-29   
说白了就很简单了,它和接在LPT:口上的加密狗一样。向特定端口发送一个要读的字节地址,然后从另一端口读出来一个字节。 " z{w^k  
KYN{iaj  
发现它只是从加密卡出读出来32个字节而已。 cIjs UqKa  
s6uAF(4,  
而且,每次运行读出来的字符序是完全一致的! g7i6Yj1  
"<#:\6aym  
把加密卡取出来,重新运行。在读端口时停下来,然后跳过去,但是把我记下的字符序列传给DX寄存器。当然把这个序列用完了以后,一个Go指令,它开始给我处理排版文件了,而PASS2 也是同样处理。 \$"Xr  
1YL5 ![T  
P#PQ4uK \  
哈哈哈!这个加密卡被我破解了!!! HbVLL`06*  
8?XZF[D  
这三天,太TMD值了!比打任何游戏通关都兴奋,而且特别好玩!
杺栫杣杊椌柮栬,䒴蓉艿芖。
伍胥之 离线
级别: 军区司令员

显示用户信息 
64楼  发表于: 2015-08-29   
接下来的就比较简单了。 eH{ 9w8~  
*E'K{?-K  
把所有的IN DX, 7F指令变成一个 INT 80, 然后在华光的中文系统加载后,自己写一个简单的TSR程序,安装一个INT 80的软中断服务程序,在其中把这32个字节放在服务程序中,再用一个字节做个计数器。 每次有程序调用这个中断时,它返回一个序列中的字节,计数器加1,达到序列末尾时计数器复位。 SGm? "esEt  
O6]~5&8U.  
完工!
杺栫杣杊椌柮栬,䒴蓉艿芖。
伍胥之 离线
级别: 军区司令员

显示用户信息 
65楼  发表于: 2015-08-29   
后来呢?没有什么后来了。 qZe"'"3M  
(P-<9y@  
我把这个盗版的东东,给好几个朋友装上了,其实我也不知道它值多少钱,反正学校门口的打字社我去了不论打字复印人家都不收钱。 ri ~2t3gg  
P_U-R%f  
/+msrrpD  
中间出了一个插曲。 f'dI"o&^/d  
$}fA;BP  
上班以后,我给人家那个研究所的电脑上装上了我的解密版,而把加密卡自己留下来装到我自己的机器上了。不厚道吧? Lw`\J|%p  
$(U|JR@  
过了两年,她突然找到我,问我那个卡是不是还用? 我都快忘了这事了,因为那个386SX被我扔到床底下去了,我已经免费换了一套386DX. |sz9l/,lG  
3I+pe;  
而她的电脑也换了,再装上正版的方正不干活了。 |{T2|iJI  
 %3j5Q   
赶紧从床底下扒拉出来那个破电脑。好在,加密卡还在。 8vK&d>  
A$cbH.  
杺栫杣杊椌柮栬,䒴蓉艿芖。
伍胥之 离线
级别: 军区司令员

显示用户信息 
66楼  发表于: 2015-08-29   
其实,我是做了很多无用功的。 CCV~nf  
g:U ul4  
因为那个时候,在386平台上已经有比DEBUG好5倍的调试器了。 "L]_NS T  
yhaYlYv[_3  
叫SoftICE, 因为ICE是一块硬件调试板,当然是专业级的。而Soft ICE只是一个软件,但是它利用了386 CPU的调试寄存器,所以有了条件中断。 例如,可以设置一个条件而不必逐条指令跟 踪,符合条件时程序会中断运行,回到SOFTICE控制台。比如当BX寄存器为1000h时则运行中断。 c+=&5=i[3  
j7&l&)5  
那可是省事省时多了。 %L3]l  
4KCxhJq  
+Sfv.6~v  
不过,这个东东我还没用热乎,它就不能用了。因为有程序自己使用了调试寄存器,所以在监控条件下运行和非监控下运行结果可以完全不同,会把跟踪都引向歧路。 o6 /?WR9  
VM[8w`  
从此,跟踪与反跟踪就变成了道和魔。 D 3PF(Wx  
0N. *c  
杺栫杣杊椌柮栬,䒴蓉艿芖。
伍胥之 离线
级别: 军区司令员

显示用户信息 
67楼  发表于: 2015-08-29   
那个时候,自己玩得不亦乐乎,已经开始把它当游戏玩了。 Tx*m p+q  
9[`6f8S_$  
我自己写过一个反跟踪的小程序,只有几条指令,做成一个宏,可以插在任意地方。很有效,但也可能很危险。 q<VhP2R  
rzu^br9X  
那个年代对指令和数据没有什么严格区分的,只要把DS取成CS一样的值,就可以在运行过程中修改代码。现在,则有人会利用一此漏洞,在数据中插入代码,然后利用这些代码来窃取点什么。 Y{KJk'xN5W  
!T*izMX}  
这个反跟踪程序利用了CPU的指令预取(prefetch)特征,在绝大多数情况下,CPU在运行一条指令时,除非是跳转指令,下面的几条指令已经在CPU中排队了,并不需要从内存中读指令。 cO:x{~  
ArY'NE\Htt  
所以,如果正在运行的指令修改了下一条指令,在全速运行且不中断时,这个修改只改变了内存中的东东,而CPU指令流水线中的并不会改变。但是,如它在被跟踪进,这条指令修改后,下一条指令已经被上条修改,所以,运行结果就会完全不同了。 0N xaQ`\  
lK-I[i!  
antitrace macro 7F.,Xvw&@  
cc[w%jlA#  
pusha :"4~V Du  
CLI /03>|Juo  
mov dx, CS &>o)7H];  
mov DS,DX cF6|IlhO  
nextInst: (]:G"W8f  
lea BX, nextinst+8 E' Bt1 u  
mov [bx],DX \cG'3\GI  
STI @lwqk J  
POPA H|Ems}b  
C7{wI` ~  
endm tz,FK ;8  
]l%j>Vb!L  
我在8086-80486系统上试过,都没有问题,当然测试次数也没有像那些Benchmark程序那么多,反正只要插入这个宏,在所有有此宏的代码段,程序都不能被跟踪,因为一跟踪,在mov [bx],dx后,后面两条指令就变成随机的了(DX只是当前的DS段值,与程序加载内存位置有关)。所以,它到底可靠性多高,吃不准。不过,这东东一旦出错,后果也是完全不可预料的。 P]n ' q  
e\<I:7%Rg  
杺栫杣杊椌柮栬,䒴蓉艿芖。
伍胥之 离线
级别: 军区司令员

显示用户信息 
68楼  发表于: 2015-08-29   
年轻时玩的胆子不小,但是跳槽的勇气却没有。 [# :k3aFz  
mIyaoIE|$  
现在老了,就只能YY了。 AF @C9 s  
+~-|( y  
如果当初跨专业读个CS硕士,我现在会做什么呢? 3r\QLIr L8  
d1-QkW^0y  
估计不如现在好玩。 g=)@yZ3>v  
P1t5-q  
+"!IVH Y  
因为分子生物学注定只能是个full time工作,而CS则是可以当作业余爱好玩的。 DCj!m<Y&  
P.o W#Je  
如果我转了CS, 难道能在半夜三更玩分子生物学? wQ5__"D  
L|<Mtw  
所以,命中如此吧!人老了就认命了。 L-XTIL$$  
杺栫杣杊椌柮栬,䒴蓉艿芖。
ostasia 离线
级别: 排长
显示用户信息 
69楼  发表于: 2015-08-29   
这是伍sir自传吗?那个唯一一次恋爱就修成正果了?
伍胥之 离线
级别: 军区司令员

显示用户信息 
70楼  发表于: 2015-08-30   
引用
引用第69楼ostasia于08-29-2015 21:09发表的  : sS._N@f  
这是伍sir自传吗?那个唯一一次恋爱就修成正果了? 7j^, 4;  
LVSJK.B  
算是吧! 是成了正果,但是20年后又abortion了, 正在考虑:  +p2)uXqW  
' `S,d[~  
R U sure? [Ignore? Retry? Restart? ]
杺栫杣杊椌柮栬,䒴蓉艿芖。
伍胥之 离线
级别: 军区司令员

显示用户信息 
71楼  发表于: 2015-08-30   
10、DOS的Abort,Retry, Fail?错误 Qk((H~I}  
85年以后出生的人可能不知道DOS是什么了,只有那老家伙还知道这是什么。 d2pVO]l YZ  
xu3qX"  
我还记得当时的我对于Abort和Fail这两个选择还是比较清楚的,不过,今天完全忘记了Abort和Fail的差别是什么? &W1cc#(  
y@F{pr+dA  
这个出是DOS下的经常出现,也相当的经典,以至于在Wikepedia上都有专门的业面 Abort, Retry, Fail?。 \QVL%,.%M  
; X8eZQ  
简称为ARF。当然,ARI – Abort, Retry, Ignore?
杺栫杣杊椌柮栬,䒴蓉艿芖。
伍胥之 离线
级别: 军区司令员

显示用户信息 
72楼  发表于: 2015-08-30   
这个SideKick是个好东东。 )gZ yW  
_f/6bpv  
下面的程序不是我写的。 >y5~:L  
D ,nF0p  
用汇编编写DOS下的内存驻留程序(1) yJ?6BLJi  
]`LMy t0  
=m UtBD.;  
d;K,2  
d%iMjY`~[g  
LKhUqW  
2QdqVwm  
绪言 Zf ;U=]R  
V V<Zl  
U<zOR=_  
0.1 内存驻留与中断 'Je;3"@  
bO9X;} \6  
rAgb<D@,H  
内存驻留程序英文叫Terminate and Stay Resident Program,缩写为TSR.这些程序加载进内存,执行完后,就驻留在内存里,当满足条件时,调到前台来执行。 U2;_{n*g%  
5~v({R.  
X4gs{kx}|  
内存驻留程序的常用形式有: {$Qw]?Yv  
Pwf":U)  
h DCR>G  
>诸如Borland 的SideKick弹出式实用程序 Esd A %`  
@I9A"4Im  
~OXPn9qPp  
>日历系统 yN9/'c~  
5-*/wKjLz  
alyWp  
>网络服务器 up1kg>i%"  
}5EvBEv-)  
+ps(9O/B>  
>通讯程序 s~3"* ,3@  
s_/ CJ6s  
QN":Qk(,q  
>本地的DOS扩展(如CCDOS,UCDOS等中文系统都属于这个范畴) q>t#5Z81  
!Eu}ro.}  
0`:0m/fsU  
>一些可恶的人利用TSR技术制作很多可恶的病毒程序,几乎所有的病毒程序都是TSR程序. @u?m4v{  
T)MKhK9\Ab  
!IcP O  
就象多任务系统调度一个进程有一个调度程序一样,在PC中从前台程序进入到一个TSR,也要有一个调度者,只是PC操作系统的调度不称为调度程序,而只称为触发机制.触发机制调度TSR执行在PC机上党称为激活一个TSR.触发机制主要有以下几种: >o.4sN@  
D/v?nW  
.^eajb`:  
>硬件中断:党用的是键盘中断INT 9H,时钟中断INT 8H,通讯中断INT 14H,磁盘中断INT 13H等等. G@s rQum(  
(V&$KDOA  
b:2# 3;)  
>软件中断:党用的是键盘中断INT 16H,时钟中断INT 1CH,DOS中断INT 21H,等等. W2'u]1bs  
^tI ,eZ  
idEhxvAo  
>以上各种的结合. f-^JI*hj  
?|kwYA$4o  
13kl\ <6  
从以上的触发机制可以看出,TSR和PC机的中断系统有着密切的关系.每种激活方式实际上都是与中断有关的.常用特殊的击键序列的识别码是通过截获INT 9H和INT 16H来实现.实际上不管TSR程序的哪一个环节,都与中断有着密切的关系.因此在具体进行TSR和程序设计之前,先介绍PC中断系统.在此只作简单说明. p[>! ;qI  
)m|)cLT&  
f<<1.4)oSV  
在PC机内存的最低端(0000H开始)的1K字节中,存放着256个指针即常说的中为向量或中断矢量(Interrupt vertor),每个中断向量都指向一个子程序,该程序称为中断处理程序(Interrup handler).一个中断向量由四个字节组成,有一个字是中断处理程序的偏移量值,后一个字是中断处理程序的段值.256中断向量一起称为中断向量表.  _->d41  
X3@Uih}|  
bZLY#g7L"  
手式计算中断向量的首址,可通过以下的公式来求得: iU+O(vi  
nH_M#  
y2cYRHN[X}  
X号中断向量的首址=0000H:X*4 F P3{Rp  
Dr)B0]KG  
*jM]:GpyoU  
当产生一个中断时,处理器都按顺序执行以下步骤:  Vmt$ ]/  
OQ&l/|{O0?  
jBb:)  
>在堆栈上压入处理器的标志(相当于指令PUSHF). JD9)Qelw^$  
PKJw%.-  
z#m ~}  
>在堆栈上压入当前CS和IP值(相当于指令PUSH CS和PUSH IP). Cs))9'cD]  
\I (g 70  
Z ):q1:y  
>关闭中断(CLI) KSz;D+L \  
8MU+i%hd  
&sJ-&7YZ  
>从中断向量加载的CS和IP,执行中断处理程序. s+DOr$\  
EV/DJ$C }  
VX0}x+LJ  
当执行完中断处理程序后,一般用IRET返回,它的作用是: NYw>Z>TD8c  
DZ"'GQSg  
Y'*oW+K  
>从堆栈上取出保存的IP和CS(相当于指令POP CS和PUSH CS). 6/6M.p  
yw\Q>~$n[=  
f}=>c|Do  
>同时恢复中断前的处理器标志(相当于指令POPF). BlnR{Y  
=bgWUu\F  
id+ ~ V  
中断有多种分类,由触发的原因和实现的性质来分,可分为硬件中断和软件中断,从操作系统分层实现来说,可以分成BIOS中断,BOS中断和用户中断. GCZx-zD~>  
W[/Txc0$  
Ir#]p9:x  
一方面,BIOS和DOS通过中断系统向用户提供一个操作系统功能界面.也就是说用户(一般来说是前台程序)的功能主要是通过调用DOS和BIOS的中断服务来实现的,具体来说就是通过INT指令来实现的.另一方面,BIOS和DOS由中断系统所构成,BIOS对硬件成为高层的功能,并通过中断的形式向用户提供. fN&@y$  
}p5_JXBV  
FF#T"y0Y  
如果在当前程序执行的同时,能将一块代码放在内存,把中断向量指向代码中的子程序,那么在当前程序执行中产生中断时,就有可能执行不属于当前程序和操作系统的代码,产生的中断可能是当前程序产生的软件中断,也可能是由硬件产生的硬件中断.这就是单任务的PC操作系统可能执行多于一个进程的简单说明. F JCs$0  
zcGmru|k  
@q]4]U)  
在PC中断系统中有几个中断具有周期性,即INT 8H,INT 1CH和INT 28H.它们或者周期性被执行用于时间计时,或者周期性产生用于等待.它们是在实现TSR时进行轮询触发的基础.键盘中断(INT 9H和INT 16H)当用户击键时发生,利用它们是进行热键处理的基础.串行口通讯也是触发的一个重要机制.此外众多的软件中断也是触发的媒介. ?fW['%  
X lLG/N  
iSbPOC7  
DaP,3>M  
0.2 DOS的可重入性分析 8 kvF~d ;  
,+~8R"  
$+w:W85B  
一个多任务操作系统之所以能使多个进行并存,是因为操作系统的大部分代码是可以了重的,对于临界资源有相应的PV操作,使得当调度一个新的进程时,能完整地保存前一个里程的现场,当再一次调度被挂起的进程时能象没有被中断一样继续执行. 2ci[L:U  
%tB7 &%ut  
Np7+g`nG  
对于PC机来说,代码的重入性比较弱,对临界资源没有PC操作.当我们用中断程序启动用户的TSR时,如果只保存标志和寄存器,以及当前进程一些信息,那么只保存了当前程序的一部分现场,DOS的临界资源不会自动保存.在进行TSR设计时,一定要了解PC操作系统的重入性和临界资源. Q<0X80w>  
]n}aePl}oU  
pmRm&VgE.  
重入性总是体现在代码上,所谓可重入代码的指这样的代码,即该代码被执行时还没有从中退出,由于某种原因又一次或者多次进入相同的代码,该代码每次的执行结果都是正确的,就说该代码是可重入的.相反,如果结果不正确,那么就就该代码是不可重入的.下面是一个可重入的子程序的例子: V_zU?}lZ^  
0RgE~x!hI  
GHY+q{'#V_  
Add proc near jh(T?t$&  
fJOw E g|  
K @RGvP  
cmp DS:word ptr [si],0 G>=Fdt7Oc  
1%E Ngb:8  
nr&bpA/  
je DonotAddTheValue rtNYX=P  
M0yv= g  
.exBU1Yk@  
add ax,DS:word ptr [si] e.\dqt~%y  
Q p7h|<  
ml@;ngmp.  
DonotAddTheValue: DG?g~{Y~b  
L I*=T   
#lR-?Uh  
ret bFjH* ~ P  
fqjBor}  
'Fy"|M;2  
Add endp 1oe,>\\  
S4\a"WYg  
t0,=U8]w  
上面的例子不管在其中任何一处再一次执行该子程序,执行结果不变.为了说明,只举多种可能性中的一种. I3HO><o f  
PriLV4?  
4O<sE@X  
mov ds,0100h ;ds=0100h x ]">  
IdqCk0lVD  
'i',M+0>jC  
mov si,0010h ;si=0010h JkhWLQ>o  
C#-HWoSi  
7r&lW<:>  
mov ax,0001h ;ax,=0001h ^hXm=r4ozR  
EHN( K-  
"}MP{/  
call Add }y Vx"e)  
NOg/rDs'{  
eAmI~oku  
cmp 0100h:word ptr [0010h],0 ;Call Add subroutine kDol1v`  
auga`*  
nrHC;R.nE  
push ds ;Interrupted (n`] sbx  
u@1 2:U$  
DkX^b:D*f  
push si `Fie'[F5,)  
)r^vrCNy>  
C~egF=w  
push ax DQ(0 :r  
P -NR]f  
r0!')?#Z  
mov ds,0200h ;ds=0200h `;Ho<26  
rY 6x):sC  
#9gx 4U  
mov si,0200h ;si=0020h R2v9gz;W  
elAWQEu s  
FQJiLb._Z  
mov ax,0003h ;ax=0003h }4N'as/ZO  
)9^)t   
To}eJ$8*5  
call Add "4\k1H"_  
Mgr?D  
1 RJFPv  
cmp 0200h:word ptr [0020h],0 ;0200:0020h=0004h L&c & <+0T  
U0t|i'Hx  
K[kK8i+(  
jne T%% 0W J  
P0yDL:X[  
~Oa$rqu%m  
add ax,0200h:word ptr [0020h] ;ax=0007h 6@TU9AZS `  
3_<l`6^Ns/  
<o/!M6^:  
ret ;Return ]!ox2m_U  
$33E-^  
SV@*[r  
pop ax ;ax=0001h ?r KbL^2  
Da615d  
0N^+d,Xt.  
pop si ;si=0010h d7Vp^^}(  
(>vyWd]  
<3!Al,!ej@  
pop ds ;ds=0100h 1~t.2eUG  
fGb}V'x}r  
Tf~eH!~0  
iret ;Return to Add subroutine HdN5zl,q  
,VS(4  
.<zKBv  
jne y_X jY  
FY^2 Y  
=WjHf8v;  
add ax,0100h:word ptr [0100h] ;ax= 0001h V:w%5'^3  
c ef[T(>  
 V1B!5N<  
;0100h:0010h= 0002h b3EGtC}^  
"]#Ij6ml  
mFg$;F  
;---------------------------------------- 23P&n(.  
<4+P37^ ~  
S=ZZ[E_~S  
;ax = 0003h 5CZyA`3V^5  
s]% C z\  
||JUP}eP  
ret ;Ax-f04gG  
E/g"}yR  
o !:Z?.!  
mov bx,ax h~7#$i  
) w0x{_  
(I BT|K  
而下面的子程序是不可重入的: "h#R>3I1)  
@QV0l]H0+  
j1KNgAo<4  
Add proc near D#UuI Z  
tBbOxMm0  
g!R7CRt%  
mov Temp,ax g]lEG>y1R  
 +=jS!  
8'u9R~})   
mov ax,DS:word ptr [si] u [._RA  
yI 2UmhA  
 D3c JIVM  
cmp ax,0 g E _+r  
KEtV  
rw,Ylr :3  
je DonotTheValue /1MmOB  
Xd=KBB[r?  
^#d\HI  
add ax,Temp RqgN<&g?  
[02rs@c>  
< mQX S87  
DonotTheValue: V _:`K$  
tsAV46S  
l3sF/zkH  
ret ?>Sv_0  
7Y9#y{v1  
T[Zs{S  
Temp: ao2^3e  
=}0Uw4ub(u  
O;~e^ <*  
dw 0 .26mB Xr  
1(-!TJ{  
-T,?'J0 2  
Add endp ~.aR=m\#  
杺栫杣杊椌柮栬,䒴蓉艿芖。
伍胥之 离线
级别: 军区司令员

显示用户信息 
73楼  发表于: 2015-08-30   
+b(};(wL  
可以利用检查可重入子程序的方法检查这个子程序的不可重入性,尝试一下在" mov ax,DS:word ptr [si]"指令后再次执行该子程序,那么就会出第一次调用返回的结果不对. >E>yA d  
A#. %7S  
m,lZy#02s3  
mov ds,0100h ;ds=0100h q7X#LYk  
eAfi!!Z<  
~ubvdQEW  
mov si,0010h ;si=0010h -N8rs[c  
杺栫杣杊椌柮栬,䒴蓉艿芖。
伍胥之 离线
级别: 军区司令员

显示用户信息 
74楼  发表于: 2015-09-05   
转战VB 6.0 {4D`VfX_  
bZ\R0[0  
杺栫杣杊椌柮栬,䒴蓉艿芖。
伍胥之 离线
级别: 军区司令员

显示用户信息 
75楼  发表于: 2015-09-05   
等我用熟了Turbo C后,TC已经又面临淘汰了。 C( ij_>  
ob\-OMNs@  
因为早已进入视窗时代了。 Windows 2.0被译为视窗,我觉得还是很贴切的。 5MVa;m  
Q#\Nhc  
可是, Borland C++ for Windows 和 Visual C++ 的程度我都看不懂。 2#>;cn\  
{Rkd;`Q`!  
因为我错过了Windows编程,只对X86的实模式非常熟悉,对保护模式一窍不通。 J,F1Xmr4  
|}z)>E  
所以,也没有学过事件、消息啥的,因为全系最好的电脑是联想的80286,386以上的机器我只能去家对门的电脑公司。那里从来不缺各种兼容机,但是都是新机器,没有一台相对固定的有全套开发系统的电脑,因为装出来都是卖的,要么是别人送修的。 S"cTi[9  
fOV_ >]u  
杺栫杣杊椌柮栬,䒴蓉艿芖。
伍胥之 离线
级别: 军区司令员

显示用户信息 
76楼  发表于: 2015-09-05   
公司一个长期固定客户是济钢采购部的,常常没事过来聊天,到点一起吃饭,当然是公司请客,我作陪。 L[x`i'0B  
^ Oh  
而我这个时候帮公司干了一个活,用Visual FoxPro帮他们写一个程序,是给济南电视台广告部的广告管理系统。 w"v!+~/9  
`,qft[1  
其实比较简单,就是客户、联系方式、广告、要求播出时间(每周的一个模式)、时长、每天执行播出的时间、和广告带子编号、在磁带上的位置。这样比较容易安排播出计划和便于查找磁带目录。 0 0N[ : %  
yp#!$+a}  
连续用了48小时,算是搞定了。但最后是不是采用了,我就不得而知了,我只对公司负责。 #7]Jz.S  
X`.##S KC  
老板希望我在他们公司兼职,但是我不同意。因为拿了人家的钱就得受人家管,而我是自由惯了的人。如果遇事请我帮忙,我有兴趣有时间就做,没兴趣可以推掉。只要我想找台电脑试试时有电脑可用,钱对我不重要。我那时的状态是我没有什么钱,可是从不缺钱,因为我不需要花钱。 J].Oxch&y  
ib=)N)l  
作完这个后,济南的这个人告诉我VB很好用,可以简单地定义按钮、窗口啥的。不过他用的VB是DOS版的,但是对鼠标支持不错。 Ix-Mp   
w:t~M[kTW  
我去软件市场看了看,有Windows版的VB, 当然是D版的。5块钱买了再说吧!  k,:W]KD  
ye(b 7CX  
DZSS  
+<a\0FsD  
0$*7lQ<a#M  
杺栫杣杊椌柮栬,䒴蓉艿芖。
伍胥之 离线
级别: 军区司令员

显示用户信息 
77楼  发表于: 2015-09-05   
在此之前我用过微软最传统的Basic,深恶而痛绝之,后来的Quick Basic 支持了结构化编程,基本可以避免使用Goto语句,感觉还不错。 '^UHY[mX8  
V|8'3=Z=  
再看VB, 原来语法是完全一样的并略有扩充,而且窗口、事件都有现成的。 /65YHXg,  
[Fl_R[o  
倒是很容易学习的。 o-\h;aQJ  
O] @E8<?^  
公司有一本Windows 32位函数参考,发现VB可以直接利用。这样多数编码效率低的缺陷也可以基本弥补了。 3vY-;&  
XQo\27Fo  
杺栫杣杊椌柮栬,䒴蓉艿芖。
伍胥之 离线
级别: 军区司令员

显示用户信息 
78楼  发表于: 2015-09-05   
在用DOS年代,教务处组织了一帮人写题库,除了计算机系的人外,只有我一个外行。 Tn&_ >R  
NiZfaC6V  
那个时候我们用FoxPro 2.5 for DOS,我的工作除了参与题库设计外,主要的活儿是将组卷结果加入BD排版语言指令,卷子可以直接送印刷厂印刷就可以,不用再排版。 I0m7;M7 P  
]SQ+r*a  
换了VB以后,自然就把数据库换成了Access 97,那时不会用OLE DB,只好用ODBC数据库引擎,将组卷结果写成一个RTF文件,然后可以用Windows下的Word来打开并编辑了。因为我把想到的在所有试卷中出现在格式编出一个文件,再存成.rtf格式,就知道这个“HTML”的各种标记了。 8ymdg\I+L  
g(@F`W[  
杺栫杣杊椌柮栬,䒴蓉艿芖。
伍胥之 离线
级别: 军区司令员

显示用户信息 
79楼  发表于: 2015-09-05   
其间给公司干了一个小活,但是虎头蛇尾没有做完。 !D=!  
S2$66xr#  
公司的另一个客户是黄台电厂,在电厂进煤的专用线上有一个运态轨道衡,也就是在火车以一定速度通过后,它可以称出每节车皮的重量,操 作人员记下车厢号后,就知道车厢自重。 ZC?~RXL(  
U#z"t&o=L  
我不知道怎么实现的,他们说里面有很多猫腻,就是说可以多算煤净重,也可以少算。 riIubX#  
$|~ <6A{y  
所以,他们要求用CCD拍下车厢,自动识别出车号,另外测出车辆通过的速度。结果存入一个数据库。 p*Z<DEh#  
c,a8#Og  
就是一个我并不懂的模式识别问题。 287j,'vR  
0Y8gUpe3P6  
想拍下火车再说吧! Z)7{~xq  
4fi4F1f  
在铁路对面的柱子上,设置了一个标记,当检测到图像变化时,开始录像。居然没有与轨道衡联动,那是别的公司的东东,接口不明。 zG9FO/@av  
9hzu!}~' I  
逐帧保存是一个问题,写盘数据量非常大,因为不能实时识别车号(事实上到最后我也没有学会),所以只能全存。就用BMP格式吧!我也只了解这一种格式。 A (2 0+  
L^JU{\C  
但是不能将每帧保存为一个文件,这样太慢了。 W Z'<iI  
@Tu`0 =8  
我的办法是只存原始数据,图像的XY值是固定的,不必记入文件,所以也不用文件头了。将一列火车的所有图像写入一个文件,你想想会有多大吧!每秒大约20帧,单色的灰度CCD,每像素8位(1字节,256级灰度)。 L]=]/>jQ6  
9<gW~ s>  
Win32API除了一个写文件的函数(writefile)外,还有一个特别的WriteDisk函数,它从内存中一个页面对齐的地址开始,将与扇区字节数(0x200)整数位的内存块,直接写入磁盘上的一个特殊方式打开的文件中。这个写操作速度特别快。  ?(9*@  
~O}r<PQ  
我猜想,Windows的交换文件pagefile.sys 就是用这种方式读写的。 ),x0G*oebj  
hIV 9.{J  
所以,就需要除了变量声明外,需要用Win32API申请一块存贮区域作为读写的buffer(这个词在CS中叫缓冲区,后来我开始做分子生物学,才知道我天天用的缓冲溶液也叫buffer)。然后用Win32API 打开一个固定的文件,并且保证它是一个连续的磁盘区域(这在编程中是做不到的,需要用Defrag去优化)。 i]ZGq7YJ%  
k=s^-Eiu  
如此,我写了一个监控程序,就是各种看守所里用的经常在需要的情况下损坏的摄像头记录仪。 _}F& ^  
.RroO_H   
火车通过后的时间,就把图像再调出来分析,我最后只能把含有车厢编号的图像块分离出来,但是却不会识别出车号来。 vFUp$[  
j9fBl:Fr  
这个识别工作后来交给了别人,我知道黄台电厂用上了,但最后结果是否理想我并不清楚。 SY,ns*>1F  
Y2L{oQ.C2  
公司好像给了我一笔挺多的钱,4或5K吧!在当时,算是我见到的最多的钱了,这时工资才1K多点嘛! {8m&Z36E  
I): c#  
MSCH6R"5  
Cff6EE  
杺栫杣杊椌柮栬,䒴蓉艿芖。
描述
快速回复

验证问题:
3 * 6 = ? 正确答案:18
按"Ctrl+Enter"直接提交