`
forrestju
  • 浏览: 3797 次
  • 性别: Icon_minigender_1
  • 来自: 济南
文章分类
社区版块
存档分类
最新评论

理想的编程语言

 
阅读更多
理想的编程语言  鞠文广

以下纯粹是个人观点, 不代表任何组织或社团.
关键词: 并发编程 函数编程 逻辑编程
摘要: 由于现有语言不能很好的为现实世界建模, 我提出一种编程方法论和编程语言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
分享到:
评论
17 楼 forrestju 2009-08-10  
ray_linn 写道
面向进程+函数编程+进程间通信+逻辑编程+约束编程 =C#+F#+Nemerble+Axum+Microsoft.Contract=.net


你能确定哪种情形下采用哪种方式最有效率? 还是MS的方法好,分而化之,信手拈来。


我在google上没搜到Nemerble和Microsoft.Contract.
Axum是基于Actor模型的,它不如通信进程科学,合理.
16 楼 Magicloud 2009-08-10  
1. 面向对象和并发不冲突。
T1君曾有引文,论述真正的面向对象是解决并发的好思想。
个人认为c++、java只是初级的面向对象,很多理论细节采用命令式的方法来解决(比如楼主提到的方法调用)。而作为不纯粹的面向对象,当然不能发挥其应有能量。
纯粹的面向对象,内容之一就是对象间使用消息交互,没有任何规定要一个对象“等待”另一个对象。而在单线时代,这些都被做成“必然”了。当我们重新审视面向对象,会发现每个对象独占一个进程是多么的美丽。
2. 单纯的函数编程只能避免代码错误,不能从设计上约束代码混乱。
函数编程,重要的一点是避免了边际效应,并有助计算、策略的分离。但对比接口、类定义,函数式编程不能把代码级的混乱约束在足够小的单位内。还是需要程序员的自觉……
所以面向对象的代码编写促进了高级的设计人才和便宜的软件蓝领的产业结构。
3. 将每一个计算片段(不可再并发的最小单位)分配一个进程,并相互通信(如楼主代码例456),在erlang中可以原生实现。

所以知道,有强大对象的ruby(个人认为)、纯函数的haskell、并发和通信都原生支持的erlang,各有其超长之处,又都不完美。
而如我前述,某些问题可以归结为文字表达的问题,比如代码的约束,这一点,我们可以通过其他辅助手段来实现,成本(实施以及人员更替等)将是低于把一门全新的语言做到成熟的。另一些问题,则是库、底层实现的问题,和代码用<-还是=来取值没关系。Haskell没有好的进程及通信支持,做个库嘛。另外,erlang的强力进程切换,我不认为能在jvm上做出来……

我认为楼主当先把一些编程理论吃透,再行组合。而不是重新造个轮子,然后发现和其他轮子没大区别……
15 楼 CharlesCui 2009-08-10  
这是个好帖子,里面的回复更值得细细推敲,顶楼主。

我认为提高生产工具的效率到一定程度之后,就再发挥下劳动者的能动力会更高效。

屠龙刀厉害吧,但内力不够的人用起来威力也不大,这时候需要提高使用者的基本功。
但有的人不需要屠龙刀和倚天剑就可以驰骋江湖了,比如张三丰和张无忌,因为他们的内力十足,用不到这么NB的东西了,他们自己更NB。

衡量好这个点,就会知道你是该创造一个更NB的工具,还是锻炼自身的基本功了。
14 楼 ray_linn 2009-08-10  
面向进程+函数编程+进程间通信+逻辑编程+约束编程 =C#+F#+Nemerble+Axum+Microsoft.Contract=.net


你能确定哪种情形下采用哪种方式最有效率? 还是MS的方法好,分而化之,信手拈来。
13 楼 forrestju 2009-08-10  
Magicloud 写道
首先问楼主,会用erlang吗?了解eiffel的思想么?

我学编程十几年了,也有过楼主类似的想法,这个也不好,那个也不行。而语言接触的越多,越觉得“发明”一种新的语言没什么意义。我们需要的“功能”已经早已不是需要“字面表达”方式来解决的了。


我不会用erlang.
函数编程语言中我只会用Clean(前年学的),正像我只会用一种面向对象语言Java一样.
我前年才了解eiffel的思想,其中核心思想是DBC.
我学编程13年,掌握的编程语言可能比你少, 我只会:C, Pascal, Delphi, java, clean, Prolog.

Magicloud 写道
我们需要的“功能”已经早已不是需要“字面表达”方式来解决的了。

不太明白,想问一句:你说的是什么"功能"? “字面表达”方式是什么方式?
12 楼 Magicloud 2009-08-10  
首先问楼主,会用erlang吗?了解eiffel的思想么?

我学编程十几年了,也有过楼主类似的想法,这个也不好,那个也不行。而语言接触的越多,越觉得“发明”一种新的语言没什么意义。我们需要的“功能”已经早已不是需要“字面表达”方式来解决的了。
11 楼 forrestju 2009-08-10  
wenjixiao 写道
语言知识表达的方式而已,就好像你可以说“你好”,也可以说成是"how are you"。
实际上,都没有改变什么。所以,不应该追求什么完美的语言,而是,要加强对实际问题的分析理解能力。要增强内功,而不是花巧的招式。

科学理论是在实践基础上经过研究得来的, 不能只停留于实践, 不然科学怎么能进步.
10 楼 forrestju 2009-08-10  
Trustno1 写道
软件设计中的代码可重用性,与编程语言无关,而在于领域本身的内在禀性。确切地说,是在于领域问题的内在"熵"。
软件设计的根本任务,即不在于模拟世界,也不在于用各种模块搭建架构,而是在于如何"压缩"代码,以逼近本领域的内在"熵"极限。



不明白领域问题的内在"熵"是什么意思. 我觉得研究问题首先要概念明确, 如果概念很含糊, 那就很难进一步研究. 例如:中国古代哲学中的"气","形"等概念很含糊,概念含糊是中国古代哲学与科技落后的一个重要影响因素.
9 楼 forrestju 2009-08-10  
秦汉唐宋明 写道
很有思想!楼主能否贴点你用这个语言重写的一些代码?


我是不能公开贴的, 我担心引起知识产权问题, 毕竟是公司的项目. 不过,有兴趣的话可以用邮件联系.

juwenguang2000@yahoo.com.cn
8 楼 forrestju 2009-08-10  
我觉得在讨论问题时,大家不要太过于情绪化了,否则只知道维护自己的已有观点,而不是要探寻真理.

我们实际上是在做研究, 研究合理的编程语言.
7 楼 forrestju 2009-08-10  
mock1234 写道

我是技术高手,所以我可以用你鄙视的那些语言写出优美的并行和进程通讯程序,基于语义网络的逻辑搜索程序,而无需等到语言的进化就实际去开始真正称得上实践的研究。

我建议你把精力放在解决问题的机制的研究上,先不要纠缠于语言之争。语言确实可以清晰地表达算法和结构,以及通信方式,但是你如果能够用别人擅长的语言来说清楚一整套你自己认为很牛逼的面向应用的系统设计问题,你说的才是真正牛逼的事情。如果你先忽悠别人放弃别人的语言,那恐怕大多数人都会觉得闲的无聊的时候才会介入编程语言之争。

大概有超过7、8年的时间,我都想对我研究了十几年的全局逻辑解题系统开发个框架出来。什么prolog之类的纯粹是不值一提,根本不能反应任何人工智能。可是,我知道这根本不是忽悠编程语言的问题,不论是使用java还是c++甚至basic都照样可以来实现逻辑系统的解题过程,首先跟语言没有关系,如果框架的实际内涵不清晰那么妄想设计出个语言来证明你懂行,也就无法被人理喻。

“流行”编程语言为什么流行,不是因为它是表达晦涩难懂的框架的理想语言,而是因为它是通用地表达各种设计框架。你先用通用编程语言来进行一些稍微大型一点的测试项目,来证明你的理论能不能解决实际问题,有没有那么高的市场价值,然后再开发特别的编程语言来给你的框架做写锦上添花吸引一些非职业编程人员,这样比较好。


我不是鄙视什么语言, 前人创造的事物有的合理,有的不合理, 不能全盘接受. 你有没有思考过你现在用的语言有哪些重要方面不合理? 你真的觉得现在这种面向对象语言很合理吗?

我在文章中已经说了, 我正在用这门语言在实际的复杂项目中实践. 我参与的项目都是大项目.
6 楼 forrestju 2009-08-10  
mock1234 写道

这是不是说你的“语言”还不是一个靠谱的一步一步成功的语言,而是一步登天(如果登不上去就干脆摔死)的语言?!


语言是需要逐步完善的, 不是一下子就提出一个完善的语言.现在的ProcessLog只是雏形,我需要不断用它来实践来逐步完善, 等觉得足够完善了,再在机器上实现它.
5 楼 wenjixiao 2009-08-10  
语言知识表达的方式而已,就好像你可以说“你好”,也可以说成是"how are you"。
实际上,都没有改变什么。所以,不应该追求什么完美的语言,而是,要加强对实际问题的分析理解能力。要增强内功,而不是花巧的招式。
4 楼 Trustno1 2009-08-07  
软件设计中的代码可重用性,与编程语言无关,而在于领域本身的内在禀性。确切地说,是在于领域问题的内在"熵"。
软件设计的根本任务,即不在于模拟世界,也不在于用各种模块搭建架构,而是在于如何"压缩"代码,以逼近本领域的内在"熵"极限。


3 楼 秦汉唐宋明 2009-08-07  
很有思想!楼主能否贴点你用这个语言重写的一些代码?
2 楼 night_stalker 2009-08-07  
一定要看看 FX 推荐的 Katahdin

这是最 nb 的语言,要什么,就有什么,不要什么,就没什么 …… 直接消灭框架。
1 楼 Magicloud 2009-08-07  
感觉作者说的没有任何新意……
其中部分问题的本质是有否合适的框架支持。
另一些部分的问题,不过是因为java不能简明的实现随意的语法糖而已。

相关推荐

    最流行的编程语言排行.txt

    根据提供的文件信息,我们可以梳理出一个关于“最流行的编程语言排行”的详细分析。虽然原始文本可能存在一些乱码问题,但仍然可以从中提炼出关键信息。 ### 标题:最流行的编程语言排行 #### 描述: 这份文档简短...

    Go编程语言Go编程语言Go编程语言Go编程语言Go编程语言Go编程语言Go编程语言Go编程语言.zip

    Go编程语言,也被称为Golang,是由Google在2007年发起的开源项目,旨在创造一种简单、高效且安全的编程语言。Go语言的设计灵感来源于C语言,但同时引入了垃圾回收、并发编程和类型安全性等现代特性,使得它在系统...

    教你创造编程语言

    编程语言是计算机世界中的基础工具,它使得人们能够与机器沟通,实现各种复杂的功能。创建自己的编程语言,虽然是一项艰巨的任务,但也充满了挑战与乐趣。本文将深入探讨如何创造编程语言,带你走进这个奇妙的世界。...

    区块链相关编程语言

    ### 区块链相关编程语言概述 随着区块链技术在全球范围内的迅速崛起,越来越多的企业和机构开始探索这一领域的可能性。为了支持这些创新和发展,各种编程语言被用于构建和维护区块链系统。本文将详细介绍几种广泛...

    968页学习资料 编程语言

    在编程世界中,掌握一门或多门编程语言是成为专业IT人才的基础。本资源包提供了丰富的学习资料,共计968页,涵盖了C#、vc++、Java以及JavaWeb这四门重要的编程语言,旨在帮助初学者和进阶者提升技能,深入理解编程的...

    Go语言编程_许式伟_完整版1

    《Go语言编程》一书由许式伟、吕桂华等人编著,旨在介绍Go语言这一新兴编程语言的全貌及其重要特性。Go语言在设计时考虑到编程的简洁性、并行与分布式支持、软件工程需求以及编程哲学的创新,力图在互联网时代成为一...

    Arduino编程语言参考大全(官方网站)

    标题《Arduino编程语言参考大全(官方网站)》表明了这份文档是官方提供的Arduino编程语言的详细参考资料。Arduino是一种基于简单易用的硬件和软件平台,广泛用于电子原型设计和交互式项目。文档说明Arduino程序由三大...

    perl 编程语言 大骆驼

    Perl编程语言,被誉为“大骆驼”,是一种强大的脚本语言,尤其在文本处理、系统管理、网络编程等领域有着广泛的应用。Perl由Larry Wall于1987年创建,设计目标是提供一种灵活、强大且易读的编程工具,能够应对各种...

    (完整版)ST语言编程手册.doc

    ST语言,全称为Structured Text,是PLC编程中常用的一种高级编程语言,它以其结构化、清晰易读的特点,被广泛应用于工业控制系统的编程。在本文中,我们将深入探讨ST语言的基本原理,包括其语法、语义以及基本元素,...

    C#编程语言详解C#编程语言详解[评价可免费]

    总结来说,C#编程语言是一门强大且富有创新的语言,具有丰富的特性和强大的支持库,是开发高质量、高效软件的理想选择。通过深入学习和掌握C#,开发者能够更好地应对各种编程挑战,实现复杂的软件系统。

    mojo编程语言介绍及示例代码.zip

    mojo编程语言 Mojo编程语言是一种相对较新的编程语言,它基于Perl 5语言的Mojolicious框架开发,为Web开发提供了现代化的工具和功能。Mojo编程语言的语法简洁而直观,同时拥有许多现代编程语言的特性,如异步I/O、...

    java 很好的文档

    值得注意的是,Java 在设计之初就考虑到了互联网环境下的应用需求,这使得 Java 成为了互联网时代的一种理想编程语言。 ##### 3.2 现代编程语言的诞生:C 语言 C 语言的诞生可以看作是现代编程语言发展的一个重要...

    计算机软件开发中JAVA编程语言及其实际应用.pdf

    Java作为一种编程语言,在计算机软件开发领域占据了重要的地位。它以其多线程能力、平台无关性以及在实际应用中的广泛运用而备受瞩目。 首先,Java的多线程特征是其一大亮点。在Java中,多线程意味着多个任务可以...

    WinBatch(高档编程语言)软件v2016B免费版

    WinBatch是一种高档的编程语言,可以完全设定计算机,分配如简单的菜单选择、命令或热键。使用我们的完整编程语言的力量,你可以创作出强大实用的应用程序,解决日常问题,例如只需一个热键就能输入一段完整的句子。...

    cpp-Pony是开源actor模型功能安全高性能的编程语言

    Pony,作为一种开源的编程语言,以其独特的特性在IT领域内独树一帜。它的设计目标是结合actor模型、功能安全性和高性能,使其成为开发复杂分布式系统、高并发应用以及对安全性有严格要求项目的理想选择。下面,我们...

    MOJO编程语言是一种相对较新的编程语言.pdf

    ### MOJO编程语言详解 #### 一、MOJO编程语言的特点 MOJO作为一种新兴的编程语言,具有多项显著特点,这些特点使其在编程语言领域独树一帜。 1. **简洁性和可读性:** - MOJO的设计理念强调代码的简洁与可读性。...

    简单的中文编程语言青语言是一门完全基于中文语言习惯打造的编程语言,主要面向青少年、儿童和非专业人士

    青语言是一门完全基于中文语言习惯打造的编程语言,主要面向青少年、儿童和非专业人士。当今世界信息化高速发展,信息技术已成为促进社会进步的重要推力。随着我国信息化的不断进步,尤其是互联网行业的高速发展,...

    教你怎么去学一门编程语言

    学习编程语言是一个既有挑战又充满乐趣的过程,尤其对于初学者来说,正确的学习方法至关重要。本文将深入探讨如何高效地学习编程语言,并在短时间内达到熟练掌握的水平。 首先,选择一门适合初学者的语言至关重要。...

Global site tag (gtag.js) - Google Analytics