我觉得每次我使用TryParse都会产生一些丑陋的代码。我主要是这样使用它的:
int value;
if (!int.TryParse(someStringValue, out value))
{
value = 0;
}有没有更优雅的解决方案来解析所有的基本数据类型,具体地说,有没有一种方法可以在一行中进行故障保护解析?为了安全起见,我假设如果解析失败而没有异常,我会设置默认值。
顺便说一句,这适用于即使解析失败也必须执行某些操作的情况,只使用默认值。
发布于 2013-09-24 19:01:23
这是有效的,如果你喜欢单行代码,你可能会更喜欢它:
int i = int.TryParse(s, out i) ? i : 42;如果不能解析字符串s,则将i的值设置为42,否则设置为i = i。
发布于 2012-05-22 06:07:06
直接扩展方法怎么样?
public static class Extensions
{
public static int? TryParse(this string Source)
{
int result;
if (int.TryParse(Source, out result))
return result;
else
return null;
}
}或者在一行中使用新的c#语法:
public static int? TryParse(this string Source) => int.TryParse(Source, out int result) ? result : (int?)null;用法:
v = "234".TryParse() ?? 0发布于 2012-05-22 06:03:46
您可以为更适合自己的解决方案编写自己的方法。不久前,我偶然发现了包装TryParse方法的Maybe类。
int? value = Maybe.ToInt("123");
if (value == null)
{
// not a number
}
else
{
// use value.Value
}或在行内指定默认值:
int value = Maybe.ToInt("123") ?? 0;观察Nullable<int>/int?和int之间的区别。
有关更多信息,请参阅http://www.kodefuguru.com/post/2010/06/24/TryParse-vs-Convert.aspx
https://stackoverflow.com/questions/10693231
复制相似问题