首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

第二章 IBM-PC微机的基本功能

1、中央处理器CPU 微型计算机的中央处理器也叫微处理器。 它包括运算器控制器。 功能:分析主存储器取来的各条指令的功能,控制计算机各部件完成指定功能的各项操作。...3. 8086CPU结构(重点重中之重) (1)执行单元EU EU的主要任务是分析与执行指令,具体包括: 指令队列取出指令代码,由控制器译码后产生相应的控制信号,控制各部件完成指令规定的操作...具体包括: 取指令——根据CS寄存器指令指针IP形成20位的物理地址,相应的存储器单元取出指令,暂存到指令队列,等待EU取走并执行。...当CPU内存取出一条指令后,IP内容自动修改为指向下一条指令。 注意:IP的内容不能被直接访问,既不能用指令去读IP的值,也不能用指令给它赋值。但是可以通过某些指令的执行而自动修改IP的内容。...即最先送入堆栈的数据要到最后才能取出,而最后送入堆栈的数据,最先取出。 二、8086/8088堆栈的组织 在8086/8088微机堆栈是由堆栈段寄存器SS指示的一段存储区。

28420

《计算机组成原理》基础概念笔记整理

总线:是计算机系统的各部件之间进行信息传输的公共通道;(即:多个部件共享传输部件) 总线传输特点:某一刻只能有一路信息在总线上传输,即:分时使用。...同步通信异步通信的区别; 同步通信,由统一的时钟控制,控制方式简单,灵活性差,当系统的各部件工作速度差异大的时候,总线工作效率明显下降,适用于差别不大的场合;异步通信,指没有统一钟控制的通信,部件之间采用应答方式进行联系...,在CPU与主存之间插入的速度高、位价高、容量的存储器。...各寻址方式的含义及应用; 存储器堆栈,需要一个堆栈指示器,它是CPU的一个专用寄存器,他指定的主存单元就是堆栈的栈顶; 相对寻址的基址是程序计数器的PC值; 除立即寻址寄存器寻址外,其他寻址方式...MDR T2:MDR->Ad(IR) 执行周期的操作:完成由指令操作规定的动作,包括传送结果及记录状态信息; 指令周期一般有4部分组成:取指周期、间址周期、执行周期、中断周期; 指令周期:CPU内存取出一条指令并执行该指令的时间称为指令周期

1.1K20
您找到你想要的搜索结果了吗?
是的
没有找到

Flutte部件目录-布局

排列其它部件列,行,网格许多其它布局。 单子部件布局部件 多子部件布局部件 布局助手 单子部件布局部件 Container 一个方便的小部件,结合了常见的绘画,定位尺寸小部件。...LimitedBox 只有当它不受约束才会限制它的大小。...OverflowBox 一个部件对它的子项施加了不同于其父项的约束,可能允许子项溢出父项。 SizedBox 具有指定大小的框。...如果给定孩子,这个小部件强制它的孩子有一个特定的宽度/或高度(假设这个小部件的父母允许这个值)。 如果宽度或高度为空,则此小部件将自行调整大小以匹配该维度的子级大小。...Stack 如果你想以一种简单的方式重叠几个子部件,这个类很有用,例如有一些文字图像,用梯度底部附加的按钮叠加。 IndexedStack 显示一个子部件列表的单个子部件堆栈

1.5K10

计算机组成-概述

规格化:尾数计算后有空缺,需要左规;尾数求和结果溢出,需要右规 舍入:在对阶右规的过程,可能将尾数的低位丢失,引起误差,影响精度。...阶码符号位为01,说明发生正溢出 本题容易误选B、C,B少了第3第4步,C少了第4步 易忘知识点 大端:高位低地址 端:低位低地址 如0x12345678,大端为12 34 56 78,端为78...原因是计算机的堆栈中都是向低地址增加,所以进栈是减1而非加1. 5.2.2 指令周期的数据流 取值周期,任务是根据PC的内容主存取出指令代码并存放在IR。...,可以用ROM构成 微指令寄存器CMDR:用于存放CM取出的微指令,它的位数同微指令字长相等 微地址形成部件:用于产生初始微地址后继微地址,以保证微指令的连续执行 微地址寄存器CMAR:接收微地址形成部件送来的微地址...,为在CM读取微指令做准备 微程序控制器的工作流程: 执行取微指令公共操作 由机器指令的操作码字段通过微地址形成部件产生该机器指令所对应的微程序的入口地址,并送入CMAR CM逐条取出对应的微指令并执行

