首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >尝试/捕捉返回值的正确方法

尝试/捕捉返回值的正确方法
EN

Stack Overflow用户
提问于 2016-06-15 17:39:36
回答 2查看 1.8K关注 0票数 2

我有一个名为ValidIP()的方法,它接受一个string,如果字符串是一个有效的IP地址,则返回true。示例1在try/catch语句之后返回true,因为我不想在返回值时捕获异常。示例2在测试字符串并在try指令中等待异常时直接返回值。这是个人偏好的问题,还是一个更正确、更安全/不太容易崩溃的例子?

示例1

代码语言:javascript
复制
private bool ValidIP(string ipAddress)
{
    try
    {
        IPAddress.Parse(ipAddress);
    }
    catch
    {
        return false;
    }
    return true;
}

示例2

代码语言:javascript
复制
private bool ValidIP(string ipAddress)
{
    try
    {
        IPAddress.Parse(ipAddress);
        return true;
    }
    catch
    {
        return false;
    }
}
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2016-06-15 17:42:56

据我所知,这两种方法都是等价的。然而,解决这个问题的一个更优雅的方法是使用IPAddress.TryParse方法:

代码语言:javascript
复制
public static bool TryParse(string ipString,out IPAddress address)

该方法返回truefalse,这取决于它是否成功地解析了地址。此外,它还使用了一个out参数`,这样您就可以立即使用解析的IP地址。

如果只对IP地址是否有效感兴趣,则可以使用dummy IP地址:

代码语言:javascript
复制
private bool ValidIP(string ipAddress) {
    IPAddress dummy;
    return IPAddress.TryParse(ipAddress,out dummy);
}

此外,请注意ParseTryParse方法的重要注释:

请注意,如果TryParse成功地解析了输入,则返回true ,但这并不一定意味着得到的IP地址是有效的。不使用此方法验证IP地址。

票数 4
EN

Stack Overflow用户

发布于 2016-06-15 17:42:30

语句return true无法抛出异常,因此这两个代码段是相同的。如果您正在对返回的值执行一些计算,该值实际上可能引发异常,并且希望抛出的异常导致抛出该异常的方法,而不是返回false,那么您就需要使用后一种方法。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/37842191

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档