Dictionary 就是 字典, 是一种可以根据 Key 来 快速 查找 Value 的 数据结构 。

比如 我们在 C# 里用到的 Dictionary<T>,

在 程序设计 里, 字典 通常使用 哈希表(Hash 表) 的 方式 实现, 也可以用 索引 的 方式 实现,

不过 索引 太占空间 了,  所以 在 数据库 里 用的 很普遍, 但是 在 应用程序(内存) 这一层面 好像 没有看到过用 索引 的 。

今天 我们 来 设计一个 用 硬件 实现 的 字典 :      ^^

要开始研究 硬件 来 实现一个 字典 呢, 需要 先 准备 一些 基础知识, 可以先看一下我写的另外一篇文章  《漫谈计算机硬件的设计和实现》

https://www.cnblogs.com/KSongKing/p/9866334.html

首先, 我们要引入一个 “开关门” 门电路, 就是 除了 “与”、“或”、“非”  门电路 外, 还需要一个 “开关门” 门电路,

实际上, “开关门” 电路 就是 构成 “与”、“或”、“非”  门电路 的 基础 。

我们来看一下  “开关门” 电路 的 逻辑电路图 :

当 控制端 输入 0 时, 开关 关, 即 输入端 到 输出端 之间的 电路 断开,

当 控制端 输入 1 时, 开关 开, 即 输入端 到 输出端 之间的 电路 接通 。

这个 “开关门 ”  是不是有点像 三极管 ?   哈哈哈

接下来, 我们要设计一个  “电子开关”,

“电子开关” 就是

当 设定端 是 0 时, 输入端 若 输入 0 , 则 输出端 输出 1, 若 输入端 输入 1 时, 输出端 输入 0,

当 设定端 是 1 时, 输入端 若 输入 0 , 则 输出端 输出 0, 若 输入端 输入 1 时, 输出端 输入 1,

这是  ……  ?

哈哈哈,  就是 输入端 输入的 值 和 设定端 相同 时, 输出端 输出 1 (开),  否则 输出端 输出 0 (关) 。

这有什么用  ?

利用 这个  “设定” 的 功能, 可以实现  “设置 Key”  的 效果 。

我们来看一下 “电子开关” 的 逻辑电路图 :

有了 “电子开关”,  我们 就可以 实现一个 “字典单元”,  一个 “字典单元” 可以 存放 一个 键值对 。

我们来看一下 “字典单元” 的 逻辑电路图 :

简单起见, 上图的这个 字典单元 只有  2 位(2 Bit),  就是说 可以支持   “00”、“01”、“10”、“11”   4 个 键 。

在 设定端 可以 设定键,  比如 设定端 是  “00”,   则 输入端 输入 “00” 时,  最上方 的 “与门” 输出 1 ,  “Value 存储单元” 接通, 可以读取数据, 读取到的就是 键 对应的 值 。 输入端 输入 非 “00” 的 其它 值 时,  与门 输出 0,  “Value 存储单元” 不接通,  不能读取数据 。

又比如 设定端 是  “01”,   则 输入端 输入 “01” 时,  最上方 的 “与门” 输出 1 ,  “Value 存储单元” 接通, 可以读取数据, 读取到的就是 键 对应的 值 。 输入端 输入 非 “01” 的 其它 值 时,  与门 输出 0,  “Value 存储单元” 不接通,  不能读取数据 。

这就实现了一个 字典单元,

我们把 若干个 字典单元 并联起来(按引脚并联), 即 设定端 的 引脚 1 和 引脚 1 并联, 引脚 2 和 引脚 2 并联 ……  输入端, 输出端 亦然 。

这样 就 组成了一个 字典, 或者说 字典阵列, 就像 内存 的 一组 存储单元 一样 。

n 个 字典单元 组成 的 字典阵列 可以 存放 n 个 键值对 。

哎 ?   等,,,  说到   “阵列”  ,  如果 设定端 在 断电 的 情况下 也能 保存 设定值,  那这岂不就成了   “可编程逻辑阵列”    了嘛  ~!

