培训首页  >  web前端新闻  >  兄弟连区块链入门教程并发技术:读写锁

兄弟连区块链入门教程并发技术:读写锁

[2018-09-28 16:43:44] 浏览量:97 来源:

北京兄弟连IT

  兄弟连区块链入门教程并发技术读写锁“区块链+时代无疑会是下一个风口,然而现在的区块链行业专业型人才正在遭遇瓶颈”兄弟连教育区块链培训学院院长尹成表示,“希望能通过兄弟连教育区块链学院为社会为企业培养并输送更多优质的区块链高精尖型技术.(

读写锁概述

· 除了上一篇提到的互斥锁以外,Go语言还给我们提供了另一种资源锁——读写锁(sync.RWMutex);

· 读写锁可以锁定和解锁两种模式:只读模式和只写模式:

· 只读模式:多路只读不可写;

· 只写模式:单路只写不可读;

只读模式示例

//定义读写锁

var rwMutex sync.RWMutex

 

/*只读模式:多路只读不可写*/

func main() {

for i := 0; i < 3; i++ {

go read(i)

}

time.Sleep(500 * time.Millisecond)

for i := 0; i < 3; i++ {

go write(i)

}

time.Sleep(10*time.Second)

}

 

func read(i int) {

rwMutex.RLock()

fmt.Println(i, "reading...")

time.Sleep(time.Second)

fmt.Println(i, "read over")

rwMutex.RUnlock()

}

 

func write(i int) {

rwMutex.Lock()

fmt.Println(i, "writing...")

time.Sleep(time.Second)

fmt.Println(i, "write over")

rwMutex.Unlock()

}

其输出效果为:
1 reading…
2 reading…
0 reading…
0 read over
2 read over
1 read over
2 writing…
2 write over
0 writing…
0 write over
1 writing…
1 write over

不难看出,在只读模式下,三条协程同时在进行读取;而只有全部读取协程结束并释放只读锁后,写模式才得以执行——此之谓多路只读不可写

只写模式示例

//定义读写锁

var rwMutex sync.RWMutex

 

/*只写模式:单路只写不可读*/

func main() {

for i := 0; i < 3; i++ {

go write(i)

}

time.Sleep(500 * time.Millisecond)

for i := 0; i < 3; i++ {

go read(i)

}

 

time.Sleep(10*time.Second)

}

 

func read(i int) {

rwMutex.RLock()

fmt.Println(i, "reading...")

time.Sleep(time.Second)

fmt.Println(i, "read over")

rwMutex.RUnlock()

}

 

func write(i int) {

rwMutex.Lock()

fmt.Println(i, "writing...")

time.Sleep(time.Second)

fmt.Println(i, "write over")

rwMutex.Unlock()

}

其输出为:
1 writing…
1 write over
0 reading…
1 reading…
2 reading…
2 read over
0 read over
1 read over
2 writing…
2 write over
0 writing…
0 write over

不难看出,在只写锁释放之前,只有一条协程可以执行写操作,其余协程无论读写都被阻塞——此之谓单路只写不可读”;
当只写锁释放时,首先被只读锁抢到资源,又是一个三路齐读没有写;
最后再次锁定为只写时,也是逐条写入直到释放只写锁,其间其余的写协程全部被阻塞;

 本文出自兄弟连区块链教程:更多区块链视频教程/源码/课件/学习资料-企鹅QUN:

文中图片素材来源网络,如有侵权请联系删除
  • 软件开发
  • 软件测试
  • 数据库
  • Web前端
  • 大数据
  • 人工智能
  • 零基础
  • 有HTML基础
  • 有PHP基础
  • 有C语言基础
  • 有JAVA基础
  • 其他计算机语言基础
  • 周末班
  • 全日制白班
  • 随到随学

网上报名

热门信息