c# – 使用goto的最佳实践

前端之家收集整理的这篇文章主要介绍了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;或返回合作伙伴;如果您希望返回当前填充的列表. (我认为合作伙伴关系是一个很酷的合作伙伴?)
原文链接:https://www.f2er.com/csharp/98094.html

猜你在找的C#相关文章