《IT播吧.-.大灰狼老师出品的零基础汇编视频课程》学习笔记

为了更深入理解嵌入式汇编,了解下下面x86汇编

1、什么是计算机的数据总线(Date Bus)、地址总线(Address Bus)和控制总线(Control Bus)?

总线是将信息以一个或多个源部件传送到一个或多个目的部件的一组传输线。通俗的说,就是多个部件间的公共连线,用于在各个部件之间传输信息。 
系统总线上传送的信息包括数据信息、地址信息、控制信息,因此,系统总线包含有三种不同功能的总线,即数据总线DB(Data Bus)、地址总线AB(Address Bus)和控制总线CB(Control Bus) 
数据总线DB:用于传送数据信息。数据总线是双向三态形式的总线,即他既可以把CPU的数据传送到存储器或I/O接口等其它部件,也可以将其它部件的数据传送到CPU。数据总线的位数是微型计算机的一个重要指标,通常与微处理的字长相一致。例如Intel 8086微处理器字长16位,其数据总线宽度也是16位。需要指出的是,数据的含义是广义的,它可以是真正的数据,也可以指令代码或状态信息,有时甚至是一个控制信息,因此,在实际工作中,数据总线上传送的并不一定仅仅是真正意义上的数据。
地址总线AB:是专门用来传送地址的,由于地址只能从CPU传向外部存储器或I/O端口,所以地址总线总是单向三态的,这与数据总线不同。地址总线的位数决定了CPU可直接寻址的内存空间大小,比如8位微机的地址总线为16位,则其最大可寻址空间为2^16=64KB,16位微型机的地址总线为20位,其可寻址空间为2^20=1MB。一般来说,若地址总线为n位,则可寻址空间为2^n字节。

控制总线CB用来传送控制信号和时序信号。控制信号中,有的是微处理器送往存储器和I/O接口电路的,如读/写信号,片选信号、中断响应信号等;也有是其它部件反馈给CPU的,比如:中断申请信号、复位信号、总线请求信号、限备就绪信号等。因此,控制总线的传送方向由具体控制信号而定,一般是双向的,控制总线的位数要根据系统的实际控制需要而定。实际上控制总线的具体情况主要取决于CPU。


2、寄存器

存放CPU要执行的的数据或者指令

寄存器分为通用寄存器和段寄存器(段寄存器专门存放基地址)


3、CPU组成

寄存器

运算器

控制器,控制各种器件运行

内部总线连接各种器件,在他们之间进行数据传输



4、内存地址的表示方法

基地址:偏移地址=实际内存地址

实际物理内存地址=基地址*16+偏移地址


5、段概念



6、CS和IP寄存器

决定了代码段位置

CS寄存器保存了要被CPU执行的代码的基地址 (code segment=cs)

IP寄存器保存了要被CPU执行代码的偏移地址,IP寄存器别名为指令指针寄存器

CPU开始执行代码的起始地址=CS*16+IP


7、debug工具使用

(win7 x64无效,在xp x86下能够使用)

命令

R:查看和改变各个寄存器的内容

CS=1409 IP=0100,则CPU

D:查看内存中的内容

直接回车会默认将CS和IP组合地址的内存内容显示出来

       d ss:0000将ss处内存显示出来

U:将内存的机器码转换为汇编指令

u cs:0100

T:跟踪代码运行

A:以汇编指令格式在内存写入指令

     a

     mov ax, 1234


8、DS寄存器(Data Segment内存访问)

决定了数据段位置

mov ds:[13ABH], 1234H=mov [13ABH], 1234H

=> ds*16+13ABH = 1234H

9、ss、sp寄存器

决定了堆栈段的位置

段寄存器ss:存放栈顶的基地址

寄存器sp:存放栈顶的偏移地址

任何时候,ss、sp都指向栈顶的位置

push ax:将ax中的内容送入ss:sp指向的内存的单元处,sp = sp-2;ss:sp指向新栈顶

入栈数据是从高字节往低字节排序

pop ax:将ss:sp指向的内存单元处的内容赋给ax寄存器,然后sp = sp+2,ss:sp此时指向新栈顶

出栈数据是从低字节往高字节排序


windows下汇编编译环境

masm for windows


10、assume关键字

表示用来假设某一段寄存器和程序中的某一个用segment...ends定义的段相关联


11、db

define byte


assume cs:code, ds:data 


data segment

;数据段内容

msg db "hello world"

data ends


code segment

;代码段内容

mov bx, 0b800h

mov es, bx


code ends


后面的课程主要讲解了如何在电脑上写BIOS汇编程序,有点类似于《自己动手写操作系统》内容,讲的还不错,入门挺好的,以后又需要再看。


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 灰狼优化粒子群算法是一种智能优化算法,结合了灰狼算法和粒子群算法的特点,能够快速并且高效地求解优化问题。该算法在Matlab中实现,通过改进控制参数和优化策略,使得算法的收敛速度和优化效果得到了进一步提升。 灰狼优化算法是模拟灰狼种群的社会行为而提出的一种优化算法。在这个算法中,将灰狼分为Alpha、Beta、Delta和Omega四个等级,每个等级的灰狼有不同的行为规则。灰狼们会通过相互竞争和合作的方式进行搜索,通过适应值来评价解的优劣。在算法的迭代过程中,通过更新灰狼的位置和速度,逐渐找到最优解。 粒子群算法是模拟鸟群觅食行为而提出的一种优化算法。在这个算法中,将解空间看作是鸟群飞翔的空间,每个解看作是一个鸟的位置。鸟们通过相互信息的交流来调整自己的飞行方向,从而找到最优解。在算法的迭代过程中,通过更新粒子的速度和位置,逐渐靠近最优解。 灰狼优化粒子群算法将两者的特点相结合,利用灰狼的竞争和合作机制来改进粒子的更新策略,进一步提高算法的优化效果。在算法的实现过程中,需要根据具体问题的需求,设置合适的参数和策略,以达到最优化的效果。 总之,灰狼优化粒子群算法是一种高效的优化算法,在求解复杂的优化问题时具有较好的效果。通过对控制参数和优化策略的改进,可以进一步提升算法的收敛速度和优化效果。 ### 回答2: 灰狼优化粒子群算法是一种进化算法,基于自然界中灰狼群体优化行为的启发,结合了粒子群算法的思想和优化能力。其核心思想是通过模拟灰狼在社会中的行为,通过合作和竞争来寻找最优解。 这个压缩包中的006期是一个matlab源码包,里面包含了灰狼优化粒子群算法的相关代码。 首先,打开压缩包,你会看到这个源码包的文件夹。进入文件夹后,你可以看到一些.mat文件,这些是用于存储中间结果和优化结果的文件。 然后,打开matlab软件,将当前目录切换到源码包所在的文件夹下。在matlab命令行窗口中输入“main_gwo_pso”命令,并回车。这个命令将运行源码中的主函数。 主函数会加载问题函数(可以是你自己定义的优化问题函数),并执行灰狼优化粒子群算法。算法会经过多次迭代,通过更新每个粒子的位置和速度来找到最优解。 在主函数运行完成后,你可以在matlab中查看输出的最优解和优化过程。你也可以根据自己的需要对源码进行更改和调试,以适应不同的优化问题。 总之,这个源码包提供了一个使用灰狼优化粒子群算法解决优化问题的框架,通过仔细学习和理解源码,你可以在matlab中使用该算法解决自己感兴趣的问题。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值