CPU和内存的电路设计07-上升沿D触发器的内部电路实现/移位寄存器/串行接口/并行接口

本文主要是介绍CPU和内存的电路设计07-上升沿D触发器的内部电路实现/移位寄存器/串行接口/并行接口,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

D是英文Data的意思

之前的文章介绍了RS触发器的内部电路实现,该电路有个缺点,就是需要用R和S两个控制端输入,才能控制Q端的输出,为了减少复杂度,D触发器诞生了,D触发器通过一个输入端,控制一个输出端

回顾一下RS触发器特性
要使Q = 0,S=0,并且R=1;
要使Q = 1,S=1,并且R=0

可以发现R和S可以使用非门电路连接,那么该设想的电路图如下,该电路的确能达到上述公式的要求,但是触发器的意义也随之消失了,触发器原本的意义是:S第一次=1之后,Q=1,之后无论S为何值,只要R不=1,Q就应该一直为1,但是现在D=1,Q就=1,而D=0,Q就=0,那我要这触发器有何意义??直接干脆弄一条直线不就可以了吗,所以应该对图1继续改造
在这里插入图片描述
如图2所示,增加一个CP位,当CP=0的时候,无论D为何值,S和R都=0,所以Q的值保持不变,之前是什么,就是什么

当CP=1时,此时让D=1,则Q=1,当Q=1之后,将CP=0,此时,无论D为何值,Q都=1

如果想让Q=0,则将CP=1,然后让D=0,此时,Q=0,然后再讲CP=0,之后无论D为何值,Q都=0

也就是说,要想改变Q的值,首先将CP=1才可以
在这里插入图片描述
D触发器符号如下,图3

在这里插入图片描述
结论:
CP=1:D=0时Q=0,D=1时Q=1
CP=0:无论D=0还是1,Q都保持原值不变

文章至此一直讲述的都是D触发器,接下来阐述另外以一种触发器(图4),叫做上升沿D触发器
先让X4=0时,X5=1,所以X2=X1,此时X3不会因为X2的变化而变化
再让X4=1时,X5=0,所以X2的值停留在上次,X4=1导致X3=X2

现在一切重来,我们断电,然后重新接通
先让X4=1时,X5=0,X2不会因为X1变化而变化,但是X3=X2
再让X4=0时,X5=1,此时X2=X1,但是X3不会有任何变化

总结:
(1)X4由0变1之后,X3会取X2在X4=0时候的值
(2)X4由1变0之后,X3没什么改变
因为结论中的(1),所以图4的触发器叫做上升沿触D触发器

在这里插入图片描述
上升沿D触发器电路图简化如下
在这里插入图片描述
结论:当CP从0变1之后,Q的值为CP=0时候的D的值

移位寄存器
接下来要说的是计算机中非常重要的一个内容:串行接口

现在将数据U盘中的一个字节,值为1100 1101,通过USB口传送到电脑中,
那么串行接口的方式是先将每个bit位按照顺序,依次,的放到位移寄存器中,然后CPU再从位移寄存器,通过总线,一次性将8个位的bit,都取走

通过上述可知:
U盘->位移寄存器,这个过程是串行过程
位移寄存器->CPU,这个过程是并行过程

一个位移寄存器的内部电路实现如下,由多个D触发器构成
在这里插入图片描述

下面图7中是电路初始的样子,其中绿色圆圈中的初始值是0,然后会将字节1100 1101这个值的每个bit位,从右向左依次往绿色圆圈中放

字节剩余:1100 1101
在这里插入图片描述

下面图8是将最右侧的一个1放到绿色圆圈处

字节剩余:1100 110
在这里插入图片描述

当按下Vcc旁边的开关键,则移位寄存器中的值如图9,之后开关弹起

字节剩余:1100 11
在这里插入图片描述

当再次按下Vcc旁边的开关键,则移位寄存器中的值如图10

字节剩余:1100 1
在这里插入图片描述

根据上面的原理依次类推,最终一个字节将按照如下排列

字节剩余:没有剩余
在这里插入图片描述