2K20

计算机组成原理 CPU的功能基本结构指令执行过程

CPU管理并产生由内存取出的每条指令的操作信号,把各种操作信号送往相应的部件,从而控制这些部件按指令的要求进行动作。时间控制: 对各种操作加以时间上的控制。...2) 通用寄存器组Ri: 用于存放操作数 (包括源操作数、目的操作数及中间结果) 各种地址信息等。SP 是堆栈指针,用于指示栈顶的地址。3) 暂存寄存器T。...保留由算术逻辑运算指令或测试指令的结果而建立的各种状态信息,如溢出标志 (OF) 、符号标志 (SF) 、零标志 (ZF) 、进位标志 (CF) 等。PSW的这些位参与并决定微操作的形成。...指令执行过程指令周期概念关于周期时钟周期: (节拍,T周期,CPU时钟周期)机器周期:(CPU周期)指令周期: CPU 主存取出并执行一条指令的时间称为指令周期,不同指令的指令周期可能不同指令的不确定性时钟周期数不同...连接各部件的总线只有一条,称为单总线结构:CPU中有两条或更多的总线,构成双总线结构或多总线结构专用数据通路方式根据指令执行过程的数据地址的流动方向安排连接线路,避免使用共享的总线,性能较高,但硬件量大

22810

攻击本地主机漏洞(

缓冲区溢出 应用程序将静态(堆栈)或动态(堆)存储变量分配内存,两者都存储在计算机的随机存取内存(RAM)。在堆栈上分配的变量可以快速访问并直接存储到内存。...当顶部取出一块新的盘子时,会弹出下一块盘子来替换它,这个循环会自动重复。要从堆栈释放一个块,只需调整指向下一个内存地址的指针。...堆栈金丝雀用于在执行恶意代码之前检测缓冲区溢出堆栈保护)。程序启动,将生成一个的随机整数,并将其放置在堆栈顶部,正好位于堆栈返回指针之前。...注:计算机通过寄存器管理堆栈。寄存器作为内存的专用位置,在使用数据存储数据。大多数寄存器临时存储用于处理的值。在堆栈存储最后一个程序请求地址的寄存器称为堆栈指针。...在我们进行这项练习,了解RSPRBP登记册将非常重要。 5. 让我们仔细看看将在overflow()函数执行的汇编代码。我们将使用反汇编溢出来反汇编函数。

1.4K20

5.1 缓冲区溢出与攻防博弈

SEHOP4.地址空间布局随机化保护 ASLR5.堆栈数据执行保护 DEP5.1.1 GS堆栈缓冲区溢出检测保护保护机制实现原理GS(/GS)是微软针对缓冲区溢出攻击提出的一种保护机制,全称为"Buffer...GS保护机制是微软堆栈检测仪概念的具体实现,Visual Studio系列的编译器上就加入了GS保护机制且默认开启,操作系统WindowsXP开始就已经全面支持该选项了。...ASLR(Address Space Layout Randomization)是一种内存随机化技术,它通过在每次程序运行时随机化程序的代码、数据堆栈等内存空间的布局,使攻击者难以准确地预测代码和数据存放的位置...5.1.5 DEP堆栈数据执行保护保护机制实现原理DEP保护直接切中了缓冲区溢出要害,数据执行保护将程序数据段所在的内存页面(堆栈)的属性强制设为NX (不可执行),当程序执行这些内存页面上的数据,将报错并禁止文件的执行...它通过将内存的数据区域(如堆、栈可执行代码)标记为可执行或不可执行来实现保护。当攻击者试图在一个不可执行的内存区域中运行代码,DEP机制就会触发异常,从而导致程序崩溃或者被终止。

21820

二进制利用之缓冲区溢出浅析

攻击者对缓冲区溢出的处理方式取决于缓冲区所在的位置以及采用的保护措施。 1.重定向程序流 在栈溢出溢出,攻击者都可以覆盖程序的重要控制变量来重定向程序流。...2.代码执行 在堆栈溢出攻击中,如果攻击者能够讲自己设计的代码植入内存,则他可以覆盖堆栈上的返回地址,从而使其指向恶意代码的位置。...栈缓冲区攻击从低地址向高地址覆盖栈空间,因此会在覆盖返回地址之前就覆盖了警惕标志。栈返回前会检查该警惕标志是否被篡改。 今天只是了解简单的概念即可,之后笔者在后续的文章再深入它们。...地址空间布局随机化 地址空间布局随机化即ASLR,随机化内存布局并使栈,堆库的地址不可预测。这样可以防止攻击者预测要跳转到的内存地址,并使代码执行攻击变得更加困难。...所以还是根源上的做法,尽可能安全的编码以防止缓冲区溢出 1.输入大小边界检查: 代码执行输入进行大小边界检查,以确保用户输入可以包含在分配的缓冲区空间内。

