程序设计语言正交特性的一点思考
在《程序员》2003年第12期的一篇访谈录中,Ruby的发明人Matz较详细地阐述了Ruby的设计思想及遵循的原则,其中大部分我都深以为然,特别是他高度重视语言设计过程中人的因素则更是让人激赏。不过他对正交特性的看法却让我颇为迷惑。
正交(orthogonal)本来是一个几何概念,表示的是垂直相交,后来又被扩展到线性代数中,表示内积为零的两个向量之间的关系。线性空间中一组两两正交的非零向量被称为正交向量组,而在n维线性空间中,n个向量组成的正交向量组一定线性无关,因而也就一定是该空间的基。这意味着什么呢?这意味着该空间中的任意向量都可以由这一组正交向量经线性组合(linear combination)得出,因此我们可以通过这n个向量表达整个线性空间。
在计算机科学领域,正交这个词通常表示基本元素之间互相独立与良好隔离,并且它们具备组合出一个完整"空间"的能力,而缺少其中任何一个都会丧失这种能力。如果把全面的逻辑运算想象成一种"运算空间"的话,那么not、and、or就是三个互不影响、互相不可替代的正交操作。由它们出发可以完成任意复杂的逻辑运算,但是无论少了谁,我们都会遇到某些无法完成的逻辑任务。再比如unix/linux系统提供了许多基本工具,其中每种工具都只专注于完成一种基本任务,并且基本任务也不互相重叠,所以工具的接口之间是正交关系,而用户则能通过管道等机制组合使用这些工具以完成各种复杂的任务。
一门程序语言的功能可以看作是一个"功能空间",语言只需拥有一组数量合适的正交特性(这些特性各自提供了互相独立的基本功能)便可以通过组合它们来实现"功能空间"中的任何功能。很明显,这种设计是在不损失语言能力的前提下的最简方案。不过最简是否意味着最优则仁者见仁智者见智了。在这点上Matz认为:正交性是设计的工具,而不是设计的主要目标。但是接下来Matz用来证明他观点的例子则似乎有些问题。
Matz举的例子是C++的缺省参数和函数重载。他认为这两种特性是正交的,可以同时使用,但是混合使用有时却会导致问题,这就需要人脑去猜测编译器的处理规则,而这种规则往往并不显然,所以这是一个有关正交性的反例。我同意同时提供缺省参数和函数重载并不是个好主意,尤其对初学者来说。比如下面的代码就会产生一个有些晦涩的编译错误:
void foo(int a = 2005)
{
//do something using a
...
}
void foo()
{
// do something
...
}
int main()
{
foo(3); //OK
foo(); //compile error:
//ambiguous call to overloaded function
return 0;
}
但是这两个特性是正交特性吗?实际上缺省参数功能可以非常容易地由函数重载特性来实现:
void foo(int a)
{
// do something using a
...
}
void foo()
{
foo(2005);
}
int main()
{
foo(3); //OK
foo(); //OK,就好象调用一个缺省参数值为2005的foo函数
return 0;
}
由此可以看出,缺省参数这个特性在功能上是冗余的,与函数重载不可能是正交关系。这个例子恰恰演示了某些不遵循正交性的设计会带来什么样的不良后果。不过能够做一样事情和能方便地做一样事情是有区别的,人们常常会为了现实的好处而牺牲理论的优美,个人认为这也是为什么C++会提供缺省参数这么一种语法糖衣(syntactic sugar)。
Matz用一个错误的例子来证明自己的观点,给我留下了很大的问号。希望下次能看到他用真正有说服力的论据来阐明对正交性的看法。
程序设计语言正交特性的一点思考相关推荐
- 计算机语言的正交性,【zt】程序设计语言正交特性的一点思考
在<程序员>2003年第12期的一篇访谈录中,Ruby的发明人Matz较详细地阐述了Ruby的设计思想及遵循的原则,其中大部分我都深以为然,特别是他高度重视语言设计过程中人的因素则更是让人 ...
- 浅谈计算机程序设计语言,探讨计算机程序设计语言教学
[文章摘要] 随着社会不断的发展与进步,计算机作为现代先进产物的代表,已经很快的进入到社会中的各行各业.而程序设计作为计算机的核心内容,也同样引起了大家的重视,同时计算机程序设计也是高校开设的一门重要 ...
- 关于c语言结构体偏移的一点思考
注:此处只是利用了编译器的特性来计算结构体偏移 这句话就一笔带过,说得有点牵强附会.以后有时间自己再详细了解一下编译器的特性... more exceptional c++ 中文版 26页 https ...
- C语言坐标结构,关于c语言结构体偏移的一点思考(一)
1 引言 而在实际开发过程中,比较常见的场景是给定结构体变量的初始地址,如何访问结构体内每一个成员变量?这类问题的核心是如何快速的计算结构体成员变量的偏移地址.本文将和大家一起探讨结构体内成员变量偏移 ...
- 关于c语言程序设计的想法,关于《C语言程序设计》学习的几点思考
摘 要:C语言是大学阶段一门必修课程,是许多理工科高校的核心课程之一.学好C语言对个人今后的专业发展和自身发展有着深远的影响.本文对<C语言程序设计>课程学习提出了几点建议,以期抛砖引玉. ...
- java 教案_关于Java语言程序设计教学设计的几点思考
摘要:本文主要通过本人多年的工作经验对Java语言程序设计教学设计中应用问题进行了思考,以此设计出更加合理教学方案,以此优化教学资源的利用,在此基础上利用Java语言调动学生的学习积极性,提高教学效率 ...
- [程序设计语言]-[核心概念]-04:数据类型
0. 概述 为何高级语言需要类型系统这个概念?在汇编时代是没有完整的数据类型系统的,结构化编程引入了结构化的控制流.为结构化设计的子程序,随之这种结构化的代码所操作的数据也进一步的"抽象化. ...
- 基于 Ruby 谈谈——程序设计语言的通用框架
基于 Ruby GScript 谈谈--程序设计语言的通用框架 目录 基于 Ruby GScript 谈谈--程序设计语言的通用框架 一.架构思维导图 1.Ruby GScript 介绍 2.实践: ...
- Ada 程序设计语言(The Ada Programming Language)[第二集]
Ada 程序设计语言(The Ada Programming Language)[第二集]- - 2.5.2 通用离散类型属性 离散类型包括整型和枚举型,除了上述的属性外,还有: S'Pos ...
最新文章
- 【USACO06JAN POJ3179】Corral the Cows
- php 魔术方法 多继承,day23:单继承多继承菱形继承__init__魔术方法
- java中gso是什么意思_Java中用Gson解析json字符串
- 计算机图形学_2020图灵奖重磅发布!两位计算机图形学先驱获奖
- vue组件之轮播图的实现
- SpringSecurity AbstractAuthenticationProcessingFilter
- 字符串指针的地址的传递
- 出现错误ActivityManager: Warning: Activity not started
- NYOJ 608 508筹划工程 HDU 1232 畅通工程
- 2006年中国首届杰出数据库工程师评选面试实录
- 自营、自营+平台、平台
- DQN玩Atari游戏安装atari环境bug指南
- PHP打印对象 用[]可以 用.不可以 不知所以然
- Allegro_理解通孔焊盘
- modem与baseband
- css宽度为自适应,高度等于宽度
- Android Zenmode/DND(勿扰模式) 实现原理剖析
- hdmiout 68411升级
- 华为软开云8--发布
- MT6771_MT6762_ISP_Tuning_Introduction
热门文章
- 基于springboot的健身管理系统微信小程序源码和论文
- JAVA UTC时间转换格式
- react项目报出警告Warning: Cannot update during an existing state transition (such as within `render`).
- excel固定第一行
- klouderr什么意思_ostrich是什么意思_ostrich的翻译_音标_读音_用法_例句_爱词霸在线词典...
- 【光环国际】提升领导者魅力与气质有绝招
- python安装与python、pip的环境变量配置
- java中异常处理中的异常匹配
- 使用Laya开发微信小游戏时无法使用位图字体解决方案
- 仙人掌之歌——高层人事风波