IF条件未满足,但代码仍被触发

本文关键字:代码 条件 未满足 IF | 更新日期: 2023-09-27 18:18:08

我发现了一些我以前从未见过的奇怪的东西,不知道有没有人能解释一下这个问题:

旧代码:

if ((orderFileCreationStatus.OrderFileStatus == OrderFileCreationStatus.Status.ContentCreated
        || orderFileCreationStatus.OrderFileStatus == OrderFileCreationStatus.Status.NoContent)
    && orderFileCreationStatus.SpecialMeasureFileStatus != OrderFileCreationStatus.Status.Published
    && orderFileCreationStatus.PersonalisedProductFileStatus != OrderFileCreationStatus.Status.Published)
{
    webOrderHeader.OrderStatus = Domain.Duos.OrderStatus.AwaitingAuthorisation;
    webOrderHeader.AuthoriserUserId = null;
    UpdateWebOrderHeader(webOrderHeader);
    throw new Exception("Could not create the Order File for order ID: " + webOrderHeader.OrderId.ToString() + "rollback");
}

新代码:

if ((orderFileCreationStatus.OrderFileStatus == OrderFileCreationStatus.Status.ContentCreated || orderFileCreationStatus.OrderFileStatus == OrderFileCreationStatus.Status.NoContent))
{
    if(orderFileCreationStatus.SpecialMeasureFileStatus != OrderFileCreationStatus.Status.Published)
    {
        if(orderFileCreationStatus.PersonalisedProductFileStatus != OrderFileCreationStatus.Status.Published)
        {
            webOrderHeader.OrderStatus = Domain.Duos.OrderStatus.AwaitingAuthorisation;
            webOrderHeader.AuthoriserUserId = null;
            UpdateWebOrderHeader(webOrderHeader);
            throw new Exception("Could not create the Order File for order ID: " + webOrderHeader.OrderId.ToString() + "rollback");
        }
    }
}               

对于resharper来说,这两个if语句是相同的,但是这里有个问题。

在旧代码中,调试器跳过嵌套在IF中的前三行并抛出异常。

在新代码中,这可以完美地工作。有人经历过这种情况吗?更重要的是,是什么导致了这种情况。我很想知道。

IF条件未满足,但代码仍被触发

这个逻辑永远不会为真:

if(orderFileCreationStatus.SpecialMeasureFileStatus != orderFileCreationStatus.SpecialMeasureFileStatus)

你将值类型与自身进行比较,该值总是为真,然后始终将真否定为假

语句完全相同。问题一定在于正在运行的代码的版本。试着将If块分解到一个新的控制台应用程序中,看看你是否能再次重现差异:

static void Main(string[] args)
{
    bool A = true;
    bool B = false;
    bool C = true;
    bool D = true;
    bool result1 = (A || B) && C && D;
    Console.WriteLine("Old way: " + result1);
    bool result2 = false;
    if (A || B)
    {
        if (C)
        {
            if (D)
            {
                result2 = true;
            }
        }
    }
    Console.WriteLine("New way: " + result2);
    Console.ReadKey();
}