c# – 使用goto的最佳实践

在这代码中使用goto是正确的吗?还有其他选择吗?
return ExecuteReader(cmd,reader =>
{
    List<BEPartnership> partnerhip = null;

    //Partnership
    if (!((sqlDataReader) reader).HasRows)
        goto exit;

    partnerhip = 
        new List<BEPartnership>{new BEPartnership().GetFromreader(reader)};

    //Customers
    if (!reader.NextResult() && !((sqlDataReader) reader).HasRows)
        goto exit;

    foreach (BEPartnership p in partnerhip)
        p.Partner = new BECustomer().GetFromreader(reader);

    //Contracts
    if (!reader.NextResult() && !((sqlDataReader) reader).HasRows)
        goto exit;

    List<BEContractB2B> contracts = new List<BEContractB2B>();
    contracts.Add(new BEContractB2B().GetFromreader(reader));
    // contracts = new BEContractB2B().GetFromreader2(reader).ToList();

    exit:
    return partnerhip;
});

解决方法

你可以替换每个goto出口;返回null;或返回合作伙伴;如果您希望返回当前填充的列表. (我认为合作伙伴关系是一个很酷的合作伙伴?)

相关文章

原文地址:http://msdn.microsoft.com/en-us/magazine/cc163...
前言 随着近些年微服务的流行,有越来越多的开发者和团队所采...
最近因为比较忙,好久没有写博客了,这篇主要给大家分享一下...
在多核CPU在今天和不久的将来,计算机将拥有更多的内核,Mic...
c语言输入成绩怎么判断等级
字符型数据在内存中的存储形式是什么