Erlang在1991年由爱立信公司向用户推出了第一个版本,经过不断的改进完善和发展,在1996年爱立信又为所有的Erlang用户提供了一个非常实用且稳定的OTP软件库并在1998年发布了第一个开源版本。 (推荐学习:go)

目前Erlang同时支持的操作系统有linux,windows,unix等,可以说适用于主流的操作系统上,尤其是它支持多核的特性非常适合现在的多核CPU,而分布式特性也可以很好融合目前的各种分布式集群。

Go语言是编程语言设计的又一次尝试,是对类C语言的重大改进,它不但能让你访问底层操作系统,还提供了强大的网络编程和并发编程支持。Go语言的用途众多,可以进行网络编程、系统编程、并发编程、分布式编程。

Go语言的推出,旨在不损失应用程序性能的情况下降低代码的复杂性,具有“部署简单、并发性好、语言设计良好、执行性能好”等优势,目前国内诸多 IT 公司均已采用Go语言开发项目。

Erlang和golang的区别:

第一对锁的态度不同,第二对异步IO的态度不同,第三消息机制不同。Erlang对锁非常反感,认为变量不可变可以很大程度避免锁。

Golang的观点是锁确实有很大的负担,但是锁基本上是无法避免的,一旦有人共享状态并且互相抢占去改变他,这时候锁是必须存在的。

Erlang服务器是单进程的,是逻辑上就没有并发的东西,一个Process就是一个执行体,所以Erlang的服务器和golang的服务器不一样,golang的服务器是多进程的(goroutine)一起构成的一个服务器。每个请求建立一个独立的进程(goroutine)。

但是Erlang不同,一个服务器就是一个单进程的,所有的并发请求都进入到了进程邮箱,然后这个服务器从进程邮箱里取邮件(请求的内容)处理,Erlang的服务器并没有并发的请求,所以不需要所锁。

Erlang的高并发实现,第一:每个Erlang的物理进会有很多的服务器,每个服务器是互相无干扰的,他们可以并发。第二是单服务器高并发使用的是异步IO。

go认为何时都不应该有异步IO的代码,Erlang则是在异步IO的基础上加上轻量级进程模型的混杂。

Golang对并发的支持,第一:价值回归,golang最重要的事情是让执行成本降低,golang的栈最小可以到4K。

第二:把执行体作为语言内建的标准设施(golang的代码风格只有标准化得一种)。go得并发模型是最古老的并发模型,该并发模型包括,routine,原子操作,互斥体,同步,消息,同步IO。

更多相关文章

  1. golang 如何部署到服务器?
  2. golang项目如何部署到linux服务器
  3. 运行golang程序提示进程无法启动
  4. golang服务器有优势吗
  5. golang如何做一个服务器?
  6. golang如何退出进程?
  7. golang是单进程的吗?
  8. 教你使用golang实现redis服务器
  9. 关于Go语言的http/2服务器功能及客户端使用方法

随机推荐

  1. Android P 系统应用无法对外置SD卡进行读
  2. android菜单参考资料
  3. android 设置壁纸几种方法
  4. Android上的命令内存相关
  5. android操作xml
  6. Android内核的根文件系统
  7. Android 常用布局
  8. Android动画一
  9. Android常见错误解析
  10. android 技术