99200

5.1 缓冲区溢出与攻防博弈

覆盖保护 SEHOP 4.地址空间布局随机化保护 ASLR 5.堆栈数据执行保护 DEP 5.1.1 GS堆栈缓冲区溢出检测保护 保护机制实现原理 GS(/GS)是微软针对缓冲区溢出攻击提出的一种保护机制...GS保护机制是微软堆栈检测仪概念的具体实现,Visual Studio系列的编译器上就加入了GS保护机制且默认开启,操作系统WindowsXP开始就已经全面支持该选项了。...ASLR(Address Space Layout Randomization)是一种内存随机化技术,它通过在每次程序运行时随机化程序的代码、数据堆栈等内存空间的布局,使攻击者难以准确地预测代码和数据存放的位置...5.1.5 DEP堆栈数据执行保护 保护机制实现原理 DEP保护直接切中了缓冲区溢出要害,数据执行保护将程序数据段所在的内存页面(堆栈)的属性强制设为NX (不可执行),当程序执行这些内存页面上的数据...它通过将内存的数据区域(如堆、栈可执行代码)标记为可执行或不可执行来实现保护。 当攻击者试图在一个不可执行的内存区域中运行代码,DEP机制就会触发异常,从而导致程序崩溃或者被终止。

32940

ARM64 撬开逆向大门

加法运算(add指令):当运算结果产生了进位(无符号数溢出),C=1,否则C=0。 减法运算(sub指令):当运算产生了借位(无符号数溢出),C=0,否则C=1。 4....(注:以LD开头的表示为取出数据) 以下是具体指令说明及汇编代码分析 STR指令:将数据寄存器读出来,存储到内存。...STUR指令:将寄存器的负数数据读取出来,存放到内存。 STP指令:表示入栈指令。 ? LDR指令:将数据内存取出来,存放到寄存器。...3.3 函数8个参数9个参数的具体情况(不过在开发过程参数超过8个的情况是比较少的,因此在逆向过程这种超过8个参数的情况也会比较少的) 3.3.1函数中有八个参数的,直接用寄存器W0-...4.函数堆栈怎么平衡? 堆栈平衡需要被调用者进行恢复平衡。 ? ? 5.函数的返回值怎么进行接收? 函数的返回值通常情况下是存放在X0寄存器里面。 ?

2K54

【发布公告】您的应用卡么?Bugly全新功能:卡顿ANR监控

iOS 卡顿:萝莉和你聊聊iOS应用卡顿那些事儿 Bugly近期功能更新动态: 一SDK功能更新 Android SDK V1.2.3 1) 新增ANR监控上报功能 2) 优化与第三方SDK...的兼容性 iOS SDK V1.2.7 1) 新增iOS卡顿监控上报功能 2) 新增会话内关键事件上报功能 3) 修复错误信号崩溃线程堆栈取出现偏差问题 二页面功能更新 1、 新增iOS卡顿、Android...ANR异常信息展示统计,实时了解用户在使用应用过程发生的不流畅信息。...3、 其它细节调整优化 1) iOS崩溃信息“其它线程”支持自动符号化,并按线程名称自动排序 2) 问题列表悬浮框敏感度调优 3) 问题列表展示内容优化,定位问题更方便...---- 本文系腾讯bugly特邀内容,转载请在文章开头显眼处注明注明作者出处“腾讯Bugly(http://bugly.qq.com)” 腾讯Bugly 最专业的质量跟踪平台 精神哥、萝莉,为您定期分享应用崩溃解决方案

2.2K40

简述51单片机的内部结构_51单片机的硬件结构及其作用

取出指令码后,PC寄存器内容自动加 1 ,指向下一指令地址。 3....指令寄存器 存放指令代码 CPU执行指令,由程序存储器读取的指令代码送入指令寄存器,经指令寄存器译码后,由定时与控制电路发出相应的控制信号,完成指令功能。 【 3. 存储器 】 1....寄存器的选组由程序状态字PSW的RS1RS0位决定。 初始化或复位自动选中0组。...常见的SFR :累加器A,寄存器B,程序状态字PSW,堆栈指针SP,数据指令寄存器DPTR,P0 P1 P2 P3 I/O端口寄存器等。 PS:52系列,高128字节RAMSFR地址是重合的。...开关复位:电源接通,利用开关,控制RST引脚接高电平实现复位。当出现死循环或崩溃的时候,可通过开关令其复位使单片机退出当前崩溃状态。

1.9K21

格式化字符串一文入门到实战

根据格式说明符规定的数据格式,格式函数检索堆栈请求的数据。...printf(“A is the number %d, B is the string %s”, A, &B); 上面的printf() 函数将尝试堆栈检索A的值字符串B的地址。....”, A, B); 当字符串的格式说明符数量与用于填充这些位置的函数参数(如上面的AB)数量不匹配,将发生此漏洞。如果攻击者提供的占位符超过了参数个数,则可以使用格式函数来读取或写入堆栈。...这意味着,当声明局部变量或函数参数,它将被压入堆栈。而当调用函数,该函数也会堆栈获取数据。...不仅如此,攻击者甚至可以使用格式函数导致程序崩溃 由于%s的函数参数是通过引用传递的,因此对于格式字符串的每个%s,该函数将从堆栈检索一个值,将该值视为地址,然后打印出存储在该地址的字符串。

