Skip to content

Latest commit

 

History

History
91 lines (60 loc) · 2.62 KB

nodejs与go比较.md

File metadata and controls

91 lines (60 loc) · 2.62 KB

nodejs与go比较

nodejs和go均擅长做web服务器

nodejs go
内存限制 64 位操作系统约为 1.4G
32 位操作系统约为 0.7G

go-nodejs-comparison.png

nodejs和golang协程的不同

nodejs和golang都是支持协程的,从表现上来看,nodejs对于协程的支持在于async/await,golang对协程的支持在于goroutine。关于协程的话题,简单来说,可以看作是非抢占式的轻量级线程。

nodejs await协程

function sleep(ms){
  return new Promise((resolve,reject) => setTimeout(
     ()=>resolve(),ms
  ))
}

async function hello(){
  await sleep(3000)
  console.log("hello")
};

async function test(){
  await sleep(3000)
  console.log("world")
};

hello();
test();

go协程

package main

import (
  "fmt"
  "time"
)

func deferPrint(str string){
  time.Sleep(time.Second*2)
  fmt.Println(str)
}

func main(){
  go deferPrint("hello")
  go deferPrint("world")
  //如果主协程不阻塞,永远不会切换

  time.Sleep(time.Second*4)
}

线程支持

golang之所以要支持锁协程,我想是为了多线程支持。golang中可以启用多个线程并行执行相同数量的协程。

nodejs受限于v8的isolate机制,只能跑在单线程中。所有代码无法并行执行,无法处理计算密集型应用场景。

切换机制

nodejs使用await阻塞协程,手动切换线程控制权,node的协程是c++控制的,c++里写了这个函数可以被推入事件队列就能够用promise封装成协程

golang在协程阻塞时自动切换协程,所以在写golang的时候所有的代码可以都写同步代码,然后用go关键字去调用,golang的协程是自己规定的,所有函数在阻塞时都必须切换线程控制权

取返回值

  • nodejs中async函数是能直接返回值的
  • golang只能传递一个引用的channel

golang类似与小c++,最大的亮点就是使用协程管理多线程。

参考链接