golang实现并发

    要知道的是golang使用goroutine实现并发,goroutine只是官方实现的超级“线程池”,每个实例4-5kb的栈内存占用,由于事先机制而大幅减少的创建和呃呃销毁开销,是制造go号称的高并发的根本原因。

    并发不是并行,并发主要是由切片来实现“同时”运行,而并行是直接利多核实现多线程的运行,但go可以设置使用核数,以发挥多核计算机的能力,某种意义上来说,并优于并行。

    Goroutine奉行的是通过共享同行来共享内存,而不是共享内存来通信。



例子:在mian方法中开一个goroutine。

go func() {

fmt.Print("by goroutine")

}()

    运行之后你会发现,没有输出内容,这是为什么呢?如果使用单线程的思想,这是走完gorotine,在退出main方法的,但在并发中,main程序没有等待goroutine的完成,main方法就直接退出了。

这时候需要一个channel与goroutine就行沟通。

func main() {

    c := make(chan bool)

    go func() {

    fmt.Print("go go go")

    c<-false

     }()

      <-c

}

在无缓存的channel中,需要先读取,后存数据,程序就会等待存了之后再退出。



func main() {

c := make(chan bool)

go func() {

fmt.Print("go go go")

c<-false

      close(c)

}()

for v:=range c {

fmt.Println(v)

}

}

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 01.{ 换行: Opening Brace Can't Be Placed on a Separate Lin...
    码农不器阅读 2,423评论 0 14
  • 选择题 [primary] 下面属于关键字的是() A. func B. def C. struct D. cla...
    盘木阅读 1,848评论 0 29
  • 在我们谈论协程(Goroutines)泄漏之前,我们先看看并发编程的概念。并发编程处理程序的并发执行。多个连续流任...
    范彬2017阅读 6,356评论 0 7
  • 使用go1.10版本,在liteIde里开发。 1,变量声明后必须使用,不然编译不过(全局变量可以不用)。 2,变...
    adrian920阅读 1,000评论 1 1
  • 我们可以采用一些常用技巧来赢得时间。尽管我们不可能也不应该排除迅速产生的强烈感情,但我们能够控制这些情绪对自己的行...
    Fly_Catkin阅读 176评论 0 0