- 内容提要
- 序 1:程序里的世界
- 序 2:最后一层表象
- 关于本书
- 致谢
- 引言:简单的本源
- 篇一:计算系统
- 第 1 章 数,以及对数据的性质的思考
- 第 2 章 逻辑
- 第 3 章 抽象
- 篇二:语言及其面临的系统
- 第 4 章 语言
- 第 5 章 从功能到系统
- 篇三:程序设计的核心思想
- 第 6 章 数据结构:顺序存储
- 第 7 章 数据结构:散列存储
- 第 8 章 执行体与它在执行过程中的环境
- 第 9 章 语法树及其执行过程
- 第 10 章 对象系统:表达、使用与模式
- 篇四:应用开发基础
- 第 11 章 应用开发的背景与成因
- 第 12 章 应用开发技术
- 第 13 章 开发视角下的工程问题
- 第 14 章 应用程序设计语言的复杂性
- 篇五:系统的基础部件
- 第 15 章 分布
- 第 16 章 依赖
- 第 17 章 消息
- 第 18 章 系统
- 篇六:系统的基本组织方法与原理
- 第 19 章 行为的组织及其抽象
- 第 20 章 领域间的组织
- 附一:主要编程范式 及其语言特性关系
- 附二:继承与混合,略谈系统的构建方式
- 附三:像大师们一样思考——从 UML 何时死掉 谈起
- 附四:VCL 已死,RAD 已死
文章来源于网络收集而来,版权归原创者所有,如有侵权请及时联系!
1.3 我们要操作的数据是什么?
数据(data),并不是数,而是数的系列。数学概念上的布尔数,是纯粹抽象的,可以是黑白点,也可以是正反面;电子学概念中的布尔数,是逻辑门电路中的高低电平信号。而数据,其内聚的特性表明它由一系列存有相互关系的数构成,其外延的特性表明它可以与其他数的系列建立新的抽象关系。
这里的“系列”,只是对数据的构成元素(例如多个二进制位)之间存在着的关系的一个简单称谓。这种关系是什么呢?例如,我们说“A”字符是一个数据,即是说它是由“1000001”这七个二进制数形成的组合关系。这个组合关系是强约束的,如果换一个组合,则不是“A”字符而是别的字符了。再例如,我们既然说“A”是“1000001”的组合关系,则同时也是说“B”必然是“A”的组合关系的一个外延。但这样的外延存在多种可能性,对于这两个字符以及由此构成的 数的系列 这一概念来说,其数学描述方式为:
B = f(A)
我们知道,在“ASCII 字符集”这个系统中,f()所表示的外延关系是 inc()
4 ,即 B = A+1
。而在另外的某个系统(例如密码卡)中,f()则可能是另外的一个函数。数,与数据之间存有的不确定的函数映射关系,是我在前文中用“数的系列”,而非“数的序列”的真实原因。
我们所面临的硬件系统以及其背后的逻辑基础,都是基于数的概念;而我们的软件系统,例如我们使用某种开发工具、语言,或者操作某个设备的指令集,都是基于数据的概念。因此在软件开发(而非计算机研制)中,第一个要明确的问题是:
我们要操作的数据是什么?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论