2

所以我有这个方法:

public string SaveImage(AppConfig imagePath, string ImageNameFilter)
{
    if (selectedFileName == null)
    {
        return null;//No image is selected - return
    }
    string imgPath = imagePath.ConfigValue.ToString();
    string baseFileName = Path.GetFileNameWithoutExtension(selectedFileName);
    string extension = Path.GetExtension(selectedFileName);

    string temp = Path.GetFileNameWithoutExtension(selectedFileName);

    if (!baseFileName.StartsWith(ImageNameFilter))
    {
        throw new InvalidImageException("The image name must starts with  " + ImageNameFilter);
    }
    else
    {
        for (int i = 1; i < (int.MaxValue - 1); i++)
        {
            if (File.Exists(imgPath + "\\" + baseFileName + extension))
            {
                baseFileName = temp;
            }
            else
            {
                File.Copy(selectedFile, imgPath + "\\" + baseFileName + extension);
                return (baseFileName + extension);
            }
            baseFileName += (i).ToString();
        }
    }

    //throw new InvalidImageException("The Image was not saved");
    return null;//Should never come here - something went wrong
}

问题是该方法在最后等待返回,即使我认为我正在处理所有可能的结果。现在我看到,实际上for (int i = 1; i < (int.MaxValue - 1); i++)是一种可能的方法(尽管主要是理论上的方法),方法到达终点,也许有更多的情况会导致在返回任何结果之前到达方法的终点。但是,如果代码到达方法的末尾,编译器会抱怨如果没有return,但另一方面,这意味着有问题,我希望能够正确处理这个问题。

null在开始时使用此检查:

if (selectedFileName == null)
{
    return null;//No image is selected - return
}

而且因为 ti 绝对可以不选择图像,所以我认为我应该返回null结果的地方就是这个。这使得其他结果几乎没有选择 - 当没有执行任何操作并且我到达方法的末尾时。正如我return null;再次发布的那样,但我需要更改它。我需要知道这种确切的情况正在发生,我需要做出相应的反应。

我现在可以想到两个选项 - 返回一些我检查的字符串或抛出异常。但我不确定 - 它是否是通过抛出异常而不是使用标准return语句来完成方法的正确方法。您认为处理此案的正确方法是什么?

4

1 回答 1

3

一般来说,throw在方法体的末尾是可以的(如“我们本不应该达到这一点”),但这有点不寻常。

在这种特定情况下,控制流很容易到达方法体的末尾——如果所有File.Exists检查都成功,就会发生这种情况。现在我和你“知道”这实际上是不可能的,但在数学上并不是不可能的,这足以让编译器给出错误。

那么在这里应该如何安抚编译器呢?好吧,任何方法都有其运作的合同。该方法的约定包括该方法将找到一个未使用的文件名,将源文件复制到那里并将路径返回给调用者。

但是,有些事情超出了您的控制范围,可能导致该方法无法满足此合同,在这种情况下,您必须以某种方式与调用者沟通“我无法按照您的期望做”。这不知何故是通过抛出异常。

于 2013-03-01T11:49:31.097 回答