资源竞争

Posted cucy

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了资源竞争相关的知识,希望对你有一定的参考价值。

#出现原因

竞争条件
如果一个程序在执行时依赖于特点的顺序和时序;但是有无法保证这种顺序或时序,此时就会存在竞争条件

竞争条件经常出现在那些需要性共享资源的并发程序中;当两个或多个进程(线程)同时去修改一项共享资源,
最先访问资源的进程(线程)将得到预期的结果,其他进程(线程)则不然;最终,因为程序无法判断哪个进程(线程)
最先访问了资源,所有将无法产生一致的行为

type DB struct {
	mutex *sync.Mutex
	store map[string][3]float64
}

func (db *DB) nearest(target [3]float64) string {
	var filename string
	db.mutex.Lock()
	smalllest := 100000.0

	for k, v := range db.store {
		dist := distance(target, v)
		if dist < smalllest {
			filename, smalllest = k, dist
		}
	}
	delete(db.store, filename)
	db.mutex.Unlock()
	return filename
}

以上是关于资源竞争的主要内容,如果未能解决你的问题,请参考以下文章

线程基础四 使用Monitor类锁定资源

使用带有 viewpager 的异步任务时的竞争条件

OS学习笔记四:同步机制

慎用 -race 选项

[Go] golang的竞争状态

一个测试记录:利用分段锁来处理并发情况下的资源竞争问题