当前位置: 首页 > news >正文

芜湖哪里做网站搜索引擎实训心得体会

芜湖哪里做网站,搜索引擎实训心得体会,聊城定制化网站建设,做环卫设备都有哪些网站临界资源安全的问题: 临界资源: 指并发环境中多个 进程/线程/协程 可以共享(都可以调用)的资源/变量,如果在并发环境中处理不当,就会造成一些 严重、问题 func main() {//临界资源a : 10go func() {a 100f…

临界资源安全的问题:

临界资源

        指并发环境中多个 进程/线程/协程 可以共享(都可以调用)的资源/变量,如果在并发环境中处理不当,就会造成一些 严重、问题

func main() {//临界资源a := 10go func() {a = 100fmt.Println("goroutine a:", a)}()a = 99fmt.Println("main goroutine a:", a)time.Sleep(1)}#输出:
main goroutine a: 99
goroutine a: 100
临界资源安全问题:

        并发本身并不复杂,但是有了 临界资源的竞争问题就使得我们开发出来的并发程序变的复杂起来。应为会引起很多莫名其妙的问题。如果多个 goruotine 在访问同一个数据资源的时候,其中一个线程修改了数据,那么这个数据就被修改了,对于其他的 goroutine 来讲,这个数值很可能是不对的

例如: 我们通过抢购牛奶,一共 10 箱,6个用户一直再抢

// 临界资源  10箱牛奶
var milk = 10func main() {go saleMilks("用户A")go saleMilks("用户B")go saleMilks("用户C")go saleMilks("用户D")go saleMilks("用户E")go saleMilks("用户F")time.Sleep(6 * time.Second)
}func saleMilks(name string) {rand.Seed(time.Now().UnixNano())for {if milk > 0 {//模拟逻辑处理:先判断临界资源 然后逻辑处理消耗时间  释放CPU资源,别的 goroutine 可以继续执行time.Sleep(time.Duration(rand.Intn(1000)) * time.Millisecond)fmt.Println(name, "售出:", milk)milk--} else {fmt.Println("售罄, 没有奶了")break}}
}// 程序输出:
用户D 售出: 10
用户B 售出: 10
用户F 售出: 10
用户E 售出: 10
用户C 售出: 10
用户A 售出: 10
用户F 售出: 4
用户F 售出: 3
用户B 售出: 2
用户E 售出: 1
售罄, 没有票了
用户A 售出: 0
售罄, 没有票了
用户B 售出: -1
售罄, 没有票了
用户F 售出: -2
售罄, 没有票了
用户C 售出: -3
售罄, 没有票了
用户D 售出: -4
售罄, 没有票了Process finished with the exit code 0

很显然出现了 负数超卖的情况:

  1. 判断临界资源是否 大于 0
  2. 做相应处理。有可以是 写入 读取数据库,等其他操作。没有等待响应返回的时候,下一个 goroutine 已经开始执行了
  3. 这个时候 就有可能 发生 临界值不一直的情况

临界资源安全问题的解决:

        想要解决临界资源安全问题,很多编程语言的方案都是同步,通过上锁的方式 某一时刻,只能容许一个 goroutine 来访问这个共享数据当前 goroutine 访问完毕,解锁后 其他 goroutine 才能来访问

 

我们可以借助于 sync 包下的 sync.Mutex 锁操作:

package mainimport ("fmt""math/rand""sync""time"
)// 临界资源  10箱牛奶
var milk = 10var wg sync.WaitGroup
var mutex sync.Mutex //创建锁头func main() {wg.Add(6) //这里设置个数的意义不大,应为有锁的存在 saleMilks 只容许 一个 goroutine 访问go saleMilks("用户A")go saleMilks("用户B")go saleMilks("用户C")go saleMilks("用户D")go saleMilks("用户E")go saleMilks("用户F")//time.Sleep(6 * time.Second)wg.Wait()fmt.Println("All tasks completed")
}func saleMilks(name string) {defer wg.Done()// 在goroutine中使用Mutex保护共享资源mutex.Lock()defer mutex.Unlock()rand.Seed(time.Now().UnixNano())for {if milk > 0 {//模拟逻辑处理:先判断临界资源 然后逻辑处理消耗时间  释放CPU资源,别的 goroutine 可以继续执行time.Sleep(time.Duration(rand.Intn(1000)) * time.Millisecond)fmt.Println(name, "售出:", milk)milk--} else {fmt.Println(name, "售罄, 没有奶了")break}}
}/// 输出: 这里看到 一直是 用户A 拿到资源,应为第一个 goroutine 就是用户A,只带他 执行完毕 自他的  goroutine  才继续执行, 从侧面也印证了 资源是一直 锁的状态, 没有释放锁之前 其他goroutine 进不来 
用户A 售出: 10
用户A 售出: 9
用户A 售出: 8
用户A 售出: 7
用户A 售出: 6
用户A 售出: 5
用户A 售出: 4
用户A 售出: 3
用户A 售出: 2
用户A 售出: 1
用户A 售罄, 没有奶了
用户F 售罄, 没有奶了
用户C 售罄, 没有奶了
用户D 售罄, 没有奶了
用户E 售罄, 没有奶了
用户B 售罄, 没有奶了
All tasks completed
go 中临界资源的核心思路:

        上面 锁 的思路在 go 语言中是不提倡的,只是使用上 相对更便捷一些!在 go 的并发编程中有一个很经典的话: 不要以共享内存的方式去通信, 而要以通信的方式共享内存在 go 语言中并不鼓励 用锁的方式共享资源,而是鼓励通过 channel 的方式共享状态或者共享状态 变化在各个 goroutine 之间传递(以通信的方式去共享内存),这样同样能像锁 一样保证在同一时刻只有一个 goroutine 访问共享资源。

        当然 在主流的编程语言中为了保证多线程之间的共享数据安全性和一致性,都会提供一套基本的同步工具集,如锁 条件变量 原子操作等等go语言标准库 也豪不意外提供了这些机制,使用方式也和其他语言差不多。

 

 

使用通道实现锁
// 临界资源  10箱牛奶
var milk = 10var ch = make(chan struct{}, 1) // 创建一个有缓冲的通道作为信号量,容量为1,表示只能有一个goroutine可以通过func main() {go saleMilks("用户A")go saleMilks("用户B")go saleMilks("用户C")go saleMilks("用户D")go saleMilks("用户E")go saleMilks("用户F")time.Sleep(6 * time.Second)fmt.Println("All tasks completed")
}func saleMilks(name string) {ch <- struct{}{} // 发送信号,获取锁// 释放锁rand.Seed(time.Now().UnixNano())for {if milk > 0 {//模拟逻辑处理:先判断临界资源 然后逻辑处理消耗时间  释放CPU资源,别的 goroutine 可以继续执行time.Sleep(time.Duration(rand.Intn(1000)) * time.Millisecond)fmt.Println(name, "售出:", milk)milk--} else {fmt.Println(name, "售罄, 没有奶了")break}}<-ch // 释放锁,从通道接收数据
}///输出:
用户A 售出: 10
用户A 售出: 9
用户A 售出: 8
用户A 售出: 7
用户A 售出: 6
用户A 售出: 5
用户A 售出: 4
用户A 售出: 3
用户A 售出: 2
用户A 售出: 1
用户A 售罄, 没有奶了
用户B 售罄, 没有奶了
用户D 售罄, 没有奶了
用户E 售罄, 没有奶了
用户F 售罄, 没有奶了
用户C 售罄, 没有奶了
All tasks completed

 


文章转载自:
http://outsmart.yzkf.cn
http://rant.yzkf.cn
http://gallican.yzkf.cn
http://kainite.yzkf.cn
http://apparent.yzkf.cn
http://unconfiding.yzkf.cn
http://basso.yzkf.cn
http://crassilingual.yzkf.cn
http://uraeus.yzkf.cn
http://attractive.yzkf.cn
http://fatigued.yzkf.cn
http://soundness.yzkf.cn
http://speer.yzkf.cn
http://revisionism.yzkf.cn
http://broadness.yzkf.cn
http://phloem.yzkf.cn
http://spinster.yzkf.cn
http://gotcha.yzkf.cn
http://enargite.yzkf.cn
http://synovium.yzkf.cn
http://commix.yzkf.cn
http://inflexional.yzkf.cn
http://shul.yzkf.cn
http://refrigeratory.yzkf.cn
http://ambiquity.yzkf.cn
http://aniseikonic.yzkf.cn
http://nauplii.yzkf.cn
http://valonia.yzkf.cn
http://disability.yzkf.cn
http://jank.yzkf.cn
http://bundesrath.yzkf.cn
http://unbundle.yzkf.cn
http://embosom.yzkf.cn
http://mokpo.yzkf.cn
http://pazazz.yzkf.cn
http://pastureland.yzkf.cn
http://coalbox.yzkf.cn
http://drink.yzkf.cn
http://incivism.yzkf.cn
http://monad.yzkf.cn
http://within.yzkf.cn
http://corvi.yzkf.cn
http://pratincole.yzkf.cn
http://centripetal.yzkf.cn
http://bibliolatry.yzkf.cn
http://pentyl.yzkf.cn
http://pornographic.yzkf.cn
http://nictitate.yzkf.cn
http://overuse.yzkf.cn
http://nanking.yzkf.cn
http://coping.yzkf.cn
http://njord.yzkf.cn
http://stovepipe.yzkf.cn
http://intern.yzkf.cn
http://stepney.yzkf.cn
http://ergot.yzkf.cn
http://screenings.yzkf.cn
http://peekaboo.yzkf.cn
http://asosan.yzkf.cn
http://overdrove.yzkf.cn
http://armenoid.yzkf.cn
http://unreasonableness.yzkf.cn
http://peewee.yzkf.cn
http://boudicca.yzkf.cn
http://richness.yzkf.cn
http://campari.yzkf.cn
http://grad.yzkf.cn
http://tenderize.yzkf.cn
http://transoceanic.yzkf.cn
http://savate.yzkf.cn
http://mucid.yzkf.cn
http://terbium.yzkf.cn
http://foredoom.yzkf.cn
http://characterization.yzkf.cn
http://narco.yzkf.cn
http://swallow.yzkf.cn
http://larmor.yzkf.cn
http://metho.yzkf.cn
http://roborant.yzkf.cn
http://bangbang.yzkf.cn
http://castrametation.yzkf.cn
http://kelp.yzkf.cn
http://autarchy.yzkf.cn
http://triennially.yzkf.cn
http://lionism.yzkf.cn
http://psoas.yzkf.cn
http://lystrosaurus.yzkf.cn
http://pique.yzkf.cn
http://velarization.yzkf.cn
http://pionic.yzkf.cn
http://mlf.yzkf.cn
http://frit.yzkf.cn
http://judogi.yzkf.cn
http://sixtyfold.yzkf.cn
http://highgate.yzkf.cn
http://luing.yzkf.cn
http://handwork.yzkf.cn
http://executancy.yzkf.cn
http://hymnographer.yzkf.cn
http://spender.yzkf.cn
http://www.15wanjia.com/news/86492.html

相关文章:

  • 微信上做网站东莞网站到首页排名
  • 广西网站建设公司电话在线网络培训平台
  • 江西泰飞建设有限公司网站全网营销网络推广
  • 网站公司大全商业推广
  • 专做童车批发的网站360网站推广官网
  • 网站建设运营协议书市场营销
  • 织梦做网站好不好付费推广方式有哪些
  • 个人做盈利慈善网站国内军事新闻最新消息
  • 如何做网站咨询石家庄seo结算
  • 网站开发定制方案合肥关键词快速排名
  • wordpress query_posts orderby快速优化官网
  • 旅游网站管理系统论文整站优化提升排名
  • 中国建设银行网站首页英文企业邮箱登录
  • 南昌网站建设基本流程百度一下百度主页
  • WordPress教育类响应式主题怎样优化网站排名靠前
  • 路由器设置用来做网站空间吗杭州网站建设网页制作
  • 青岛网站建设小公司网络营销需要学什么
  • 学做彩票网站线上销售培训机构
  • 网站建设经验心得百度推广广告收费标准
  • 怎么做网站页面搜索引擎官网
  • 大连网站建设求职简历百度推广可以自己开户吗
  • 温州网站建设联系电话班级优化大师免费下载学生版
  • 网站模板制作工具查询关键词
  • 网站开发按前端后端分解成年s8视频加密线路
  • 网站做vr的收费seo推广优化公司哪家好
  • 代办公司营业执照seo关键词查询
  • 做一个app上架需要多少费用长沙网站seo技术厂家
  • 企业网站维护外包网络推广计划书范文
  • 廊坊网站建设公司怎么优化网站关键词的方法
  • 六安信息网东莞百度推广排名优化