设计一个 硬件 实现的 Dictionary(字典)的更多相关文章

  1. 为 .NET Core 设计一个 3D 图形渲染库

    原文地址:https://mellinoe.wordpress.com/2017/02/08/designing-a-3d-rendering-library-for-net-core/ 作者:ERI ...

  2. 你能熟练使用Dictionary字典和List列表吗?(转)

    命名空间System.Collections.Generic中有两个非常重要,而且常用的泛型集合类,它们分别是Dictionary<TKey,TValue>字典和List<T> ...

  3. (转)C#中的Dictionary字典类介绍

    关键字:C# Dictionary 字典 作者:txw1958原文:http://www.cnblogs.com/txw1958/archive/2012/11/07/csharp-dictionar ...

  4. C#中的Dictionary字典类介绍

      Dictionary字典类介绍 必须包含名空间System.Collection.Generic    Dictionary里面的每一个元素都是一个键值对(由二个元素组成:键和值)    键必须是 ...

  5. C# Dictionary 字典

    C#中的Dictionary字典类介绍   关键字:C# Dictionary 字典 作者:txw1958原文:http://www.cnblogs.com/txw1958/archive/2012/ ...

  6. 关于Dictionary字典和List列表

    命名空间System.Collections.Generic中有两个非常重要,而且常用的泛型集合类,它们分别是Dictionary<TKey,TValue>字典和List<T> ...

  7. 如何一步一步用DDD设计一个电商网站(十三)—— 领域事件扩展

    阅读目录 前言 回顾 本地的一致性 领域事件发布出现异常 订阅者处理出现异常 结语 一.前言 上篇中我们初步运用了领域事件,其中还有一些问题我们没有解决,所以实现是不健壮的,下面先来回顾一下. 二.回 ...

  8. 深入理解计算机系统(4.2)------逻辑设计和硬件控制语言HCL

    上一篇博客我们简单介绍了Y86指令集体系,而这篇博客我们将介绍指令集体系的逻辑设计和硬件控制语言HCL,为后面去实现Y86打下基础. 在硬件设计中,用电子电路来计算对位进行运算的函数,以及在各种存储器 ...

  9. 如何设计一个异步Web服务——任务调度

    接上一篇<如何设计一个异步Web服务——接口部分> Application已经将任务信息发到了Service服务器中,接下来,Service服务器改如何对自身的资源进行合理分配以满足App ...

随机推荐

  1. VCL界面控件DevExpress VCL Controls发布v18.2.5|附下载

    DevExpress VCL Controls是 Devexpress公司旗下最老牌的用户界面套包.所包含的控件有:数据录入,图表,数据分析,导航,布局,网格,日程管理,样式,打印和工作流等,让您快速 ...

  2. day 35 关于线程

    并发编程之协程   对于单线程下,我们不可避免程序中出现io操作,但如果我们能在自己的程序中(即用户程序级别,而非操作系统级别)控制单线程下的多个任务能在一个任务遇到io阻塞时就切换到另外一个任务去计 ...

  3. 引入网站标题小logo

    <link rel="icon" type="image/png" href="路径/favicon.png"> 关注微信小程序

  4. 使用scrapy ImagesPipeline爬取图片资源

    这是一个使用scrapy的ImagesPipeline爬取下载图片的示例,生成的图片保存在爬虫的full文件夹里. scrapy startproject DoubanImgs cd DoubanIm ...

  5. C语言基础:数组 分类: iOS学习 c语言基础 2015-06-10 21:40 7人阅读 评论(0) 收藏

    数组:是由一组具有相同数据类型的数据组合而来. 数组定义:元素类型修饰符 数组名[数组个数]={元素1,元素2....};  int arr[ 2 ]={1,2};    //正确 int arr[ ...

  6. SpringBatch Sample (一)(Hello World)

    通过前面两篇关于Spring Batch文章的介绍,大家应该已经对Spring Batch有个初步的概念了.这篇文章,将通过一个”Hello World!”实例,和大家一起探讨关于Spring Bat ...

  7. c语言求最大公约数和最小公倍数(转)

    最大公约数与最小公倍数的求解是很多初学C的人所面临的一道问题.当然这道问题并不难解答,也有很多人已经写过相关的博客,我在此书写此篇博客,一是为了让自己能够夯实基础,另外就是希望能够帮到和我一样的初学者 ...

  8. c++字符串前几位,后几位的截取

    参考 1. https://blog.csdn.net/haijunsm/article/details/82733584 完

  9. 【CSP】字符与int

    [转自https://yq.aliyun.com/articles/19153] WIKIOI-1146 ISBN号码   光仔december 2014-03-01 16:20:00 浏览479 评 ...

  10. 求强连通分量Tarjan算法

    ]; // 时间戳 ; // 时间 ]; // 节点u所能访问到的最小时间戳 ]; // 节点u是否在栈中. ]; ; // 我们维护的信息. ]; // 给节点染色, 同一个连通块的节点应该是同一个 ...