<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>壹亩叁分地</title>
	<atom:link href="http://www.opzn.org/feed" rel="self" type="application/rss+xml" />
	<link>http://www.opzn.org</link>
	<description>WenYunlong&#039;s blog 温云龙的博客</description>
	<lastBuildDate>Fri, 23 Dec 2011 02:07:24 +0000</lastBuildDate>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	<generator>http://wordpress.org/?v=3.3.1</generator>
		<item>
		<title>Nginx的队列</title>
		<link>http://www.opzn.org/archives/966</link>
		<comments>http://www.opzn.org/archives/966#comments</comments>
		<pubDate>Fri, 23 Dec 2011 02:07:05 +0000</pubDate>
		<dc:creator>温 云龙</dc:creator>
				<category><![CDATA[Life]]></category>

		<guid isPermaLink="false">http://www.opzn.org/?p=966</guid>
		<description><![CDATA[队列数据结构：
struct ngx_queue_s {
ngx_queue_t  *prev;
ngx_queue_t  *next;
};
队列的其它操作没有什么，取值比较有意思
#define ngx_queue_data(q, type, link)                                         \
    (type *) ((u_char *) q - offsetof(type, link))
根据link在type中的偏移计算整个结构的内存地址]]></description>
		<wfw:commentRss>http://www.opzn.org/archives/966/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Python执行命令行获取输出</title>
		<link>http://www.opzn.org/archives/919</link>
		<comments>http://www.opzn.org/archives/919#comments</comments>
		<pubDate>Wed, 03 Aug 2011 10:22:59 +0000</pubDate>
		<dc:creator>温 云龙</dc:creator>
				<category><![CDATA[Develop]]></category>

		<guid isPermaLink="false">http://www.opzn.org/?p=919</guid>
		<description><![CDATA[<pre lang="python" line="0">
#!/usr/bin/env python
#
# $id: refresh.py,v 1.0.0 2009/01/05 15:32:48 master Exp $
# Copyright (C) 2009 Yunlong Wen (wenyunlong@gmail.com)
#
# Last Modified: 2009/01/05 16:19:12

import fileinput
import os
from os import curdir, sep

class Shell:

    def exec(self, cmdline):
        out = os.popen( cmdline, 'r')
        txt = out.read()
        ret = out.close()
        if ret:
            raise RuntimeError, '%s failed with exit code %d' % (cmdline, ret)
	    return '%s failed with exit code %d' % (cmdline, ret)
        else:
            return  txt
</pre>]]></description>
		<wfw:commentRss>http://www.opzn.org/archives/919/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>X86 汇编指令详解</title>
		<link>http://www.opzn.org/archives/908</link>
		<comments>http://www.opzn.org/archives/908#comments</comments>
		<pubDate>Sat, 23 Jul 2011 19:46:21 +0000</pubDate>
		<dc:creator>温 云龙</dc:creator>
				<category><![CDATA[Life]]></category>

		<guid isPermaLink="false">http://www.opzn.org/?p=908</guid>
		<description><![CDATA[<h3 style="color: blue;">MOVE</h3>
数据传送指令 MOV

格式: MOV OPRD1,OPRD2

功能: 本指令将一个源操作数送到目的操作数中,即OPRD1&#60;--OPRD2.

说明:

1. OPRD1 为目的操作数,可以是寄存器、存储器、累加器.

OPRD2 为源操作数,可以是寄存器、存储器、累加器和立即数.

2. MOV 指令以分为以下四种情况:

&#60;1&#62; 寄存器与寄存器之间的数据传送指令

&#60;2&#62; 立即数到通用寄存器数据传送指令

&#60;3&#62; 寄存器与存储器之间的数据传送指令

&#60;4&#62; 立即数到存储器的数据传送

3. 本指令不影响状态标志位<!--more-->
<h3 style="color: blue;">PUSH</h3>
堆栈操作指令 PUSH和POP

格式: PUSH OPRD

POP OPRD

功能: 实现压入操作的指令是PUSH指令;实现弹出操作的指令是POP指令.

说明:
1. OPRD为16位(字)操作数,可以是寄存器或存储器操作数.

2. PUSH的操作过程是: (SP)&#60;--(SP)-2,((sp))&#60;--OPRD 即先修改堆栈指针SP(压入时为自动减2),然后,将指定的操作数送入新的栈顶位置.

此处的((SP))&#60;--OPRD,也可以理解为: [(SS)*16+(SP)]&#60;--OPRD 或 [SS:SP]&#60;--OPRD
<h3 style="color: blue;">POP</h3>
堆栈操作指令 PUSH和POP

格式: PUSH OPRD

POP OPRD

功能: 实现压入操作的指令是PUSH指令;实现弹出操作的指令是POP指令.

说明:

1. OPRD为16位(字)操作数,可以是寄存器或存储器操作数.

2. POP指令的操作过程是: POP OPRD:OPRD&#60;--((SP)),(SP)&#60;--(SP)+2

它与压入操作相反,是先弹出栈顶的数顶,然后再修改指针SP的内容.

3. 示例: POP AX
POP DS
POP DATA1 POP ALFA[BX][DI]

4. PUSH和POP指令对状态标志位没有影响.
<h3 style="color: blue;">XCHG</h3>
数据交换指令 XCHG

格式: XCHG OPRD1,OPRD2 其中的OPRD1为目的操作数,OPRD2为源操作数

功能: 将两个操作数相互交换位置,该指令把源操作数OPRD2与目的操数OPRD1交换.

说明:

1. OPRD1及OPRD2可为通用寄存器或存储器,但是两个存储器之间是不能用XCHG指令实现的.

2. 段寄存器内容不能用XCHG指令来交换.

3. 若要实现两个存储器操作数DATA1及DATA2的交换,可用以下指令实现:
示例: PUSH DATA1
PUSH DATA2
POP DATA1
POP DATA2

4. 本指令不影响状态标志位.
<h3 style="color: blue;">XLAT</h3>
查表指令 XLAT

格式: XLAT TABLE其中TABLE为一待查表格的首地址.

功能: 把待查表格的一个字节内容送到AL累加器中.

说明:

1. 在执行该指令前,应将TABLE先送至BX寄存器中,然后将待查字节与在表格中距表首地址位移量送AL,即 (AL)&#60;--((BX)+(AL)).

2. 本指令不影响状态标位,表格长度不超过256字节.
<h3 style="color: blue;">LAHF</h3>
标志传送指令 LAHF

格式: LAHF

功能: 取FLAG标志寄存器低8位至AH寄存器.(AH)&#60;--(FLAG)7~0

说明: 该指令不影响FLAG的原来内容,AH只是复制了原FLAG的低8位内容.
<h3 style="color: blue;">SAHF</h3>
标志传送指令 SAHF

格式: SAHF

功能: 将AH存至FLAG低8位

说明: 本指令将用AH的内容改写FLAG标志寄存器中的SF、ZF、AF、PF、和CF标志,从而改变原来的标志位.
<h3 style="color: blue;">PUSHF</h3>
标志传送指令 PUSHF

格式: PUSHF

功能: 本指令可以把标志寄存器的内容保存到堆栈中去
<h3 style="color: blue;">POPF</h3>
标志传送指令 POPF

格式: POPF

功能: 本指令的功能与PUSHF相反,在子程序调用和中断服务程序中,往往用PUSHF指令保护FLAG的内容,用POPF指令将保护的FLAG内容恢复.

说明: 如果对堆栈中的原FLAG内容进行修改,如对TF等标志位进行修改,然后再弹回标志位寄存器FLAG.这是通过指令修改TF标志的唯一方法.
<h3 style="color: blue;">LEA</h3>
有效地址传送指令 LEA

格式: LEA OPRD1,OPRD2

功能: 将源操作数给出的有效地址传送到指定的的寄存器中.

说明:

1. OPRD1 为目的操作数,可为任意一个16位的通用寄存器.

OPRD2 为源操作数,可为变量名、标号或地址表达式.

示例: LEA BX,DATA1
LEA DX,BETA[BX+SI]
LEA BX BX,[BP],[DI]

2. 本指令对标志位无影响。
<h3 style="color: blue;">LDS</h3>
从存储器取出32位地址的指令 LDS

格式: LDS OPRD1,OPRD2

功能: 从存储器取出32位地址的指令.

说明:

OPRD1 为任意一个16位的寄存器.

OPRD2 为32位的存储器地址.

示例: LDS SI,ABCD
LDS BX,FAST[SI]
LDS DI,[BX]

注意: 上面LDS DI,[BX]指令的功能是把BX所指的32位地址指针的段地址送入DS,偏移地址送入DI.
<h3 style="color: blue;">LES</h3>
从存储器取出32位地址的指令 LES

格式: LES OPRD1,OPRD2

功能: 从存储器取出32位地址的指令.

说明:

OPRD1 为任意一个16位的寄存器.

OPRD2 为32位的存储器地址.

示例: LES SI,ABCD
LES BX,FAST[SI]
LES DI,[BX]

注意: 上面LES DI,[BX]指令的功能是把BX所指的32位地址指针的段地址送入ES,偏移地址送入DI.
<h3 style="color: blue;">ADD</h3>
加法指令 ADD(Addition)

格式: ADD OPRD1,OPRD2

功能: 两数相加

说明:

1. OPRD1为任一通用寄存器或存储器操作数,可以是任意一个通用寄存器,而且还可以是任意一个存储器操作数.

OPRD2为立即数,也可以是任意一个通用寄存器操作数.立即数只能用于源操作数.

2. OPRD1和OPRD2均为寄存器是允许的,一个为寄存器而另一个为存储器也是允许的, 但不允许两个都是存储器操作数.

3. 加法指令运算的结果对CF、SF、OF、PF、ZF、AF都会有影响.以上标志也称为结果标志.加法指令适用于无符号数或有符号数的加法运算.
<h3 style="color: blue;">ADC</h3>
带进位加法指令 ADC(Addition Carry)

格式: ADC OPRD1,OPRD2

功能: OPRD1&#60;--OPRD1 + OPRD2 + CF

说明:

1. OPRD1为任一通用寄存器或存储器操作数,可以是任意一个通用寄存器,而且还可以是任意一个存储器操作数.
OPRD2为立即数,也可以是任意一个通用寄存器操作数.立即数只能用于源操作数.

2. OPRD1和OPRD2均为寄存器是允许的,一个为寄存器而另一个为存储器也是允许的,但不允许两个都是存储器操作数.

3. 加法指令运算的结果对CF、SF、OF、PF、ZF、AF都会有影响.以上标志也称为结果标志.

4. 该指令对标志位的影响同ADD指令.
<h3 style="color: blue;">INC</h3>
加1指令 INC(INCrement by 1)

格式: INC OPRD

功能: OPRD&#60;--OPRD+1

说明:

1. OPRD 为寄存器或存储器操作数.

2. 这条指令执行结果影响AF、OF、PF、SF、ZF标志位,但不影响CF标志位.

3. 示例:
INC SI;(SI)&#60;--(SI)+1
INC WORD PTR[BX]
INC BYTE PTR[BX+DI]
INC CL;(CL)&#60;--(CL)+1

注意: 上述第二,三两条指令,是对存储字及存储字节的内容加1以替代原来的内容.
<h3 style="color: blue;">AAA</h3>
未组合的十进制加法调整指令 AAA(ASCII Adgust for Addition)

格式: AAA

功能: 对两个组合的十进制数相加运算(存在AL中)的结果进行调整,产生一个未组合的十进制数放在AX中.

说明:

1. 组合的十进制数和未组合的十进制数:在计算中,十进制数可用四位二进制数编码,称为BCD码.

当一个节(8位)中存放一位BCD码,且放在字节的低4位, 高4位为时称为未组合的BCD码.

2. AAA的调整操作

若(AL) and 0FH&#62;9 或 AF=1,则调整如下:

(AL)&#60;--(AL)+6,(AH)&#60;--(AH)+1,AF=1,CF&#60;--AF,(AL)&#60;--(AL) and 0FH
<h3 style="color: blue;">DAA</h3>
组合的十进制加法调整指令 DAA(Decimal Adjust for Addition)

格式: DAA

功能: 对AL中的两个组合进制数相加的结果进行调整,调整结果仍放在AL中,进位标志放在CF中.

说明:

1. 调整操作如下
(1) 若(AL) and 0FH&#62;9 或 AF=1,则(AL)&#60;--(AL)+6,AF&#60;--1,对低四位的调整.

(2) 若(AL) and 0F0H&#62;90H 或 CF=1,则(AL)&#60;--(AL)+60H,CF&#60;--1.

2. 示例: (AL)=18H,(BL)=06H
ADD AL,BL ; (AL)&#60;--(AL)+(BL) ; (AL)=1EH
DAA ; (AL)
<h3 style="color: blue;">SUB</h3>
减法指令SUB(SUBtract)

格式: SUB OPRD1,OPRD2

功能: 两个操作数的相减,即从OPRD1中减去OPRD2,其结果放在OPDR1中.

说明:

示例 SUB DX,CX
SUB [BX+25],AX
SUB DI,ALFA[SI]
SUB CL,20
SUB DATA1[DI][BX],20A5H
<h3 style="color: blue;">SBB</h3>
带借位减去指令 SBB(SuBtraction with Borrow)

格式: SBB OPRD1,OPRD2

功能: 是进行两个操作数的相减再减去CF进位标志位,即从OPRD1&#60;--OPRD1-OPRD2-CF,其结果放在OPDR1中.

说明:

示例 SBB DX,CX
SBB AX,DATA1
SBB BX,2000H
SBB ALFA[BX+SI],SI
SBB BETAP[DI,030AH
<h3 style="color: blue;">DEC</h3>
减一指令 DEC(Decrement by 1)

格式: DEC OPRD

功能: OPRD&#60;--OPRD-1

说明:

1. OPRD 为寄存器或存储器操作数.

2. 这条指令执行结果影响AF、OF、PF、SF、ZF标志位，但不影响CF标志位.

3. 示例 DEC AX
DEC CL
DEC WORD PTR[DI]
DEC ALFA[DI+BX]
<h3 style="color: blue;">NEG</h3>
取补指令 NEG(NEGate)

格式: NEG OPRD

功能: 对操作数OPRD进行取补操作,然后将结果送回OPRD.取补操作也叫作求补操作,就是求一个数的相反数的补码.

说明:

1. OPRD为任意通用寄存器或存储器操作数.

2. 示例: (AL)=44H,取补后,(AL)=0BCH(-44H).

3. 本指令影响标志位CF、OF、SF、PF、ZF及AF.
<h3 style="color: blue;">CMP</h3>
比效指令 CMP(CoMPare)

格式: CMP OPRD1,OPRD2

功能: 对两数进行相减,进行比较.

说明:

1. OPRD1为任意通用寄存器或存储器操作数.

OPRD2为任意通用寄存器或存储器操作数,立即数也可用作源操作数OPRD2.

2. 对标志位的影响同SUB指令,完成的操作与SUB指令类似,唯一的区别是不将OPRD1-OPRD2的结果送回OPRD1,而只是比较.

3. 在8088/8086指令系统中,专门提供了一组根据带符号数比较大小后,实现条件转移的指令.
<h3 style="color: blue;">AAS</h3>
未组合十进制减法调整指令 AAS(ASCII Adjust for Subtraction)

格式: AAS

功能: 对两个未组合十进制数相减后存于AL中的结果进行调整,调整后产生一个未组合的十进制数数且仍存于AL中.

说明:

1. 本指令影响标志位CF及AF.

2. 调整操作

若(AL) and 0FH &#62; 9 或 AF=1

则(AL)&#60;--(AL)-6,(AH)&#60;--(AH)-1,CF&#60;--AF,(AL)&#60;--(AL) and 0FH,

否则(AL)&#60;--(AL) and 0FH
<h3 style="color: blue;">DAS</h3>
组合十进制减法调整指令 DAS(Decimal Adjust for Subtraction)

格式: DAS

功能: 对两个组合十进制数相减后存于AL中的结果进行调整,调整后产生一个组合的十进制数且仍存于AL中.

说明:

调整操作

若(AL) and 0FH &#62; 9 或 AF=1,则(AL)&#60;--(AL)-6,AF=1

若(AL) and 0F0H &#62; 90H 或 CF=1,则(AL)&#60;--(AL)-60,CF=1
<h3 style="color: blue;">MUL</h3>
无符号数乘法指令 MUL(MULtiply)

格式: MUL OPRD

功能: 乘法操作.

说明:

1. OPRD为通用寄存器或存储器操作数.

2. OPRD为源操作数,即作乘数.目的操作数是隐含的,即被乘数总是指定为累加器AX或AL的内容.

3. 16位乘法时,AX中为被乘数.8位乘法时,AL为被乘数.当16位乘法时,32位的乘积存于DX及AX中;8位乘法的16位乘积存于AX中.

4. 操作过程: 字节相乘:(AX)&#60;--(AL)*OPRD,当结果的高位字节(AH)不等于0时,则CF＝1、OF＝1.
<h3 style="color: blue;">IMUL</h3>
带符号数乘法指令 IMUL(Integer MULtiply)

格式: IMUL OPRD

功能: 完成两个带符号数的相乘

说明:

1. 其中OPRD为任一通用寄存器或存储器操作数.

2. MUL指令对带符号相乘时,不能得到正确的结果.

例如: (AL)=255
(CL)=255
MUL CL
(AX)=65025
注意: 这对无符号数讲,结果是正确的,但对带符号数讲,相当于(-1)*(-1)结果应为+1,而65025对应的带符号数为-511,显然是不正确的.
<h3 style="color: blue;">AAM</h3>
未组合十进制数乘法调整指令 AAM(ASCII Adjust MULtiply)

格式: AAM

功能: 对两个未组合的十进制数相乘后存于AX中的结果进行调整,产生一个未组合的十进制数存在AL中.

说明:

1. 实际上是两个未组合的十进制数字节相乘,一个0～9的数与另一个0～9的数相乘其积最大为81.为了得到正确的结果,应进行如下调整:

乘积: (AH)&#60;--(AL)/10
(AL)&#60;--(AL)MOD10

2. 本指令应跟在MUL指令后使用,乘积的两位十进制结果,高位放在AH中,低位放在AL中.AH内容是MUL指令的结果被10除的商,即(AL)/10,而最后的AL内容是乘积被10整除的余数(即个位数).
<h3 style="color: blue;">DIV</h3>
无符号数除法指令 DIV(DIVision)

格式: DIV OPRD

功能: 实现两个无符号二进制数除法运算.

说明:

1. 其中OPRD为任一个通用寄存器或存储器操作数.

2. 字节相除,被除数在AX中;字相除,被除数在DX,AX中,除数在OPRD中.

字节除法: (AL)&#60;--(AX)/OPRD,(AH)&#60;--(AX)MOD OPRD

字除法: (AX)&#60;--(DX)(AX)/OPRD,(DX)&#60;--(DX)(AX) MOD OPRD
<h3 style="color: blue;">IDIV</h3>
带符号数除法指定 IDIV(Interger DIVision)

格式: IDIV OPRD

功能: 这实现两个带符号数的二进制除法运算.

说明:

1. 其中OPRD为任一通用寄存器或存储器操作数.

2. 理由与IMUL相同,只有IDIV指令,才能得到符号数相除的正确结果.

3. 当被除数为8位,在进行字节除法前,应把AL的符号位扩充至AH中.在16位除法时,若被除数为16位,则应将AX中的符号位扩到DX中.
<h3 style="color: blue;">CBW</h3>
字节扩展指令 CBW(Convert Byte to Word)

格式: CBW

功能: 将字节扩展为字,即把AL寄存器的符号位扩展到AH中.

说明:

1. 两个字节相除时,先使用本指令形成一个双字节长的被除数.

2. 本指令不影响标志位.

3. 示例: MOV AL,25
CBW
IDIV BYTE PTR DATA1
<h3 style="color: blue;">CWD</h3>
字扩展指令 CWD(Convert Word to Double Word)

格式: CWD

功能: 将字扩展为双字长,即把AX寄存器的符号位扩展到DX中.

说明:

1. 两个字或字节相除时,先用本指令形成一个双字长的的被除数.

2. 本指令不影响标志位.

3. 示例: 在B1、B2、B3字节类型变量中,分别存有8们带符号数a、b、c,实现(a*b+c)/a运算。
<h3 style="color: blue;">AAD</h3>
未组合十进制数除法调整指令 AAD(ASCII Adjust for Division)

格式: AAD

功能: 在除法指令前对AX中的两个未组合十进制数进行调整,以便能用DIV指令实现两个未组合的十进制数的除法运算,其结果为未组合的十进制数,商(在AL中)和余数(在AH中).

说明:

1. AAD指令是在执行除法DIV之前使用的,以便得到二进制结果存于AL中,然后除以OPRD,得到的商在AL中,余数在AH中.

2. 示例: MOV BL,5
MOV AX,0308H
AAD ;(AL)&#60;--1EH+08H=26H,(AH)&#60;--0
DIV BL ;商＝07H--&#62;(AL),余数＝03H--&#62;(AH).
<h3 style="color: blue;">AND</h3>
逻辑与运算指令 AND

格式: AND OPRD1,OPRD2

功能: 对两个操作数实现按位逻辑与运算,结果送至目的操作数.本指令可以进行字节或字的‘与’运算,

OPRD1&#60;--OPRD1 and OPRD2.

说明:

1. 目的操作数OPRD1为任一通用寄存器或存储器操作数.源操作数OPRD2为立即数,任一通用寄存器或存储器操作数.

2. 示例: AND AL,0FH ;(AL)&#60;--(AL) AND 0FH
AND AX,BX ;(AX)&#60;--(AX) AND (BX)
AND DX,BUFFER[SI+BX]
AND BETA[BX],00FFH
注意: 两数相与，有一个数假则值为假
<h3 style="color: blue;">OR</h3>
逻辑或指令 OR

格式: OR OPRD1,OPRD2

功能: OR指令完成对两个操作数按位的‘或’运算,结果送至目的操作数中,本指令可以进行字节或字的‘或’运算.

OPRD1&#60;--OPRD1 OR OPRD2.

说明:

1. 其中OPRD1,OPRD2含义与AND指令相同,对标志位的影响也与AND指令相同.

2. 两数相或,有一个数为真则值为真.
<h3 style="color: blue;">NOT</h3>
逻辑非运算指令 NOT

格式: NOT OPRD

功能: 完成对操作数按位求反运算(即0变1,1变0),结果关回原操作数.

说明:

1. 其中OPRD可为任一通用寄存器或存储器操作数.

2. 本指梳令可以进行字或字节‘非’运算.

3. 本指令不影响标志位.
<h3 style="color: blue;">XOR</h3>
逻辑异或运算指令 XOR

格式: XOR OPRD1,OPRD2

功能: 实现两个操作数按位‘异或’运算,结果送至目的操作数中.

OPRD1&#60;--OPRD1 XOR OPRD2

说明:

1. 其在OPRD1、OPRD2的含义与AND指令相同,对标志位的影响与与AND指令相同.

2. 相异为真,相同为假.
<h3 style="color: blue;">TEST</h3>
测试指令 TEST

格式: TEST OPRD1,OPRD2

功能: 其中OPRD1、OPRD2的含义同AND指令一样,也是对两个操作数进行按位的'与'运算,唯一不同之处是不将'与'的结

果送目的操作数,即本指令对两个操作数 的内容均不进行修改,仅是在逻辑与操作后,对标志位重新置位.

说明: TEST与AND指令的关系,有点类似于CMP与SUB指令之间的关系.
<h3 style="color: blue;">SHL</h3>
逻辑左移指令 SHL(Shift logical left)

格式: SHL OPRD1,COUNT

功能: 对给定的目的操作数左移COUNT次,每次移位时最高位移入标志位CF中,最低位补零.

说明:

1. 其中OPRD1为目的操作数,可以是通用寄存器或存储器操作数.

2. COUNT代表移位的次数(或位数).移位一次,COUNT=1;移位多于1次时,COUNT=(CL),(CL)中为移位的次数.

3. 例如: SHL AL,1
SHL CX,1
SHL ALFA[DI] 或者:
MOV CL,3
SHL DX,CL
SHL ALFA[DI],CL
<h3 style="color: blue;">SHR</h3>
逻辑右移指令 SHR

格式: SHR OPRD1,COUNT

功能: 本指令实现由COUNT决定次数的逻辑右移操作,每次移位时,最高位补0,最低位移至标志位CF中.

说明:

1. 其中OPRD1为目的操作数,可以是通用寄存器或存储器操作数.

2. COUNT代表移位的次数(或位数).移位一次,COUNT=1;移位多于1次时,COUNT=(CL),(CL)中为移位的次数.

3. 影响标志位OF,PF,SF,ZF,CF.
<h3 style="color: blue;">SAL</h3>
算术左移指令 SAL(Shift Arithmetic Left)

格式: SAL OPRD1,COUNT

功能: 其中OPRD1,COUNT与指令SHL相同.本指令与SHL的功能也完全相同,这是因为逻辑左移指令与算术左移指令所要完成的操作是一样的.

说明:

1. 其中OPRD1为目的操作数,可以是通用寄存器或存储器操作数.

2. COUNT代表移位的次数(或位数).移位一次,COUNT=1;移位多于1次时,COUNT=(CL),(CL)中为移位的次数.
<h3 style="color: blue;">SAR</h3>
算术右移指令 SAR

格式: SAR OPRD1,COUNT

功能: 本指令通常用于对带符号数减半的运算中,因而在每次右移时,保持最高位(符号位)不变,最低位右移至CF中.

说明:

1. 其中OPRD1为目的操作数,可以是通用寄存器或存储器操作数.

2. COUNT代表移位的次数(或位数).移位一次,COUNT=1;移位多于1次时,COUNT=(CL),(CL)中为移位的次数.
<h3 style="color: blue;">ROL</h3>
循环移位指令

格式: ROL OPRD1,COUNT ;不含进位标志位CF在循环中的左循环移位指令.

ROR OPRD1,COUNT ;不含进位示志位CF在循环中的右循环移位指令.

RCL OPRD1,COUNT ;带进位的左循环移位指令.

RCR OPRD1,COUNT ;带进位的右循环移位指令.

说明:

1. 本指令组只影响标志CF、OF.OF由移入CF的内容决定,OF取决于移位一次后符号位是否改变,如改变,则OF=1.

2. 由于是循环移位,所以对字节移位8次; 对字移位16次,就可恢复为原操作数.由于带CF的循环移位,可以将CF的内容移入,
所以可以利用它实现多字节的循环.
<h3 style="color: blue;">ROR</h3>
循环移位指令

格式:
ROL OPRD1,COUNT ;不含进位标志位CF在循环中的左循环移位指令.
ROR OPRD1,COUNT ;不含进位示志位CF在循环中的右循环移位指令.
RCL OPRD1,COUNT ;带进位的左循环移位指令.
RCR OPRD1,COUNT ;带进位的右循环移位指令.

说明:

1. 本指令组只影响标志CF、OF.OF由移入CF的内容决定,OF取决于移位一次后符号位是否改变,如改变,则OF=1.

2. 由于循环移位,所以对字节移位8次; 对字移位16次,可恢复为原操作数.
<h3 style="color: blue;">RCL</h3>
循环移位指令

格式: ROL OPRD1,COUNT ;不含进位标志位CF在循环中的左循环移位指令.
ROR OPRD1,COUNT ;不含进位示志位CF在循环中的右循环移位指令.
RCL OPRD1,COUNT ;带进位的左循环移位指令.
RCR OPRD1,COUNT ;带进位的右循环移位指令.

说明:

1. 本指令组只影响标志CF、OF.OF由移入CF的内容决定,OF取决于移位一次后符号位是否改变,如改变,则OF=1.

2. 由于是循环移位,所以对字节移位8次; 对字移位16次,就可恢复为原操作数.由于带CF的循环移位,可以将CF的内容移入,

所以可以利用它实现多字节的循环.
<h3 style="color: blue;">RCR</h3>
循环移位指令

格式: ROL OPRD1,COUNT ;不含进位标志位CF在循环中的左循环移位指令.

ROR OPRD1,COUNT ;不含进位示志位CF在循环中的右循环移位指令.

RCL OPRD1,COUNT ;带进位的左循环移位指令.

RCR OPRD1,COUNT ;带进位的右循环移位指令.

说明:

1. 本指令组只影响标志CF、OF.OF由移入CF的内容决定,OF取决于移位一次后符号位是否改变,如改变,则OF=1.

2. 由于是循环移位,所以对字节移位8次; 对字移位16次,就可恢复为原操作数.由于带CF的循环移位,可以将CF的内容移入,所以可以利用它实现多字节的循环.

注意: 以上程序中的指令SHR AL,CL如改为SAR AL,CL,虽然最高4位可移入低4位,但最高位不为0,故应加入一条指令AND AL,0FH.否则,若最高位不为0时,将得到错误结果.
<h3 style="color: blue;">JMP</h3>
无条件转移指令JMP

格式: JMP OPRD

功能: JMP指令将无条件地控制程序转移到目的地址去执行.当目的地址仍在同一个代码段内,称为段内转移;当目标地址不在同一个代码段内,则称为段间转移.这两种情况都将产生不同的指令代码,以便能正确地生成目的地址,在 段内转移时,指令只要能提供目的地址的段 内偏移量即够了;而在段间转移时,指令应能提供目的地址的段地址及段内偏移地址值.

说明:

1. 其中OPRD为转移的目的地址.程序转移到目的地址所指向的指令继续往下执行.

2. 本组指令对标志位无影响.

3. &#60;1&#62; 段内直接转移指令: JMP NEAR 标号

&#60;2&#62; 段内间接转移指令: JMP OPRD

&#60;3&#62; 段间直接转移指令: JMP FAR 标号

&#60;4&#62; 段间间接转移指令:JMP OPRD其中的OPRD为存储器双字操作数.段间间接转移只能通过存储器操作数来实现.
<h3 style="color: blue;">JC</h3>
条件转移指令 JC

格式: JC 标号

功能: CF＝1,转至标号处执行

说明: JC为根据标志位CF进行转移的指令
<h3 style="color: blue;">JNC</h3>
条件转移指令JNC

格式: JNC标号

功能: CF＝0,转至标号处执行

说明: JNC为根据标志位CF进行转移的指令
<h3 style="color: blue;">JE</h3>
条件转移指令JE/JZ

格式: JE/JZ标号

功能: ZF＝1,转至标号处执

说明:

1. 指令JE与JZ等价,它们是根据标志位ZF进行转移的指令

2. JE,JZ均为一条指令的两种助记符表示方法
<h3 style="color: blue;">JZ</h3>
条件转移指令JE/JZ

格式: JE/JZ标号

功能: ZF＝1,转至标号处执

说明:

1. 指令JE与JZ等价,它们是根据标志位ZF进行转移的指令

2. JE,JZ均为一条指令的两种助记符表示方法
<h3 style="color: blue;">JNE</h3>
条件转移指令JNE/JNZ

格式: JNE/JNZ 标号

功能: ZF＝0,转至标号处执行

说明:

1. 指令JNE与JNZ等价,它们是根据标志位ZF进行转移的指令

2. JNE,JNZ均为一条指令的两种助记符表示方法
<h3 style="color: blue;">JNZ</h3>
条件转移指令JNE/JNZ

格式: JNE/JNZ 标号

功能: ZF＝0,转至标号处执行

说明:

1. 指令JNE与JNZ等价,它们是根据标志位ZF进行转移的指令

2. JNE,JNZ均为一条指令的两种助记符表示方法
<h3 style="color: blue;">JS</h3>
条件转移指令JS

格式: JS 标号

功能: SF＝1,转至标号处执行

说明: JS是根据符号标志位SF进行转移的指令
<h3 style="color: blue;">JNS</h3>
条件转移指令JNS

格式: JNS 标号

功能: SF＝0,转至标号处执行

说明: JNS是根据符号标志位SF进行转移的指令
<h3 style="color: blue;">JO</h3>
条件转移指令JO

格式: JO 标号

功能: OF＝1,转至标号处执行

说明: JO是根椐溢出标志位OF进行转移的指令
<h3 style="color: blue;">JNO</h3>
条件转移指令JNO

格式: JNO 标号

功能: OF＝0,转至标号处执行

说明: JNO是根椐溢出标志位OF进行转移的指令
<h3 style="color: blue;">JP</h3>
条件转移指令JP/JPE

格式: JP/JPE 标号

功能: PF＝1,转至标号处执行

说明:

1. 指令JP与JPE,它们是根据奇偶标志位PF进行转移的指令

2. JP,JPE均为一条指令的两种助记符表示方法
<h3 style="color: blue;">JPE</h3>
条件转移指令JP/JPE

格式: JP/JPE 标号

功能: PF＝1,转至标号处执行

说明:

1. 指令JP与JPE,它们是根据奇偶标志位PF进行转移的指令

2. JP,JPE均为一条指令的两种助记符表示方法
<h3 style="color: blue;">JNP</h3>
条件转移指令JNP/JPO

格式: JNP/JPO 标号

功能: PF＝0,转至标号处执行

说明:

1. 指令JNP与JPO,它们是根据奇偶标志位PF进行转移的指令

2. JNP,JPO均为一条指令的两种助记符表示方法
<h3 style="color: blue;">JPO</h3>
条件转移指令JNP/JPO

格式: JNP/JPO 标号

功能: PF＝0,转至标号处执行

说明:

1. 指令JNP与JPO,它们是根据奇偶标志位PF进行转移的指令

2. JNP,JPO均为一条指令的两种助记符表示方法
<h3 style="color: blue;">JA</h3>
条件转移指令JA/JNBE

格式: JA/JNBE标号

功能: 为高于/不低于等于的转移指令

说明:

1. 例如两个符号数a,b比较时,a&#62;b(即CF=0,ZF=0)时转移.因为单一标志位CF=0,只表示a&#62;=b.

2. JA/JNBE是同一条指令的两种不同的助记符.

3. 该指令用于无符号数进行条件转移
<h3 style="color: blue;">JNBE</h3>
条件转移指令JA/JNBE

格式: JA/JNBE标号

功能: 为高于/不低于等于的转移指令

说明:

1. 例如两个符号数a,b比较时,a&#62;b(即CF=0,ZF=0)时转移.因为单一标志位CF=0,只表示a&#62;=b.

2. JA/JNBE是同一条指令的两种不同的助记符.

3. 该指令用于无符号数进行条件转移
<h3 style="color: blue;">JAE</h3>
条件转移指令JAE/JNB

格式: JAE/JNB 标号

功能: 为高于等于/不低于的转移指令

说明:

1. JAE/JNB是同一条指令的两种不同的助记符.

2. 该指令用于无符号数进行条件转移.
<h3 style="color: blue;">JNB</h3>
条件转移指令JAE/JNB

格式: JAE/JNB 标号

功能: 为高于等于/不低于的转移指令

说明:

1. JAE/JNB是同一条指令的两种不同的助记符.

2. 该指令用于无符号数进行条件转移.
<h3 style="color: blue;">JB</h3>
条件转移指令JB/JNAE

格式: JB/JNAE 标号

功能: 低于/不高于等于时转移

说明: 该指令用于无符号数的条件转移
<h3 style="color: blue;">JNAE</h3>
条件转移指令JB/JNAE

格式: JB/JNAE 标号

功能: 低于/不高于等于时转移

说明: 该指令用于无符号数的条件转移
<h3 style="color: blue;">JBE</h3>
条件转移指令JBE/JNA

格式: JBE/JNA 标号

功能: 低于等于/不高于时转移

说明: 该指令用于无符号数的条件转移
<h3 style="color: blue;">JNA</h3>
条件转移指令JBE/JNA

格式: JBE/JNA 标号

功能: 低于等于/不高于时转移

说明: 该指令用于无符号数的条件转移
<h3 style="color: blue;">JG</h3>
条件转移指令JG/JNLE

格式: JG/JNLE 标号

功能: 大于/不小于等于时转移

说明: 用于带符号数的条件转移指令
<h3 style="color: blue;">JNLE</h3>
条件转移指令JG/JNLE

格式: JG/JNLE 标号

功能: 大于/不小于等于时转移

说明: 用于带符号数的条件转移指令
<h3 style="color: blue;">JGE</h3>
条件转移指令JGE/JNL

格式: JGE/JNL标号

功能: 大于等于/不小于时转移

说明: 用于带符号数的条件转移指令
<h3 style="color: blue;">JNL</h3>
条件转移指令JGE/JNL

格式: JGE/JNL标号

功能: 大于等于/不小于时转移

说明: 用于带符号数的条件转移指令
<h3 style="color: blue;">JL</h3>
条件转移指令JL/JNGE

格式: JL/JNGE标号

功能: 小于/不大于等于时转移

说明: 用于带符号数的条件转移指令
<h3 style="color: blue;">JNGE</h3>
条件转移指令JL/JNGE

格式: JL/JNGE标号

功能: 小于/不大于等于时转移

说明: 用于带符号数的条件转移指令
<h3 style="color: blue;">JLE</h3>
条件转移指令JLE/JNG

格式: JLE/JNG 标号

功能: 小于等于/不大于时转移

说明: 用于带符号数的条件转移指令
<h3 style="color: blue;">JNG</h3>
条件转移指令JLE/JNG

格式: JLE/JNG 标号

功能: 小于等于/不大于时转移

说明: 用于带符号数的条件转移指令
<h3 style="color: blue;">LOOP</h3>
循环控制指令LOOP

格式: LOOP 标号

功能: (CX)&#60;--(CX)-1,(CX)&#60;&#62;0,则转移至标号处循环执行, 直至(CX)=0,继续执行后继指令.

说明:

1. 本指令是用CX寄存器作为计数器,来控制程序的循环.

2. 它属于段内SHORT短类型转移,目的地址必须距本指令在-128到+127个字节的范围内.
<h3 style="color: blue;">LOOPZ</h3>
循环控制指令LOOPZ/LOOPE

格式: LOOPZ/LOOPE 标号

功能: (CX)&#60;--(CX)-1,(CX)&#60;&#62;0 且ZF＝1时,转至标号处循环

说明:

1. 本指令是用CX寄存器作为计数器,来控制程序的循环.

2. 它属于段内SHORT短类型转移,目的地址必须距本指令在-128到+127个字节的范围内.

3. 以上两种助记符等价.
<h3 style="color: blue;">LOOPE</h3>
循环控制指令LOOPZ/LOOPE

格式: LOOPZ/LOOPE 标号

功能: (CX)&#60;--(CX)-1,(CX)&#60;&#62;0 且ZF＝1时,转至标号处循环

说明:

1. 本指令是用CX寄存器作为计数器,来控制程序的循环.

2. 它属于段内SHORT短类型转移,目的地址必须距本指令在-128到+127个字节的范围内.

3. 以上两种助记符等价.
<h3 style="color: blue;">LOOPNZ</h3>
循环控制指令LOOPNZ/LOOPNE

格式: LOOPNZ/LOOPNE 标号

功能: (CX)&#60;--(CX)-1,(CX)&#60;&#62;0 且ZF＝0时,转至标号处循环

说明:

1. 本指令是用CX寄存器作为计数器,来控制程序的循环.

2. 它属于段内SHORT短类型转移,目的地址必须距本指令在-128到+127个字节的范围内.

3. 以上两种助记符等价.
<h3 style="color: blue;">LOOPNE</h3>
循环控制指令LOOPNZ/LOOPNE

格式: LOOPNZ/LOOPNE 标号

功能: (CX)&#60;--(CX)-1,(CX)&#60;&#62;0 且ZF＝0时,转至标号处循环

说明:

1. 本指令是用CX寄存器作为计数器,来控制程序的循环.

2. 它属于段内SHORT短类型转移,目的地址必须距本指令在-128到+127个字节的范围内.

3. 以上两种助记符等价.
<h3 style="color: blue;">CALL</h3>
过程调用指令 CALL

格式: CALL OPRD

功能: 过程调用指令

说明:

1. 其中OPRD为过程的目的地址.

2. 过程调用可分为段内调用和段间调用两种.寻址方式也可以分为直接寻址和间接寻址两种.

3. 本指令不影响标志位.
<h3 style="color: blue;">RET</h3>
返回指令 RET

格式: RET

功能: 当调用的过程结束后实现从过程返回至原调用程序的下一条指令,本指令不影响标志位.

说明:

由于在过程定义时,已指明其近(NEAR)或远(FAR)的属性,所以RET指令根据段内调用与段间调用,执行不同的操作

对段内调用: 返回时,由堆栈弹出一个字的返回地址的段内偏移量至IP.

对段外调用: 返回时,由堆栈弹出的第一个字为返回地址的段内偏移量,将其送入IP中,由堆栈弹出第二个字为返回地址的段基址,将其送入CS中.
<h3 style="color: blue;">MOVS</h3>
字符串传送指令 MOVS

格式: MOVS OPRD1,OPRD2
MOVSB
MOVSW

功能: OPRD1&#60;--OPRD2.

说明:

1. 其中OPRD2为源串符号地址,OPRD1为目的串符号地址.

2. 字节串操作: 若DF=0,则作加, 若DF=1,则作减.

3. 对字串操作时: 若DF=0,则作加,若DF=1,则作减,.

4. 在指令中不出现操作数时,字节串传送格式为MOVSB、字串传送格式为MOVSW.

5. 本指令不影响标志位.
<h3 style="color: blue;">MOVSB</h3>
字符串传送指令 MOVS

格式: MOVS OPRD1,OPRD2
MOVSB
MOVSW

功能: OPRD1&#60;--OPRD2.

说明:

1. 其中OPRD2为源串符号地址,OPRD1为目的串符号地址.

2. 字节串操作: 若DF=0,则作加, 若DF=1,则作减.

3. 对字串操作时: 若DF=0,则作加,若DF=1,则作减,.

4. 在指令中不出现操作数时,字节串传送格式为MOVSB、字串传送格式为MOVSW.

5. 本指令不影响标志位.
<h3 style="color: blue;">MOVSW</h3>
字符串传送指令 MOVS

格式: MOVS OPRD1,OPRD2
MOVSB
MOVSW

功能: OPRD1&#60;--OPRD2.

说明:

1. 其中OPRD2为源串符号地址,OPRD1为目的串符号地址.

2. 字节串操作: 若DF=0,则作加, 若DF=1,则作减.

3. 对字串操作时: 若DF=0,则作加,若DF=1,则作减,.

4. 在指令中不出现操作数时,字节串传送格式为MOVSB、字串传送格式为MOVSW.

5. 本指令不影响标志位.
<h3 style="color: blue;">CMPS</h3>
字符串比较指令

格式: CMPS OPRD1,OPRD2
CMPSB
CMPSW

功能: 由SI寻址的源串中数据与由DI寻址的目的串中数据进行比较,比较结果送标志位,而不改变操作数本身.
同时SI,DI将自动调整.

说明:

1. 其中OPRD2为源串符号地址,OPRD1为目的串符号地址.

2. 本指令影响标志位AF、CF、OF、SF、PF、ZF.本指令可用来检查二个字符串是否相同,可以使用循环控制方法对整串进行比较.

3. 与MOVS相似,CMPS指令也可以不使用操作数,此时可用指令CMPSB或CMPSW分别表示字节串比较或字串比较.
<h3 style="color: blue;">CMPSB</h3>
字符串比较指令

格式: CMPS OPRD1,OPRD2
CMPSB
CMPSW

功能: 由SI寻址的源串中数据与由DI寻址的目的串中数据进行比较,比较结果送标志位,而不改变操作数本身.
同时SI,DI将自动调整.

说明:

1. 其中OPRD2为源串符号地址,OPRD1为目的串符号地址.

2. 本指令影响标志位AF、CF、OF、SF、PF、ZF.本指令可用来检查二个字符串是否相同,可以使用循环控制方法对整串进行比较.

3. 与MOVS相似,CMPS指令也可以不使用操作数,此时可用指令CMPSB或CMPSW分别表示字节串比较或字串比较.
<h3 style="color: blue;">CMPSW</h3>
字符串比较指令

格式: CMPS OPRD1,OPRD2
CMPSB
CMPSW

功能: 由SI寻址的源串中数据与由DI寻址的目的串中数据进行比较,比较结果送标志位,而不改变操作数本身.
同时SI,DI将自动调整.

说明:

1. 其中OPRD2为源串符号地址,OPRD1为目的串符号地址.

2. 本指令影响标志位AF、CF、OF、SF、PF、ZF.本指令可用来检查二个字符串是否相同,可以使用循环控制方法对整串进行比较.

3. 与MOVS相似,CMPS指令也可以不使用操作数,此时可用指令CMPSB或CMPSW分别表示字节串比较或字串比较.
<h3 style="color: blue;">SCAS</h3>
字符串搜索指令 SCAS

格式: SCAS OPRD
SCASB
SCASW

功能: 把AL(字节串)或AX(字串)的内容与由DI寄存器寻址的目的串中的数据相减,结果置标志位,但不改变任一操作数本身.

地址指针DI自动调整.

说明:

1. 其中OPRD为目的串符号地址.

2. 本指令影响标志AF、CF、OF、PF、SF、ZF.该指令可查找字符串中的一个关键字,只需在本指令执行前,

把关键字放在AL(字节)或AX(字串 )中,用重复前缀可在整串中查找.

指令中不使用操作数时,可用指令格式SCASB,SCASW,分别表示字节串或字串搜索指令.
<h3 style="color: blue;">SCASB</h3>
字符串搜索指令 SCAS

格式: SCAS OPRD
SCASB
SCASW

功能: 把AL(字节串)或AX(字串)的内容与由DI寄存器寻址的目的串中的数据相减,结果置标志位,但不改变任一操作数本身.

地址指针DI自动调整.

说明:

1. 其中OPRD为目的串符号地址.

2. 本指令影响标志AF、CF、OF、PF、SF、ZF.该指令可查找字符串中的一个关键字,只需在本指令执行前,

把关键字放在AL(字节)或AX(字串 )中,用重复前缀可在整串中查找.

指令中不使用操作数时,可用指令格式SCASB,SCASW,分别表示字节串或字串搜索指令.
<h3 style="color: blue;">SCASW</h3>
字符串搜索指令 SCAS

格式: SCAS OPRD
SCASB
SCASW

功能: 把AL(字节串)或AX(字串)的内容与由DI寄存器寻址的目的串中的数据相减,结果置标志位,但不改变任一操作数本身.

地址指针DI自动调整.

说明:

1. 其中OPRD为目的串符号地址.

2. 本指令影响标志AF、CF、OF、PF、SF、ZF.该指令可查找字符串中的一个关键字,只需在本指令执行前,

把关键字放在AL(字节)或AX(字串 )中,用重复前缀可在整串中查找.

指令中不使用操作数时,可用指令格式SCASB,SCASW,分别表示字节串或字串搜索指令.
<h3 style="color: blue;">LODS</h3>
取字符串元素指令 LODS

格式: LODS OPRD 其中OPRD为源字符串符号地址.

功能: 把SI寻址的源串的数据字节送AL或数据字送AX中去, 并根据DF的值修改地址指针SI进行自动调整.

说明:

1. 本指令不影响标志位.

2. 当不使用操作数时,可用LODS(字节串)或LODSW(字串)指令.
<h3 style="color: blue;">STOS</h3>
字符串存储指令 STOS

格式: STOS OPRD

功能: 把AL(字节)或AX(字)中的数据存储到DI为目的串地址指针所寻址的存储器单元中去.指针DI将根据DF的值进行自动调整.

说明:

1. 其中OPRD为目的串符号地址.

2. 本指令不影响标志位.当不使用操作数时,可用STOSB或STOSW分别表示字节串或字串的操作.
<h3 style="color: blue;">REP</h3>
重复前缀的说明

格式: REP ;CX&#60;&#62;0 重复执行字符串指令
REPZ/REPE ;CX&#60;&#62;0 且ZF＝1重复执行字符串指令
REPNZ/REPNE ;CX&#60;&#62;0 且ZF＝0重复执行字符串指令

功能: 在串操作指令前加上重复前缀,可以对字符串进重复处理.由于加上重复前缀后,对应的指令代码是不同的,所以指令的功能便具有重复处理的功能,重复的次数存放在CX寄存器中.

说明:

1. REP与MOVS或STOS串操作指令相结合使用,完成一组字符的传送或建立一组相同数据的字符串.

2. REPZ/REPE常用与CMPS串操作指令结合使用, 可以完成两组字符串的比较.

3. REPZ/REPE常与SCAS指令结合使用,可以完成在一个字符串中搜索一个关键字.

4. REPNZ/REPNE与CMPS指令结合使用,表示当串未结束(CX=1)且当对应串元素不相同(ZF=0)时,继续重复执行串比较指令.
<h3 style="color: blue;">REPZ</h3>
重复前缀的说明

格式: REP ;CX&#60;&#62;0 重复执行字符串指令
REPZ/REPE ;CX&#60;&#62;0 且ZF＝1重复执行字符串指令
REPNZ/REPNE ;CX&#60;&#62;0 且ZF＝0重复执行字符串指令

功能: 在串操作指令前加上重复前缀,可以对字符串进重复处理.由于加上重复前缀后,对应的指令代码是不同的,所以指令的功能便具有重复处理的功能,重复的次数存放在CX寄存器中.

说明:

1. REPZ/REPE常用与CMPS串操作指令结合使用, 可以完成两组字符串的比较.

2. REPZ/REPE常与SCAS指令结合使用,可以完成在一个字符串中搜索一个关键字.

3. REPNZ/REPNE与CMPS指令结合使用,表示当串未结束(CX=1)且当对应串元素不相同(ZF=0)时,继续重复执行串比较指令.

4. REPNZ/REPNE与SCAS指令结合使用,表示串未结束(CX=1)且当关键字与串元素不相同(ZF=0)时,继续重复执行串搜索指令.
<h3 style="color: blue;">REPE</h3>
重复前缀的说明

格式: REP ;CX&#60;&#62;0 重复执行字符串指令
REPZ/REPE ;CX&#60;&#62;0 且ZF＝1重复执行字符串指令
REPNZ/REPNE ;CX&#60;&#62;0 且ZF＝0重复执行字符串指令

功能: 在串操作指令前加上重复前缀,可以对字符串进重复处理.由于加上重复前缀后,对应的指令代码是不同的,所以指令的功能便具有重复处理的功能,重复的次数存放在CX寄存器中.

说明:

1. REPZ/REPE常用与CMPS串操作指令结合使用, 可以完成两组字符串的比较.

2. REPZ/REPE常与SCAS指令结合使用,可以完成在一个字符串中搜索一个关键字.

3. REPNZ/REPNE与CMPS指令结合使用,表示当串未结束(CX=1)且当对应串元素不相同(ZF=0)时,继续重复执行串比较指令.

4. REPNZ/REPNE与SCAS指令结合使用,表示串未结束(CX=1)且当关键字与串元素不相同(ZF=0)时,继续重复执行串搜索指令.
<h3 style="color: blue;">REPNZ</h3>
重复前缀的说明

格式: REP ;CX&#60;&#62;0 重复执行字符串指令
REPZ/REPE ;CX&#60;&#62;0 且ZF＝1重复执行字符串指令
REPNZ/REPNE ;CX&#60;&#62;0 且ZF＝0重复执行字符串指令

说明:

1. REPZ/REPE常用与CMPS串操作指令结合使用, 可以完成两组字符串的比较.

2. REPZ/REPE常与SCAS指令结合使用,可以完成在一个字符串中搜索一个关键字.

3. REPNZ/REPNE与CMPS指令结合使用,表示当串未结束(CX=1)且当对应串元素不相同(ZF=0)时,继续重复执行串比较指令.

4. REPNZ/REPNE与SCAS指令结合使用,表示串未结束(CX=1)且当关键字与串元素不相同(ZF=0)时,继续重复执行串搜索指令.
<h3 style="color: blue;">REPNE</h3>
重复前缀的说明

格式: REP ;CX&#60;&#62;0 重复执行字符串指令
REPZ/REPE ;CX&#60;&#62;0 且ZF＝1重复执行字符串指令
REPNZ/REPNE ;CX&#60;&#62;0 且ZF＝0重复执行字符串指令

说明:

1. REPZ/REPE常用与CMPS串操作指令结合使用, 可以完成两组字符串的比较.

2. REPZ/REPE常与SCAS指令结合使用,可以完成在一个字符串中搜索一个关键字.

3. REPNZ/REPNE与CMPS指令结合使用,表示当串未结束(CX=1)且当对应串元素不相同(ZF=0)时,继续重复执行串比较指令.

4. REPNZ/REPNE与SCAS指令结合使用,表示串未结束(CX=1)且当关键字与串元素不相同(ZF=0)时,继续重复执行串搜索指令.
<h3 style="color: blue;">CLC</h3>
处理器控制指令－标志位操作指令

格式:
CLC ;置CF=0
STC ;置CF=1
CMC ;置CF=(Not CF)进位标志求反
CLD ;置DF=0
STD ;置DF＝1
CLI ;置IF=0，CPU禁止响应外部中断
STI ;置IF=1，使CPU允许向应外部中断

功能: 完成对标志位的置位、复位等操作.

说明: 例如串操作中的程序,经常用CLD指令清方向标志使DF＝0,在串操作指令执行时,按增量的方式修改吕指针.
<h3 style="color: blue;">STC</h3>
处理器控制指令－标志位操作指令

格式:
CLC ;置CF=0
STC ;置CF=1
CMC ;置CF=(Not CF)进位标志求反
CLD ;置DF=0
STD ;置DF＝1
CLI ;置IF=0，CPU禁止响应外部中断
STI ;置IF=1，使CPU允许向应外部中断

功能: 完成对标志位的置位、复位等操作.

说明: 例如串操作中的程序,经常用CLD指令清方向标志使DF＝0,在串操作指令执行时,按增量的方式修改吕指针.
<h3 style="color: blue;">CMC</h3>
处理器控制指令－标志位操作指令

格式:
CLC ;置CF=0
STC ;置CF=1
CMC ;置CF=(Not CF)进位标志求反
CLD ;置DF=0
STD ;置DF＝1
CLI ;置IF=0，CPU禁止响应外部中断
STI ;置IF=1，使CPU允许向应外部中断

功能: 完成对标志位的置位、复位等操作.

说明: 例如串操作中的程序,经常用CLD指令清方向标志使DF＝0,在串操作指令执行时,按增量的方式修改吕指针.
<h3 style="color: blue;">CLD</h3>
处理器控制指令－标志位操作指令

格式:
CLC ;置CF=0
STC ;置CF=1
CMC ;置CF=(Not CF)进位标志求反
CLD ;置DF=0
STD ;置DF＝1
CLI ;置IF=0，CPU禁止响应外部中断
STI ;置IF=1，使CPU允许向应外部中断

功能: 完成对标志位的置位、复位等操作.

说明: 例如串操作中的程序,经常用CLD指令清方向标志使DF＝0,在串操作指令执行时,按增量的方式修改吕指针.
<h3 style="color: blue;">STD</h3>
处理器控制指令－标志位操作指令

格式:
CLC ;置CF=0
STC ;置CF=1
CMC ;置CF=(Not CF)进位标志求反
CLD ;置DF=0
STD ;置DF＝1
CLI ;置IF=0，CPU禁止响应外部中断
STI ;置IF=1，使CPU允许向应外部中断

功能: 完成对标志位的置位、复位等操作.

说明: 例如串操作中的程序,经常用CLD指令清方向标志使DF＝0,在串操作指令执行时,按增量的方式修改吕指针.
<h3 style="color: blue;">CLI</h3>
处理器控制指令－标志位操作指令

格式:
CLC ;置CF=0
STC ;置CF=1
CMC ;置CF=(Not CF)进位标志求反
CLD ;置DF=0
STD ;置DF＝1
CLI ;置IF=0，CPU禁止响应外部中断
STI ;置IF=1，使CPU允许向应外部中断

功能: 完成对标志位的置位、复位等操作.

说明: 例如串操作中的程序,经常用CLD指令清方向标志使DF＝0,在串操作指令执行时,按增量的方式修改吕指针.
<h3 style="color: blue;">STI</h3>
处理器控制指令－标志位操作指令

格式:
CLC ;置CF=0
STC ;置CF=1
CMC ;置CF=(Not CF)进位标志求反
CLD ;置DF=0
STD ;置DF＝1
CLI ;置IF=0，CPU禁止响应外部中断
STI ;置IF=1，使CPU允许向应外部中断

功能: 完成对标志位的置位、复位等操作.

说明: 例如串操作中的程序,经常用CLD指令清方向标志使DF＝0,在串操作指令执行时,按增量的方式修改吕指针.
<h3 style="color: blue;">HLT</h3>
处理器暂停指令 HLT

格式: HLT

功能: 使处理器处于暂时停机状态.

说明:

1. 本指令不影响标志位.

2. 由执行HLT引起的暂停,只有RESET(复位)、NMI(非屏蔽中断请求)、INTR(可屏蔽的外部中断请求)信号可以使

其退出暂停状态.它可用于等待中断的到来或多机系统的同步操作.
<h3 style="color: blue;">WAIT</h3>
处理器等待指令 WAIT

格式: WAIT

功能: 本指令将使处理器检测TEST端脚,当TEST有效时,则退出等待状态执行下条指令,否则处理器处于等待状态,直到TEST有效.

说明: 本指令不影响标志位.
<h3 style="color: blue;">ESC</h3>
处理器交权指令 ESC

格式: ESC EXTOPRD,OPRD

功能: 使用本指令可以实现协处理器出放在ESC指令代码中的6位常数,该常数指明协处理器要完成的功能.

当源操作数为存储器变量时,则取出该存储器操作数传送给协处理器.

说明:

1. 其中EXTOPRD为外部操作码,OPRD为源操作数.

2. 本指不影响标志位.
<h3 style="color: blue;">NOP</h3>
空操作指令 NOP

格式: NOP

功能: 本指令不产生任何结果,仅消耗几个时钟周期的时间,接着执行后续指令,常用于程序的延时等.

说明: 本指令不影响标志位.
<h3 style="color: blue;">LOCK</h3>
封锁总线指令 LOCK

格式: LOCK

功能: 指令是一个前缀,可放在指令的前面,告诉CPU在执行该指令时,不允许其它设备对总线进行访问.

无可用信息!用户可自行添加!
<h3 style="color: blue;">IN</h3>
输入指令 IN

格式: IN AL,n ;(AL)&#60;--(n)
IN AX,n ;(AX)&#60;--(n+1),(n)
IN AL,DX ;(AL)&#60;--[(DX)]
IN AX,DX ;(AX)&#60;--[(DX)+1],[(DX)]

功能: 输入指令

说明:

1. 其中n为8位的端口地址,当字节输入时,将端口地址n+1的内容送至AH中,端口地址n的内容送AL中.

2. 端口地址也可以是16位的,但必须将16位的端口地址送入DX中.当字节寻址时,由DX内容作端口地址的内容送至AL中;

当输入数据字时,[(DX)+1]送AH,[(DX)]送AL中,用符号:(AX)&#60;--[(DX)+1],[(DX)]表示.
<h3 style="color: blue;">OUT</h3>
输出指令 OUT

格式: OUT n,AL ;(n)&#60;--(AL)

功能: 输出指令

说明:

1. OUT n,AX ;(n+1),(n)&#60;--(AX)
OUT DX,AL ;[(DX)]&#60;--(AL)
OUT DX,AX ;[(DX)+1],[(DX)]&#60;--(AX)

2. 输入指令及输出指令对标志位都不影响.
<h3 style="color: blue;">INTO</h3>
溢出中断指令 INTO(INTerrupt if Overflow)

格式: INTO

功能: 本指令检测OF标志位,当OF=1时,说明已发生溢出,立即产生一个中断类型4的中断,当OF＝0时,本指令不起作用.

说明:

1. 本指令影响标志位IF及TF.

2. 本指令可用于溢出处理,当OF=1时,产生一个类型4的软中断.在中断处理程序中完成溢出的处理操作.
<h3 style="color: blue;">INT</h3>
软中断指令 INT

格式: INT n 其中n为软中断的类型号.

功能: 本指令将产生一个软中断,把控制转向一个类型号为n的软中断,该中断处理程序入口地址在中断向量表的n*4地址

处的二个存储器字(4个单元)中.

说明: 操作过程与INTO指令雷同,只需将10H改为n*4即可.所以,本指令也将影响标志位IF及TF.
<h3 style="color: blue;">IRET</h3>
中断返回指令 IRET

格式: IRET

功能: 用于中断处理程序中,从中断程序的断点处返回,继续执行原程序.

说明:

1. 本指令将影响所有标志位.

2. 无论是软中断,还是硬中断,本指令均可使其返回到中断程序的断点处继续执行原程序.]]></description>
		<wfw:commentRss>http://www.opzn.org/archives/908/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>简简单单</title>
		<link>http://www.opzn.org/archives/846</link>
		<comments>http://www.opzn.org/archives/846#comments</comments>
		<pubDate>Mon, 13 Jun 2011 17:09:46 +0000</pubDate>
		<dc:creator>温 云龙</dc:creator>
				<category><![CDATA[Life]]></category>

		<guid isPermaLink="false">http://www.opzn.org/?p=846</guid>
		<description><![CDATA[简简单单做人，简简单单生活。用心去对待身边每一个真心的朋友，不管明天我们在那里，都不会忘记曾经一起的记忆。生活总是这样不停的聚了散了，能留下的都只在心里，真心的期盼身边每一个朋友过得开心幸福。]]></description>
		<wfw:commentRss>http://www.opzn.org/archives/846/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>开发目录清理脚本</title>
		<link>http://www.opzn.org/archives/837</link>
		<comments>http://www.opzn.org/archives/837#comments</comments>
		<pubDate>Fri, 10 Jun 2011 10:13:18 +0000</pubDate>
		<dc:creator>温 云龙</dc:creator>
				<category><![CDATA[Develop]]></category>

		<guid isPermaLink="false">http://www.opzn.org/?p=837</guid>
		<description><![CDATA[<pre lang="bash" line="1">
#!/bin/sh

function usage() {
    echo "usage: <source dir>"
}

if [ $ARGC != 1 ] &#124;&#124; [ -d $1 ];then
    usage
    exit
fi

DIR=$1

for i in `find $DIR -type f -name '*.log'`;do rm -f $i;done
for i in `find $DIR -type f -name '*.o'`;do rm -f $i;done
for i in `find $DIR -type f -name '*.a'`;do rm -f $i;done
for i in `find $DIR -type f -perm +100`;do rm $i;done
</pre>]]></description>
		<wfw:commentRss>http://www.opzn.org/archives/837/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>目录备份脚本</title>
		<link>http://www.opzn.org/archives/835</link>
		<comments>http://www.opzn.org/archives/835#comments</comments>
		<pubDate>Fri, 10 Jun 2011 10:12:08 +0000</pubDate>
		<dc:creator>温 云龙</dc:creator>
				<category><![CDATA[Develop]]></category>

		<guid isPermaLink="false">http://www.opzn.org/?p=835</guid>
		<description><![CDATA[备份执行目录到 BACKUP_DIR, 压缩文件名为 目录名+'_'+时间+'_'+随机数.tar.gz
<pre lang="bash" line="1">
#!/bin/sh
PWD=`pwd`
ARGC=$#
BDIR=$BACKUP_DIR

function usage() {
    echo "usage: <source dir> <backup dir>"
}

if [ $ARGC != 1 ] &#038;& [ $ARGC != 2 ];then
    usage
    exit
fi

if [ $ARGC == 1 ] &#038;& [ "$BDIR" == '' ];then
    usage
    exit
fi

if [ $ARGC == 2 ];then
    BDIR=$2
fi

if ! [ -d $BDIR ];then
    echo "backup dir '$2' is not found"
    usage
    exit
fi

if ! [ -d $1 ];then
    echo "source dir '$1' is not found"
    usage
    exit
fi

LAST=`echo $BDIR &#124; awk -F/ '{print $(NF)}'`
EXT=`date +'%Y%m%d%H%M%S-%s'`
NAME=`echo $1 &#124; awk -F/ '{print $(NF)}'`
if [ "$NAME" == '' ];then
    NAME=`echo $1 &#124; awk -F/ '{print $(NF-1)}'`
fi

if [ "$LAST" == '' ];then
    FILE="$BDIR$NAME-$EXT.tar.gz"
else
    FILE="$BDIR/$NAME-$EXT.tar.gz"
fi

cd $1
cd ..

tar -cvzf $FILE ./$NAME

echo ""
echo "backup $1 to $FILE success"
</pre>]]></description>
		<wfw:commentRss>http://www.opzn.org/archives/835/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>IPV6地址类型</title>
		<link>http://www.opzn.org/archives/832</link>
		<comments>http://www.opzn.org/archives/832#comments</comments>
		<pubDate>Fri, 10 Jun 2011 08:05:41 +0000</pubDate>
		<dc:creator>温 云龙</dc:creator>
				<category><![CDATA[Develop]]></category>

		<guid isPermaLink="false">http://www.opzn.org/?p=832</guid>
		<description><![CDATA[IN6_IS_ADDR_UNSPECIFIED //未指定地址
IN6_IS_ADDR_LOOPBACK //环回地址
IN6_IS_ADDR_LINKLOCAL //单播链路本地地址
IN6_IS_ADDR_SITELOCAL //单播站点本地地址
IN6_IS_ADDR_V4MAPPED  //映射的IPv4地址
IN6_IS_ADDR_V4COMPAT  //IPv4兼容地址
IN6_IS_ADDR_MC_NODELOCAL //组播节点本地地址
IN6_IS_ADDR_MC_LINKLOCAL //组播链路本地地址
IN6_IS_ADDR_MC_SITELOCAL //组播站点本地地址
IN6_IS_ADDR_MC_ORGLOCAL //组播组织本地地址
IN6_IS_ADDR_MC_GLOBAL //全球多播地址]]></description>
		<wfw:commentRss>http://www.opzn.org/archives/832/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>根据UDP数据包不可达的ICMP回应追踪网络路由</title>
		<link>http://www.opzn.org/archives/817</link>
		<comments>http://www.opzn.org/archives/817#comments</comments>
		<pubDate>Thu, 09 Jun 2011 00:01:30 +0000</pubDate>
		<dc:creator>温 云龙</dc:creator>
				<category><![CDATA[Develop]]></category>

		<guid isPermaLink="false">http://www.opzn.org/?p=817</guid>
		<description><![CDATA[在发送UDP数据包（保证UDP端口在目标没有监听）的之前递增的设置TTL，UDP途径的路由将TTL减1，当TTL为0时或目标服务器UDP端口没有监听，路由向UDP包发送方返回一个type=11（请求的服务或网络不可达）的ICMP回应包。<!--more-->

C源代码
<pre lang="c" line="1">
/* 
 * 根据UDP数据包不可达的ICMP回应追踪网络路由
 * Auther: WenYunlong
 */
#include <stdio.h>
#include <string.h>
#include <fcntl.h>
#include <errno.h>
#include <sys/socket.h>
#include <netinet/udp.h>
#include <arpa/inet.h>
#include <netinet/ip_icmp.h>

/*两个timeval结构相减*/
double tvsub(register struct timeval *out, register struct timeval *in)
{
    double usec = out->tv_usec - in->tv_usec;
    double sec = out->tv_sec;
	if (usec < 0) {
        sec--;
		usec += 1000000;
	}
    sec -= in->tv_sec;

	return sec * 1000.0f + usec/1000.0f;
}

int main(int argc, char *args[]) {
    int icmp_fd, udp_fd;
    char *ipaddr, buf[1024]; /* 需要追踪的IP地址*/

    if(argc != 2) {
        printf("trace <ipaddr>\n");
    }
    ipaddr = args[1];

    /* 创建用于接收ICMP封包的原始套节字，绑定到本地端口 */
	icmp_fd = socket(AF_INET, SOCK_RAW, IPPROTO_ICMP);
    if(icmp_fd < 0) {
        fprintf(stderr, "create icmp socket failure : %s\n", strerror(errno));
        return 0;
    }
    
    struct timeval tv;
    tv.tv_sec = 3;
    tv.tv_usec = 0;
    if(setsockopt(icmp_fd, SOL_SOCKET, SO_RCVTIMEO, (char *)&#038;tv, sizeof(tv))) {
        fprintf(stderr, "set icmp socket timeout failure : %s\n", strerror(errno));
        close(icmp_fd);
        return 0;
    }

	struct sockaddr_in local;
	local.sin_family = AF_INET;
	local.sin_port = htons(0);
	local.sin_addr.s_addr = htons(INADDR_ANY);

    /* 帮定端口等待数据到来 */
	if(bind(icmp_fd, (struct sockaddr*)&#038;local, sizeof(local)) != 0)
	{
		fprintf(stderr, "bind icmp socket failure : %s\n", strerror(errno));
		close(icmp_fd);
        return 0;
	}


    int ttl, ret;
	struct icmp *icmp_hdr;
	struct sockaddr_in recv_addr;
    struct ip *ip_hdr;
    struct udphdr *udp_hdr;
    float time; struct timeval send_tval, recv_tval;
    char *p, fip[20],tip[20];
    
    /* 创建用于发送UDP封包的套节字 */
	udp_fd = socket(AF_INET, SOCK_DGRAM, 0);
	struct sockaddr_in udp_addr;
	udp_addr.sin_family = AF_INET;
	udp_addr.sin_port = htons(10000);
	udp_addr.sin_addr.s_addr = htons(INADDR_ANY);
    /* 帮定端口等待数据到来 */
	if(bind(udp_fd, (struct sockaddr*)&#038;udp_addr, sizeof(udp_addr)) != 0)
	{
		fprintf(stderr, "bind udp socket failure : %s\n", strerror(errno));
		close(icmp_fd);
        return 0;
	}

    int ok = 0;
    for(ttl=2;ttl<32;ttl++) {
        struct sockaddr_in dest;
	    dest.sin_family = AF_INET;
	    dest.sin_port = htons(33434+ttl);
	    dest.sin_addr.s_addr = inet_addr(ipaddr);

        if(setsockopt(udp_fd, IPPROTO_IP, IP_TTL, (char*)&#038;ttl, sizeof(ttl)) != 0) {
            close(icmp_fd);
            close(udp_fd);
            fprintf(stderr, "set socket ttl failure : %s\n", strerror(errno));
            return 0;
        }

        gettimeofday(&#038;send_tval, NULL);
        if(sendto(udp_fd, "AAAAAAAA", 8, 0, (struct sockaddr*)&#038;dest, sizeof(dest)) <= 0) {
            close(icmp_fd);
            close(udp_fd);
            fprintf(stderr, "send pakcet failure : %s\n", strerror(errno));
        }
        
        /* 等待接收路由器返回的ICMP报文 */
		int len = sizeof(recv_addr);
		ret = recvfrom(icmp_fd, buf, 1024, 0, (struct sockaddr*)&#038;recv_addr, &#038;len);
        if(ret < 0) {
            fprintf(stderr, "recv pakcet failure : %s\n", strerror(errno));
            break;
        }
        gettimeofday(&#038;recv_tval, NULL);

        /* 解析接收到的ICMP数据 */
        p = buf + sizeof(struct ip);
		icmp_hdr = (struct icmp*)p;

		if(icmp_hdr->icmp_type != 11 &#038;& icmp_hdr->icmp_type != 3)
		{
			fprintf(stderr, "unknow icmp type: %d , code: %d \n",
				icmp_hdr->icmp_type, icmp_hdr->icmp_code);
		} else {
			p = icmp_hdr->icmp_data;
            ip_hdr = (struct ip*)p;
            
            p +=  sizeof(struct ip);
            udp_hdr = (struct udphdr *)p;
            
            strcpy(fip, inet_ntoa(ip_hdr->ip_src));
            strcpy(tip, inet_ntoa(ip_hdr->ip_dst));

            ipaddr = inet_ntoa(recv_addr.sin_addr);
			printf("%d route addr : %s (%s:%d => %s:%d),use time %02f\n", ttl, ipaddr, 
                    fip, ntohs(udp_hdr->source), tip, ntohs(udp_hdr->dest), time);
		}
		if(dest.sin_addr.s_addr == recv_addr.sin_addr.s_addr) {
            ipaddr = inet_ntoa(recv_addr.sin_addr);
            ok = 1;
            break;
        }
    }
    if(ok) printf("%s success\n", ipaddr);
    else printf("%s timeout\n", ipaddr);
    close(icmp_fd);
    close(udp_fd);
    return 0;
}
</pre>]]></description>
		<wfw:commentRss>http://www.opzn.org/archives/817/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Debian6 国内比较快的源</title>
		<link>http://www.opzn.org/archives/811</link>
		<comments>http://www.opzn.org/archives/811#comments</comments>
		<pubDate>Wed, 08 Jun 2011 13:11:08 +0000</pubDate>
		<dc:creator>温 云龙</dc:creator>
				<category><![CDATA[Software]]></category>

		<guid isPermaLink="false">http://www.opzn.org/?p=811</guid>
		<description><![CDATA[deb http://mirrors.163.com/debian/ squeeze main contrib non-free

deb-src http://mirrors.163.com/debian squeeze main contrib non-free

deb http://ftp.cn.debian.org/debian-backports squeeze-backports main

deb-src http://ftp.cn.debian.org/debian-backports squeeze-backports main

deb http://mirrors.163.com/debian squeeze main

deb-src http://mirrors.163.com/debian squeeze main

deb http://mirrors.163.com/debian squeeze-updates main

deb-src http://mirrors.163.com/debian squeeze-updates main

deb http://security.debian.org/ squeeze/updates main

deb-src http://security.debian.org/ squeeze/updates main]]></description>
		<wfw:commentRss>http://www.opzn.org/archives/811/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>尘埃</title>
		<link>http://www.opzn.org/archives/797</link>
		<comments>http://www.opzn.org/archives/797#comments</comments>
		<pubDate>Sun, 22 May 2011 21:41:20 +0000</pubDate>
		<dc:creator>温 云龙</dc:creator>
				<category><![CDATA[Life]]></category>

		<guid isPermaLink="false">http://www.opzn.org/?p=797</guid>
		<description><![CDATA[<table cellspacing="0" cellpadding="0">
<tbody>
<tr>
<td valign="top">
<div>
<div>

我只是一粒尘埃，努力的沉浮在你的身边，等待着某个阴天，阳光穿过窗棂，好让我装点你的世界，也许你从来不曾留意，可这就是我那一世的修行<span style="font-size: 13px; line-height: 19px;">。</span>

</div>
</div></td>
</tr>
</tbody>
</table>
&#160;]]></description>
		<wfw:commentRss>http://www.opzn.org/archives/797/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
	</channel>
</rss>

<!-- Dynamic page generated in 2.047 seconds. -->
<!-- Cached page generated by WP-Super-Cache on 2012-01-29 08:34:31 -->

