字符串的截取匹配操作在开发中非常常见,比如下面这个示例:我要匹配查找出来字符串数组中以"abc"开头的字符串并打印,我下面分别用了两种方式实现,代码如下:
using System;
namespace ConsoleApp23{ class Program { static void Main(string[] args) { string[] strs = new string[] { "abc123" , "abc456" ,"ab123","a12345" };
//方法1 foreach (var str in strs) { if (str.Substring(0, 3) == "abc") { Console.WriteLine(str); } } Console.WriteLine();
//方法2 foreach (var str in strs) { if (str.StartsWith("abc")) { Console.WriteLine(str); } }
Console.ReadKey(); } }}
运行结果如下:
诚然,两种方法都输出了正确的结果。
那么既然,两种方式都能实现,这两种方法有没有什么区别呢?当然有的,而且大多数时候,一个老练的程序员都会用StartsWith而不是Substring,为什么呢?
往下看,我把数据源修改下:
static void Main(string[] args) {``
string[] strs = new string[] { "abc123" , "abc456" ,"ab123","a12345" ,"abc","ab"};
//方法1`` foreach (var str in strs)``
{``
if (str.Substring(0, 3) == "abc")``
{``
Console.WriteLine(str);``
}
}``
Console.WriteLine();
//方法2 `` foreach (var str in strs)``
{``
if (str.StartsWith("abc"))``
{
Console.WriteLine(str);
}
}
Console.ReadKey();``
}
运行后,方法一直接崩了,但是方法2则可以正确运行出来结果
看一下Substring的用法解释:startIndex 加 length 指示不在此实例内的位置。- 或 - startIndex 或 length 小于零。,所以当字符串小于你要截取的长度时,你如果没用try catch去捕获异常,代码就崩溃了.
// // 摘要:
// 从此实例检索子字符串。子字符串从指定的字符位置开始且具有指定的长度。
//`` 参数:`` // startIndex:`` // 此实例中子字符串的起始字符位置(从零开始)。`` //`` // length:`` // 子字符串中的字符数。`` //`` // 返回结果:`` // 与此实例中在 length 处开头、长度为 startIndex 的子字符串等效的一个字符串;如果 System.String.Empty 等于此实例的长度且`` // startIndex 为零,则为 length。`` //`` // 异常:`` // T:System.ArgumentOutOfRangeException:`` // startIndex 加 length 指示不在此实例内的位置。- 或 - startIndex 或 length 小于零。`` [SecuritySafeCritical]`` public String Substring(int startIndex, int length);
所以,我们需要慎用Substring,如果非要用,一定需要进行异常处理。