本文整理汇总了Golang中github.com/cmu440-F15/paxosapp/rpc/paxosrpc.GetValueReply.V方法的典型用法代码示例。如果您正苦于以下问题:Golang GetValueReply.V方法的具体用法?Golang GetValueReply.V怎么用?Golang GetValueReply.V使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类github.com/cmu440-F15/paxosapp/rpc/paxosrpc.GetValueReply
的用法示例。
在下文中一共展示了GetValueReply.V方法的7个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Golang代码示例。
示例1: GetValue
func (pn *paxosNode) GetValue(args *paxosrpc.GetValueArgs, reply *paxosrpc.GetValueReply) error {
// fmt.Println("Get value begins, numNodes:", pn.numNodes)
tempValue, ok := pn.keyValue[args.Key]
if !ok {
fmt.Println("Keynotfound")
reply.Status = paxosrpc.KeyNotFound
reply.V = nil
return nil
}
reply.V = tempValue.Value
reply.Status = paxosrpc.KeyFound
return nil
}
示例2: GetValue
// GetValue looks up the value for a key, and replies with the value or with
// the Status KeyNotFound.
func (pn *paxosNode) GetValue(args *paxosrpc.GetValueArgs, reply *paxosrpc.GetValueReply) error {
key := args.Key
pxi := pn.getInstance(key)
pxi.storeLock.RLock()
defer pxi.storeLock.RUnlock()
value := pxi.CommittedVal
if value == nil {
reply.Status = paxosrpc.KeyNotFound
reply.V = nil
} else {
reply.Status = paxosrpc.KeyFound
reply.V = value
}
return nil
}
示例3: GetValue
func (pn *paxosNode) GetValue(args *paxosrpc.GetValueArgs, reply *paxosrpc.GetValueReply) error {
key := args.Key
if value, found := pn.store[key]; found {
reply.Status = paxosrpc.KeyFound
reply.V = value
} else {
reply.Status = paxosrpc.KeyNotFound
}
return nil
}
示例4: GetValue
// It will check whether the key is in the storage
// If so, return the value and set status as KeyFound
// If not, set status as Key Not Found
func (pn *paxosNode) GetValue(args *paxosrpc.GetValueArgs, reply *paxosrpc.GetValueReply) error {
recvKey := args.Key
pn.storage.storageLock.Lock()
defer pn.storage.storageLock.Unlock()
if value, ok := pn.storage.storage[recvKey]; ok {
reply.Status = paxosrpc.KeyFound
reply.V = value
} else {
reply.Status = paxosrpc.KeyNotFound
fmt.Println("[GETVALUE] Key Not Found")
}
return nil
}
示例5: GetValue
func (pn *paxosNode) GetValue(args *paxosrpc.GetValueArgs, reply *paxosrpc.GetValueReply) error {
pn.nodeMutex.Lock()
defer pn.nodeMutex.Unlock()
val, ok := pn.valueMap[args.Key]
if !ok {
reply.Status = paxosrpc.KeyNotFound
} else {
reply.Status = paxosrpc.KeyFound
reply.V = val
}
return nil
}
示例6: GetValue
func (pn *paxosNode) GetValue(args *paxosrpc.GetValueArgs, reply *paxosrpc.GetValueReply) error {
// i think eventually this needs to be a survey of all the nodes, but for now, just taking
// local values
pn.storageMutex.Lock()
defer pn.storageMutex.Unlock()
val, ok := pn.storage[args.Key]
if ok {
reply.Status = paxosrpc.KeyFound
reply.V = val
} else {
reply.Status = paxosrpc.KeyNotFound
}
return nil
}
示例7: GetValue
// return the value
func (pn *paxosNode) GetValue(args *paxosrpc.GetValueArgs, reply *paxosrpc.GetValueReply) error {
reply.V = pn.valueMap[args.Key]
return nil
}