1.4K30

Flutte部件目录-基本部件(一)

Container按顺序尝试:遵守alignment,将自己调整到child部件的尺寸,遵守宽度,高度constraints,扩展以适应父部件,变得尽可能。...如果部件没有子且没有alignment(对齐),但是提供了高度,宽度或constraints(约束),那么基于给定这些约束父对象的约束相结合容器会尝试尽可能。...如果该行的非弹性内容比该行(那些不包含在Expanded或Flexible部件的)本身多,则该行被认为已经溢出。当一行溢出,该行没有任何剩余空间ExpandedFlexible的子项。...该行通过在溢出的边上绘制黄色黑色条纹警告来报告此情况。如果行外有空间,溢出量将以红色字体打印。...黄色黑色的条纹横幅 当列的内容超过可用空间量,列溢出,内容被剪辑。 在调试模式下,在溢出边缘处呈现黄色黑色条纹条以指示问题,并在列下方显示一条消息,指出检测到多少溢出

7.4K20

堆栈里的秘密行动:劫持执行流

前情回顾: 线程老哥执行memcpy越界访问溢出堆栈里的一众对象难逃噩运。 详情参见:堆栈里的悄悄话——智能指针 1 神秘的0xCC ?...说完我们就来到了防火墙面前,当差的守卫查看了我们的源IP端口,又看了目的IP目的端口,接着瞟了一眼负载数据,当他望向我这边,我紧张的大气都不敢出一声,把头深深的埋着。 ?...2 栈溢出 & Stack Cannary 线程大哥把我俩放到了一片陌生的区域。 “你等我一下,我去打听下情况”,P叮嘱完我后,隔壁一个对象聊了起来。 ?...“可不要小瞧了它,当栈溢出数据被修改后,函数return,在从栈取出返回地址之前会检查它有没有被修改,一旦被发现修改过,进程就会终止,咱们的计划不就泡汤了吗?” “这程序员还挺聪明的嘛!...我一下趴着不敢动弹,余光瞥见线程大哥取出了隔壁对象的前面8个字节后就离开了。 “好险,差点被发现,你呀,说话别那么大声,计划败露那就全完了,知道吗!”,P把我训了一顿。 “好啦,我知道了。

47510

计算机基础之计算机硬件系统

四.CPU、内存、磁盘之间的关系  1.CPU即中央处理器, CPU内存或缓存取出指令,放入指令寄存器,并对指令译码分解成一系列的微操作,然后发出各种控制命令,执行微操作系列,从而完成一条指令的执行...寄存器的分类:      a.通用寄存器:用来保存变量临时结果      b.程序计数器:保存了将要取出的下一条指令的内存地址。在指令取出后,程序计算器就被更新以便执行后期的指令。     ...c.堆栈指针: 指向内存当前栈的顶端。该栈包含已经进入但是还没有退出的每个过程的一个框架。...在一个过程的堆栈框架中保存了有关的输入参数、局部变量以及那些没有保存在寄存器的临时变量。         ...总线与南桥北桥 1.总线将计算机内部各部件连接,并且实现了计算机各功能部件之间的信息传输。 2.南桥即ISA桥:连接慢速设备,硬盘,显示器等设备。

