Thinking in Current Programming Languages
程序员文章站
2022-03-29 20:39:01
...
一、现状
- 软件越来越庞大,细节越来越多---->难以改错,改进
- 开发周期越来越长---->浪费金钱、生命
二、原因
- 生产工具与任务之间的差距太大:要砍伐整片森林,手里只有斧子
- 生产资料与产品之间的差距太大:要葱油鲤鱼,手里只有鱼籽葱籽
- 要建立一个金融系统,手里只有C++Java编译器,UML“建模”工具
- 要建立一个化学反应模拟系统,手里还是只有C++Java编译器,UML“建模”工具
三、其它领域的样例
- 要创作一首曲子,只需写出它的五线谱,你几乎不可能用自然语言来描述
- 要证明一个数学定理,只需用数学符号、现有的数学公式来推理、自然语言语焉不详,不够精确
- 要表达一个化学反应过程:只需要写出分子式、每一步的化学方程式
- 自然语言在这些领域碌碌无为,或者说在背后默默而为
四、曾经的成功样例
- C语言代替汇编和机器语言来表示机器模型:在机器的领域中,C语言是问题域的建模语言,有直接的语法来表达寻址等概念,汇编才是解决域的算法实现语言;C语言已经是写操作系统/虚拟机较为理想的语言了,但它仍然没有直接提供进程、线程等概念,而是通过库来表达
- DOS命令、Unix命令、甚至FTP命令等:都能直接完成意图,C/C++是背后的解决域的算法实现语言
五、现在的成功样例
- HTML:Web静态表示领域的描述语言,有直接的术语来表达各种概念,C/C++是背后的解决域的算法实现语言
- SQL:数据管理领域的描述语言,有直接的术语来表达各种概念,C/C++是背后的解决域的算法实现语言
六、推论
- 通用的东西最终只在后台发挥作用,无论是理论还是工具
七、继续推论
- UML将一事无成,直到它退居幕后,或演变成另外一个C++(所谓可执行的UML)
- Java或C++会变得象今天的汇编,我们就是60年代的汇编程序员,或公元前修长城的民工、建金字塔的外国民工
- DSL、LOP以各种面貌登上舞台
- ...
上一篇: 错误处理规范