上述的这个过程就是串行过程,然后如果谁用位移寄存器中的值,则谁就将8个bit,一次性取走,如图12这样
在这里插入图片描述
注意:为了方便说明,Vcc旁边是个开关,实际中Vcc旁边那个应该是个振荡器

这篇关于CPU和内存的电路设计07-上升沿D触发器的内部电路实现/移位寄存器/串行接口/并行接口的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1057328

相关文章

python生成随机唯一id的几种实现方法

《python生成随机唯一id的几种实现方法》在Python中生成随机唯一ID有多种方法,根据不同的需求场景可以选择最适合的方案,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习... 目录方法 1:使用 UUID 模块(推荐)方法 2:使用 Secrets 模块(安全敏感场景)方法

Spring StateMachine实现状态机使用示例详解

《SpringStateMachine实现状态机使用示例详解》本文介绍SpringStateMachine实现状态机的步骤,包括依赖导入、枚举定义、状态转移规则配置、上下文管理及服务调用示例,重点解... 目录什么是状态机使用示例什么是状态机状态机是计算机科学中的​​核心建模工具​​,用于描述对象在其生命

Spring Boot 结合 WxJava 实现文章上传微信公众号草稿箱与群发

《SpringBoot结合WxJava实现文章上传微信公众号草稿箱与群发》本文将详细介绍如何使用SpringBoot框架结合WxJava开发工具包,实现文章上传到微信公众号草稿箱以及群发功能,... 目录一、项目环境准备1.1 开发环境1.2 微信公众号准备二、Spring Boot 项目搭建2.1 创建

Linux进程CPU绑定优化与实践过程

《Linux进程CPU绑定优化与实践过程》Linux支持进程绑定至特定CPU核心,通过sched_setaffinity系统调用和taskset工具实现,优化缓存效率与上下文切换,提升多核计算性能,适... 目录1. 多核处理器及并行计算概念1.1 多核处理器架构概述1.2 并行计算的含义及重要性1.3 并

IntelliJ IDEA2025创建SpringBoot项目的实现步骤

《IntelliJIDEA2025创建SpringBoot项目的实现步骤》本文主要介绍了IntelliJIDEA2025创建SpringBoot项目的实现步骤,文中通过示例代码介绍的非常详细,对大家... 目录一、创建 Spring Boot 项目1. 新建项目2. 基础配置3. 选择依赖4. 生成项目5.

Linux下进程的CPU配置与线程绑定过程

《Linux下进程的CPU配置与线程绑定过程》本文介绍Linux系统中基于进程和线程的CPU配置方法,通过taskset命令和pthread库调整亲和力,将进程/线程绑定到特定CPU核心以优化资源分配... 目录1 基于进程的CPU配置1.1 对CPU亲和力的配置1.2 绑定进程到指定CPU核上运行2 基于

Linux下删除乱码文件和目录的实现方式

《Linux下删除乱码文件和目录的实现方式》:本文主要介绍Linux下删除乱码文件和目录的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux下删除乱码文件和目录方法1方法2总结Linux下删除乱码文件和目录方法1使用ls -i命令找到文件或目录

SpringBoot+EasyExcel实现自定义复杂样式导入导出

《SpringBoot+EasyExcel实现自定义复杂样式导入导出》这篇文章主要为大家详细介绍了SpringBoot如何结果EasyExcel实现自定义复杂样式导入导出功能,文中的示例代码讲解详细,... 目录安装处理自定义导出复杂场景1、列不固定,动态列2、动态下拉3、自定义锁定行/列,添加密码4、合并

mybatis执行insert返回id实现详解

《mybatis执行insert返回id实现详解》MyBatis插入操作默认返回受影响行数,需通过useGeneratedKeys+keyProperty或selectKey获取主键ID,确保主键为自... 目录 两种方式获取自增 ID:1. ​​useGeneratedKeys+keyProperty(推

Spring Boot集成Druid实现数据源管理与监控的详细步骤

《SpringBoot集成Druid实现数据源管理与监控的详细步骤》本文介绍如何在SpringBoot项目中集成Druid数据库连接池,包括环境搭建、Maven依赖配置、SpringBoot配置文件... 目录1. 引言1.1 环境准备1.2 Druid介绍2. 配置Druid连接池3. 查看Druid监控