您的位置:首页 > 编程语言 > Go语言

利用channel在goroutins之间控制同步和传递数据

2016-09-17 08:17 465 查看

利用channel在goroutins之间控制同步和传递数据

发表回复

在java等代码中,我们查询数据库的操作:

1

2

3

4

5

6

sql = "select * from ....";

result = db.query(sql)
for(item in result)
{

.....
}
但是在go语言中,这么做就有些土了,我们可以利用channel天生的队列和线程同步的特性来实现。这也是go和其它语言很明显的思维区别。

db的封装:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

package main

var database *db

type db struct {

    req   chan string

    res   chan interface{}
}

func init() {

    database = NewDB()

    go database.Run()
}

//处理查询请求,请req channel中的SQL取到,执行查询后结果放在res channel中

func (d *db) Run()
{

    var s string

    for {

        s = <-d.req

        d.res <- d.query(s)

    }
}

func (d *db) query(sql string) interface{}{

    //...
}

func NewDB()
*db {

    out := new(db)

    out.req = make(chan string)

    out.res = make(chan bool)

    return out
}
调用时,将sql放入请求队列,并阻塞等待响应结果

1

2

3

4

sql := "select * from ...";
if database.req
<- sql; res<-database.res
{

    //use res
}
这么做的好处:

1、实现了同步获取结果,和直接一个线程里调用方法效果相似。

2、调用和被调用在独立的协程里

3、查询列表是一个先进先出的队列
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: