当我生成消息时,我正在使用Go中编写的Sarama库来读取错误通道。整个代码看起来像这个包含在函数中:
/*
function count(objectValues){
var count = 0;
objectValues.forEach(elt => count += Object.values(elt).length + Object.keys(elt).length);
return count;
} */
function countrec(objectValues){
if(typeof objectValues !== "object"){
return 1;
}
var count = Object.keys(objectValues).length;
Object.values(objectValues).forEach(elt => count += countrec(elt));
return count;
}
var jsonArray = {
'-1': { '-1': 'b', '2': 'a', '10': 'c' }, '2': { '-1': 'a', '2': 'b', '10': 'a' }, '5': { '-1': 'a', '2': 'a', '10': 'b' }
};
console.log(countrec(jsonArray));
随着我对常规程序的理解,我的常规程序将继续迭代producer.AsyncProducer.Input() <- &sarama.ProducerMessage{Topic: topic, Key: nil, Value: sarama.ByteEncoder(message)}
go func() {
for err := range saramaProducer.Errors() {
if producer.callbacks.OnError != nil {
producer.callbacks.OnError(err)
}
}
}()
通道,直到它收到一个。一旦我的功能执行完毕,有没有办法让它停止侦听错误?
答案 0 :(得分:1)
您可以使用其他频道和select
来循环返回。
var quit chan struct{}
go func() {
for {
select {
case err:=<-saramaProducer.Errors():
//handle errors
case <-quit:
return
}
}
}
defer func() { quit<-struct{}{} }()
orignal for ... range
循环不会迭代通道,直到它获得一个。相反,它会阻塞,直到遇到错误,处理它,然后再次等待新错误,直到通道关闭或main
返回。
上面的代码存在一些问题,即quit
和错误通道已准备好,select
随机选择一个,因此可能导致单个错误丢失。如果值得处理,只需将switch
与default
放在一起,即可获得该错误,然后return
。