QQ讨论摘录
三国之西蜀 11:11:19
latch和lock不同之处是lock是队列机制
在路上 11:12:47
latch不是防止数据写出到磁盘里面吗?
小熊 11:13:05
lock是队列机制是因为其功能决定的。
三国之西蜀 11:13:59
是的
在路上 11:14:29
具体怎么来实现的?
小熊 11:14:31
比如在获取一个lock的时候,如果lock已经被其它进程获取,进程就进行排队以获取这个LOCK。同时进程进入睡眠
小熊 11:15:37
既然是排队,肯定是有轮到他的时候(不考虑超时问题),轮到了就叫醒这个进程,这个进程可以继续处理
下里巴人(琦) 11:16:15
lock相对比latch时间要长 .
小熊 11:16:37
latch相对非常简单,就是一个test / set的指令。
下里巴人(琦) 11:18:33
就是一个test / set的指令 , 解释一下
小熊 11:19:36
这个latch就是一个标志(令牌)。比如初始值为0,表示没有进程获取。有一个进程想使用共享内存时,test其值为0,就将其set为1。另一个进程也要使用时,发现已经被其它进程设为1了(test),所以不能获取这个latch
小熊 11:20:16
最后一句话应该说为:因为这个标志被其它进程设为了1,因此就不能访问这个共享内存了
小熊 11:20:46
这个进程然后会进行spin状态。
小熊 11:22:05
当然spin是在多CPU的情况下才会有的(我个人理解,没有确认过)
小熊 11:23:43
spin就是空转。就是类似于我们程序中一个循环。但在这个循环里面什么事情都不干。
小熊 11:24:52
空转的时候,实际上是进程占着CPU什么事情都不干。
下里巴人(琦) 11:26:00
还要占用cpu啊
小熊 11:26:26
因为latch是轻量级的,在多CPU的情况下,这个latch的占有者进程很可能是用的其它CPU在跑。
小熊 11:27:10
因为latch是轻量级的,因此占有那个进程很可能会很快就释放了
下里巴人(琦) 11:27:47
哦
小熊 11:27:39
LATCH是针对共享内存的呀,内存操作一般都非常快。
小熊 11:28:27
spin完了之后,再去看看latch释放没有,没有就spin。一直达到spin_count这个参数。还没得到就进入睡眠了
小熊 11:29:14
因为进入睡眠,进程让出CPU,OS对进程进行上下文切换,这个过程也是比较慢的。所以ORACLE选择了空转。 以避免进入睡眠状态
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/35489/viewspace-84868/,如需转载,请注明出处,否则将追究法律责任。