公共命名空间和新编译原理

公共命名空间将发展成新汇编语言,这就需要新编译原理支持,才能实现自然语言编程。

公共命名空间中储存着所有方言的所有句子,每一行是一个句子,每一列是一种方言。可以进行翻译,也就是同一行中的不同方言间的翻译。中文是一种方言,英文是一种方言,C语言是一种,java也是一种……以前面向百度编程时,搜索的关键词描述了我遇到的问题,搜索的结果多是一些技术博客、文章。如果在公共命名空间中搜索,输入的内容就从中文方言那一列里边找,找到之后再去找对应的列,即方言,比如C语言,我能得到用C语言实现的代码。

为什么说公共命名空间会成为新汇编语言?因为汇编语言在处理“人数加一”这一任务时,用的是eax寄存器加一这一操作。到了C语言等高级语言中,才成为population++。公共命名空间中的所有句子,看上去很强大,因为我们收录了所有句子,但实际上它不能实现自然语言编程,其原理大约就是eax和population的关系吧,我猜。汇编语言是机器语言和文本符号间的简单映射,正如公共命名空间是问题空间中的简单映射。总之,公共命名空间将发展成新汇编语言。

C语言等高级语言使用的是上下文无关文法,对于实现上下文有关文法和短语文法,我持悲观态度。我们需要新的编译原理,但这种编译原理是什么样子,应该在公共命名空间之后研究。顺着四型文法的思路走下去,不会有我们想要的东西,即自然语言编程。

本文主要是为了推广“公共命名空间”,以及预言了新编译原理的存在。对于公共命名空间的设想是清晰的,至于新编译原理,则是模糊的。用现有的lex+yacc实现公共命名空间是可行的。S→S1|S2|…每个Si都对应公共命名空间中的一行,大约就是这样。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值