1.3K50

JS 执行上下文

如图所示,我们只能从栈顶取出或放入乒乓球,最先放进盒子的总是最后才能取出。栈"放入/取出",也可称为"入栈/出栈"。...foo(); // 输出bar()整个函数声明 函数声明,变量声明,函数表达式的优先级 函数声明,如果有同名属性,会替换掉 变量,函数表达式 函数声明优先 > 变量,函数表达式 执行上下文的数量限制(堆栈溢出...) 执行上下文可存在多个,虽然没有明确的数量限制,但如果超出栈分配的空间,会造成堆栈溢出。...其它需要排队 全局上下文只有一个处于栈底,页面关闭出栈 函数执行上下文可存在多个,但应避免递归堆栈溢出 函数调用时就会创建新的上下文,即使调用自身,也会创建不同的执行上下文 参考文档 执行上下文详细图解...理解JavaScript 的执行上下文执行栈 这一次,彻底弄懂 JavaScript 执行机制

4.1K41

数据结构与算法 --- 递归(二)

探究产生堆栈溢出的原因 函数调用采用「函数调用栈」来保存当前“快照”(局部变量,返回地址等)。函数调用栈是内存开辟的一块存储空间,它被组织成“栈”这种数据结构,数据先进后出。...递归的过程包含大量的函数调用,如果递归求解的数据规模很大,函数调用层次很深,那么函数调用栈的数据(栈帧)会越来越多,而函数调用栈空间一般不大,堆栈空间不足以存储所有的调用信息,从而导致堆栈溢出。...在 Factorial(n - 1) 执行完成之后,返回结果(假设是 result ),编译器就从函数调用栈取出之前保存的栈帧(局部变量 n Factorial(n - 1) 的返回地址)。...,尾递归是又可能解决堆栈溢出的问题的。...但是在实际开发过程,尾递归其实并没有太大作用,不能期望它来规避递归导致的堆栈溢出问题,主要表现在: 并不是所有编程语言都支持尾递归优化 并不是所有的递归都可以改成尾递归 能改成尾递归的代码也就都可以改成迭代方式

15910

【团队分享】刀锋铁骑:常见Android Native崩溃及错误原因

这时查看Crash显示的调用栈,野指针所在的代码部分,有可能基本上没有任何关联。 解决方法 在指针变量定义,一定要初始化,特别是在结构体或类的成员指针变量。...解决方法 在书写输出格式参数,要做到参数个数类型都要与输出格式一致。 在GCC的编译选项中加入-wformat,让GCC在编译检测出此类错误。...该功能会在编译后的汇编代码插入堆栈检测的代码,并在运行时能够检测到栈破坏并输出报告。 Bug评述 缓冲区溢出是一种非常普遍、非常危险的漏洞,在各种操作系统、应用软件中广泛存在。...四、编有话说 Java异常已经搞得大家焦头烂额了,Native异常更是恐怖,数量比Java异常多得多,只是看堆栈还不好定位(画小圈圈诅咒万恶的指针)。...非常感谢王竞原童鞋能在日常开发遇到的崩溃总结出这一篇宝贵的文章! 不总结哪来经验,不分享经验何用?

4.1K62

Bugless 异常监控系统 (iOS端)

也无法在多维度进行异常数据的对比,使得收集应用信息收集崩溃日志变得日益迫切。 37手游研发的 Bugless 定位于线上问题追踪的视角出发,检测代码异常,通过回溯问题,从而解决代码本身问题。...二、认识崩溃异常 在讲解 Bugless 之前,让我们三个层面来介绍,让大家认识App为什么会出现崩溃异常,以及如何应对。...在常见的异常崩溃信息,经常会看到有 Exception Type: EXC_BAD_ACCESS (SIGSEGV) 这样的字段内容,EXC_BAD_ACCESS SIGSEGV,分别是指 Mach...堆栈溢出也有可能产生该信号。 SIGABRT:程序中止命令中止信号,调用 abort 函数产生该信号。...2.3.1 Bugless 上报闪退堆栈 数据全量收集出发,获取闪退的日志时机有两个: 第一机:闪退立即上报,但第一次可能因为进程被杀死而发送不成功。

2.5K30
领券