`
- 浏览:
3707 次
- 性别:
- 来自:
济南
-
理想的编程语言 鞠文广
以下纯粹是个人观点, 不代表任何组织或社团.
关键词: 并发编程 函数编程 逻辑编程
摘要: 由于现有语言不能很好的为现实世界建模, 我提出一种编程方法论和编程语言Processlog. 它的编程思想是"面向进程 + 函数编程+ 逻辑编程等", 用它写的程序的软件体系结构很清晰, 程序简洁优美, 程序的正确性容易用数学推理证明, 适用于各种领域.
现在流行的编程语言如Java和C#, 大多是面向对象的, 程序的各部分是通过方法调用连在一起, 其编程范式是命令编程, 即使支持其他范式也包装得很难理解和使用.
面向对象实际上只适合实现抽象数据类型, 让它去完成除此之外的任务确实是勉为其难, 即便能完成也给人不伦不类的感觉, 既不像面向对象编程, 也不像它的前任(过程编程). 这些语言中的对象与物质世界的物质(或对象)很不一致, 它使用方法调用的方式与其他对象进行相互作用, 而这与物质之间的(通过通信或媒介)相互作用是截然不同的, 因此用面向对象无法很确切地模拟现实世界(面向对象思想的初衷), 更不用说准确地为现实世界建立模型.
这几年流行的web服务和SOA虽使程序间交互更方便, 但它从本质上说还是使用”面向对象+命令编程+方法调用”的思路, 在编程方法论上并没有实质的进步.
用现在流行的语言实现的完成复杂功能的程序逻辑不清晰, 原因在于”命令编程+方法调用”的设计机制. 这使程序很难模块化, 副作用无所不在, 因此很难正确实现复杂功能.
现实世界的发展变化是通过事物间的相互作用实现的, 而这种相互作用用计算机科学的语言来说就是进程间的并发(concurrency). 软件的本质是什么? 我觉得:软件总是完成某种功能的,归根到底是对现实世界的事物间相互作用进行建模. 因此软件的组成部分间自然就是并发的关系, 而不是过程调用的关系. 用相互通信的进程来对现实世界的事物间相互作用进行建模是比较合理的. 所以进程应该作为语言的基础成分, 是软件的基本组成部分, 而不是只为了提高效率才采用的.
为了使程序能准确地为现实世界建立模型, 从而正确性更高, 结构更合理, 模块化程度更高, 因此在几种编程思想或语言的基础上(见references), 我提出一种新的编程思想: 面向进程+函数编程+逻辑编程+约束编程(constraint programming)+其他合理的范式(命令编程除外)和以此为方法论的一门编程语言Processlog (全称process logic).
由于现有的并发机制要么不够理想, 存在不能接受的缺陷(如Java中的monitor机制); 要么很难应用于实际(如CSP的通道(channel)通信), Processlog中采用的并发机制是: 程序中同时运行的进程相互间通过端口来通信. 这种并发机制是我根据Abstract Behavior Types[1]的思想提出来的. 要完成两个进程间通信, 需把一个进程的输出端口和另一进程的输入端口相连, 然后在输出端口发送消息, 在输入端口接收消息就可以了. 这种机制很自然, 和现实世界的事物间相互作用是类似的.
Processlog的语法概要如下:
1 运算符
(1) ? 输入; c ? x 从输入端口c上接收输入值放到变量x中
(2) ! 输出; c ! v 把v的值从输出端口c上输出
(3) -> 顺序进行的事件的先后关系
(4) | b : s 分支
(5) a >> p.b 输出端口a连接到进程p的输入端口b
(6) a << p.b 输入端口a连接到进程p的输出端口b
(7) and, or, not 逻辑运算符
(8) 算术运算符和关系运算符 与Java中相同
2 程序的组成成分
(1) Unit 程序单元
(2) Process 进程
(3) Function 函数
(4) Predicate 谓词
(5) DataInPort 数据输入端口类型
(6) OutPort 输出端口类型
(7) InPort 输入端口类型
(8) ResultPort 结果输出端口类型
3 原子数据结构
(1) List (函数编程中的List类型, 对List的操作函数与函数编程中相同);
(2) Tuple 元组, 同Clean.
(3) Set 集合
没有数组
4 进程的定义
Process ChangeRel
( DataInPort dataIn(List, Em, Em);
ResultPort resultOut(Em);
InPort fromGetRel;
OutPort toGetRel, toDetach, toAttach, toChangeRel
)
% 生成与当前进程相连接的进程, 并配置端口间的连接
(
GetRel getRel; Detach detach; Attach attach;
toGetRel >> getRel.dataIn,
fromGetRel << getRel.resultOut;
toDetach >> detach.dataIn;
toAttach >> attach.dataIn
)
{
dataIn?(list, rlEm, em) ->
( | list=[cem:cems]:
( ChangeRel changeRel;
toChangeRel >> changeRel.dataIn % 递归进程
)
toGetRel!(rlEm.id) -> fromGetRel?rel
-> toDetach!(cem, rlEm.id)
-> toAttach!(cem, em.id, rel.level, rel.weight, rel.relation)
-> toChangeRel!(cems, rlEm, em)
)
}
进程由事件组成, 如fromGetRel?rel是输入事件, toGetRel!(rlEm.id)是输出事件.
用Processlog写的程序都可以用动态视图(见附件)来表示, 其中的方形表示进程, 箭头表示数据流向. 进程间是并行运行的, 相互通信.
5 函数
[Function] compute(double x)=
| x<=0: x*x+3
| x>0: compute(x-5)* compute(x-3)
函数只能以事件的方式在进程中使用或在其他函数中使用, 不能独立使用.
6 谓词
/* 建图 */
Predicate createGraph(t, graph):-
addNode(t, null, ({},{}), graph1),
getDS(t, graph1.ns, tlist),
addList(tlist, t, graph1, graph).
/* 加节点 */
Predicate addNode(t, null, (ns, es), (ns1, es):-
merge(ns, {t}, ns1).
Predicate addNode(t, upper, (ns, es), (ns1, es1)):-
merge(ns, {t}, ns1),
merge(es, {(upper, t)}, es1).
7 把谓词转换为函数
create(t)= graph
where createGraph(t, graph)
谓词不能独立使用也不能在进程中直接使用, 先转换为函数后再在进程中使用.
8 程序单元: 包含进程和数据类型
Unit PMDAO;
interface
Tuple M;
Process GetReleasedVersion(DataInPort dtIn, OutPort pt1 , InPort pt2);
…
implementation
M=(String id, String name, String version, …);
Process GetReleasedVersion(DataInPort dtIn, OutPort pt1 , InPort pt2)
(…)
{
…
}
指导原则: 程序是由通过端口相连接的进程组成的. 数据处理和算法用函数编程实现, 如果函数编程不适用于要处理的问题, 就使用逻辑编程或约束编程.
Processlog语言限制了编程的随意性, 要求只能用进程+函数编程+逻辑编程的方式编程, 不允许用Java或c#的命令方式编程.
Processlog 现在还没有在机器上实现. 我用该语言重写了实际项目中的一些复杂代码(原是Java代码), 证实用它写的程序确实简单清晰, 有类似数学的简洁美. "7 谓词"就是其中一部分代码.
我的想法是: 应先在纸面上规定它的语法与语义, 再通过使用它完成一些复杂的项目代码来发现它的不足, 再进而改进它, 再实践, 再改进, 直到它基本完善再在机器上实现.
现在需解决的问题是: 软件分析设计方法(不同于面向对象编程和面向过程编程)?
希望有识之士和我一起共同发展这种编程方法论和这门语言.
联系方式: juwenguang2000@yahoo.com.cn
博客: http://www.cnblogs.com/forrestju/
References
1. Farhad Arbab, Abstract Behavior Types: a foundation model for components and their composition
2. Clean http://clean.cs.ru.nl/
3. Prolog
4. Delphi
5. JCSP
注: 转载时请注明作者.
- 大小: 11.9 KB
分享到:
Global site tag (gtag.js) - Google Analytics
相关推荐
根据提供的文件信息,我们可以梳理出一个关于“最流行的编程语言排行”的详细分析。虽然原始文本可能存在一些乱码问题,但仍然可以从中提炼出关键信息。 ### 标题:最流行的编程语言排行 #### 描述: 这份文档简短...
Go编程语言,也被称为Golang,是由Google在2007年发起的开源项目,旨在创造一种简单、高效且安全的编程语言。Go语言的设计灵感来源于C语言,但同时引入了垃圾回收、并发编程和类型安全性等现代特性,使得它在系统...
编程语言是计算机世界中的基础工具,它使得人们能够与机器沟通,实现各种复杂的功能。创建自己的编程语言,虽然是一项艰巨的任务,但也充满了挑战与乐趣。本文将深入探讨如何创造编程语言,带你走进这个奇妙的世界。...
### 区块链相关编程语言概述 随着区块链技术在全球范围内的迅速崛起,越来越多的企业和机构开始探索这一领域的可能性。为了支持这些创新和发展,各种编程语言被用于构建和维护区块链系统。本文将详细介绍几种广泛...
《自制编程语言:基于C语言的实践与解析》 编程语言是计算机科学的灵魂,它连接了人类思维与机器执行的桥梁。本项目聚焦于“自制编程语言”的实践,旨在为那些对编程语言设计感兴趣的开发者提供一份实用的指南。...
在编程世界中,掌握一门或多门编程语言是成为专业IT人才的基础。本资源包提供了丰富的学习资料,共计968页,涵盖了C#、vc++、Java以及JavaWeb这四门重要的编程语言,旨在帮助初学者和进阶者提升技能,深入理解编程的...
《Go语言编程》一书由许式伟、吕桂华等人编著,旨在介绍Go语言这一新兴编程语言的全貌及其重要特性。Go语言在设计时考虑到编程的简洁性、并行与分布式支持、软件工程需求以及编程哲学的创新,力图在互联网时代成为一...
标题《Arduino编程语言参考大全(官方网站)》表明了这份文档是官方提供的Arduino编程语言的详细参考资料。Arduino是一种基于简单易用的硬件和软件平台,广泛用于电子原型设计和交互式项目。文档说明Arduino程序由三大...
Perl编程语言,被誉为“大骆驼”,是一种强大的脚本语言,尤其在文本处理、系统管理、网络编程等领域有着广泛的应用。Perl由Larry Wall于1987年创建,设计目标是提供一种灵活、强大且易读的编程工具,能够应对各种...
ST语言,全称为Structured Text,是PLC编程中常用的一种高级编程语言,它以其结构化、清晰易读的特点,被广泛应用于工业控制系统的编程。在本文中,我们将深入探讨ST语言的基本原理,包括其语法、语义以及基本元素,...
总结来说,C#编程语言是一门强大且富有创新的语言,具有丰富的特性和强大的支持库,是开发高质量、高效软件的理想选择。通过深入学习和掌握C#,开发者能够更好地应对各种编程挑战,实现复杂的软件系统。
mojo编程语言 Mojo编程语言是一种相对较新的编程语言,它基于Perl 5语言的Mojolicious框架开发,为Web开发提供了现代化的工具和功能。Mojo编程语言的语法简洁而直观,同时拥有许多现代编程语言的特性,如异步I/O、...
值得注意的是,Java 在设计之初就考虑到了互联网环境下的应用需求,这使得 Java 成为了互联网时代的一种理想编程语言。 ##### 3.2 现代编程语言的诞生:C 语言 C 语言的诞生可以看作是现代编程语言发展的一个重要...
Java作为一种编程语言,在计算机软件开发领域占据了重要的地位。它以其多线程能力、平台无关性以及在实际应用中的广泛运用而备受瞩目。 首先,Java的多线程特征是其一大亮点。在Java中,多线程意味着多个任务可以...
WinBatch是一种高档的编程语言,可以完全设定计算机,分配如简单的菜单选择、命令或热键。使用我们的完整编程语言的力量,你可以创作出强大实用的应用程序,解决日常问题,例如只需一个热键就能输入一段完整的句子。...
Pony,作为一种开源的编程语言,以其独特的特性在IT领域内独树一帜。它的设计目标是结合actor模型、功能安全性和高性能,使其成为开发复杂分布式系统、高并发应用以及对安全性有严格要求项目的理想选择。下面,我们...
### MOJO编程语言详解 #### 一、MOJO编程语言的特点 MOJO作为一种新兴的编程语言,具有多项显著特点,这些特点使其在编程语言领域独树一帜。 1. **简洁性和可读性:** - MOJO的设计理念强调代码的简洁与可读性。...
C#编程语言是一种由微软开发的强大且广泛应用的编程语言,主要设计用于构建Windows平台上的应用程序。它被广泛应用于游戏开发、Web应用、桌面应用以及移动应用等。C#结合了面向对象编程(OOP)的概念,使其成为学习...