本文整理汇总了Golang中github.com/fmstephe/flib/queues/spscq.PointerQ.FailedReads方法的典型用法代码示例。如果您正苦于以下问题:Golang PointerQ.FailedReads方法的具体用法?Golang PointerQ.FailedReads怎么用?Golang PointerQ.FailedReads使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类github.com/fmstephe/flib/queues/spscq.PointerQ
的用法示例。
在下文中一共展示了PointerQ.FailedReads方法的3个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Golang代码示例。
示例1: pqsDequeue
func pqsDequeue(msgCount int64, q *spscq.PointerQ, done chan bool) {
runtime.LockOSThread()
start := time.Now().UnixNano()
sum := int64(0)
checksum := int64(0)
var v unsafe.Pointer
for i := int64(1); i <= msgCount; i++ {
v = q.ReadSingle()
for v == nil {
v = q.ReadSingle()
}
pv := int64(uintptr(v))
sum += pv
checksum += i
if pv != i {
print(fmt.Sprintf("Bad message. Expected %d, found %d (found-expected = %d)", pv, i, pv-i))
}
}
nanos := time.Now().UnixNano() - start
printSummary(msgCount, nanos, q.FailedWrites(), q.FailedReads(), "pqs")
expect(sum, checksum)
done <- true
}
示例2: pqarlDequeue
func pqarlDequeue(msgCount int64, q *spscq.PointerQ, batchSize int64, done chan bool) {
runtime.LockOSThread()
start := time.Now().UnixNano()
sum := int64(0)
checksum := int64(0)
t := int64(1)
var buffer []unsafe.Pointer
for t < msgCount {
buffer = q.AcquireRead(batchSize)
for buffer == nil {
buffer = q.AcquireRead(batchSize)
}
for i := range buffer {
t++
sum += int64(uintptr(buffer[i]))
checksum += t
}
q.ReleaseReadLazy()
}
nanos := time.Now().UnixNano() - start
printSummary(msgCount, nanos, q.FailedWrites(), q.FailedReads(), "pqarl")
expect(sum, checksum)
done <- true
}
示例3: pqrwDequeue
func pqrwDequeue(msgCount int64, q *spscq.PointerQ, batchSize int64, done chan bool) {
runtime.LockOSThread()
start := time.Now().UnixNano()
sum := int64(0)
checksum := int64(0)
t := int64(1)
buffer := make([]unsafe.Pointer, batchSize)
for t < msgCount {
if batchSize > msgCount-t {
buffer = buffer[:msgCount-t]
}
for r := false; r == false; r = q.Read(buffer) {
}
for i := range buffer {
t++
sum += int64(uintptr(buffer[i]))
checksum += t
}
}
nanos := time.Now().UnixNano() - start
printSummary(msgCount, nanos, q.FailedWrites(), q.FailedReads(), "pqrw")
expect(sum, checksum)
done <- true
}