C#判断字符串中是否包含指定字符串及contains与indexof方法效率问题

正文

 #方法一:使用string.Contains方法

  string.Contains是大小写敏感的,如果要用该方法来判断一个string是否包含某个关键字keyword,需要把这个string和这个keyword都转成小写或大写再调用Contains方法;

 string key = "bbb";
 string temp = "aaaBBBcccDDD";
 bool isContains= temp.ToLower().Contains(key.ToLower());//true

#方法二:使用sring.Index方法

  使用string.Index方法,然后通过StringComparison.OrdinalIgnoreCase指定查找过程忽略大小写;

 string key = "bbb";
 string temp = "aaaBBBcccDDD";
 bool isContains = temp.IndexOf(key,StringComparison.OrdinalIgnoreCase)>=0;//true

#那什么时候使用Contains方法,什么时候使用Index方法,哪个效率高?

1、测试代码:

  注:此测试针对的是拥有大量英文的情况下,并且指定的字符串为英文

  每个方法测试1千万次,输出所用时间;

class Program
  {
    private const int N = 10000000;
    private static Stopwatch watch = new Stopwatch();
    static void Main(string[] args)
    {
      string source = "aaabbbcccdddeeefffggghhhiiijjjkkklllmmmnnnooopppqqq";
      string target = "AAA";
      Console.WriteLine("目标在开头部分时:");
      Console.WriteLine("不区分大小写:");
      TestContains(source, target,true);
      TestIndexOf(source, target,true);
      Console.WriteLine("区分大小写:");
      target = "aaa";
      TestContains(source, target,false);
      TestIndexOf(source, target,false);
      Console.WriteLine();
      Console.WriteLine("目标在中部时:");
      Console.WriteLine("不区分大小写:");
      target = "HHH";
      TestContains(source, target, true);
      TestIndexOf(source, target, true);
      Console.WriteLine("区分大小写:");
      target = "hhh";
      TestContains(source, target, false);
      TestIndexOf(source, target, false);
      Console.WriteLine();
      Console.WriteLine("目标在结尾时:");
      Console.WriteLine("不区分大小写:");
      target = "QQQ";
      TestContains(source, target,true);
      TestIndexOf(source, target,true);
      Console.WriteLine("区分大小写:");
      target = "qqq";
      TestContains(source, target,false);
      TestIndexOf(source, target,false);
      Console.WriteLine("执行完毕,按任意键退出...");
      Console.ReadKey();
    }
    private static void TestIndexOf(string source, string target,bool isIgnoreCase)
    {
      watch.Reset();
      watch.Start();
      for (int i = 0; i < N; i++)
      {
        if (isIgnoreCase)
          source.IndexOf(target, StringComparison.OrdinalIgnoreCase);
        else
          source.IndexOf(target);
      }
      watch.Stop();
      Console.WriteLine("IndexOf: " + watch.ElapsedMilliseconds.ToString() + "ms");
      return;
    }
    private static void TestContains(string source, string target,bool isIgnoreCase)
    {
      watch.Reset();
      watch.Start();
      for (int i = 0; i < N; i++)
      {
        if (isIgnoreCase)
          source.ToLower().Contains(target.ToLower());
        else
          source.Contains(target);
      }
      watch.Stop();
      Console.WriteLine("Contains: " + watch.ElapsedMilliseconds.ToString() + "ms");
      return;
    }
  }

2、测试结果:

3、总结

  1、从测试结果(大量测试)中能明显看出,当拥有大量英文的字符串中:

  *当不区分大小写时,string.IndexOf方法的效率明显高于string.Contains方法;

  *当区分大小写时,string.Contains方法的效率明显高于string.IndexOf方法;

  *如果判断的是中文,没有大小写之分,还是string.Contains方法的效率高;

  2、综合上述总结,定义了一个String扩展方法,该方法包含一个StringComparison参数,返回值为是否包含子字符串:

    参考:https://docs.microsoft.com/zh-cn/dotnet/api/system.string.contains?redirectedfrom=MSDN&view=netframework-4.5#System_String_Contains_System_String_

using System;
 public static class StringExtensions
 {
   public static bool Contains(this String str, String substring,
                 StringComparison comp)
   {
    if (substring == null)
      throw new ArgumentNullException("substring",
                     "substring cannot be null.");
    else if (! Enum.IsDefined(typeof(StringComparison), comp))
     throw new ArgumentException("comp is not a member of StringComparison",
                   "comp");
    return str.IndexOf(substring, comp) >= ;
  }
 }

using System;
public class Example
{
  public static void Main()
  {
   String s = "This is a string.";
   String sub1 = "this";
   Console.WriteLine("Does '{0}' contain '{1}'?", s, sub1);
   StringComparison comp = StringComparison.Ordinal;
   Console.WriteLine("  {0:G}: {1}", comp, s.Contains(sub1, comp));
   comp = StringComparison.OrdinalIgnoreCase;
   Console.WriteLine("  {0:G}: {1}", comp, s.Contains(sub1, comp));
  }
}
// The example displays the following output:
//    Does 'This is a string.' contain 'this'?
//     Ordinal: False
//     OrdinalIgnoreCase: True

总结

以上所述是小编给大家介绍的C#判断字符串中是否包含指定字符串及contains与indexof方法效率问题,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!

(0)

相关推荐

  • C#验证用户输入信息是否包含危险字符串的方法

    本文实例讲述了C#验证用户输入信息是否包含危险字符串的方法.分享给大家供大家参考.具体分析如下: 这个C#函数可以用于表单输入数据的后端验证,判断用户是否提交了一些sql相关的危险注入字符 /// <summary> /// 检测客户输入的字符串是否有效,并将原始字符串修改为有效字符串或空字符串 /// 当检测到客户的输入中有攻击性危险字符串,则返回false,有效返回true. /// </summary> /// <param name="input"

  • C#判断一个字符串是否包含另一个字符串的方法

    本文实例讲述了C#判断一个字符串是否包含另一个字符串的方法.分享给大家供大家参考.具体如下: string a="china"; string b="i"; if (a.IndexOf(b) > -1) { //包含指定的字符串,执行相应的代码 } 希望本文所述对大家的C#程序设计有所帮助.

  • c# indexof 用法深入理解

    IndexOf() 查找字串中指定字符或字串首次出现的位置,返首索引值,如: 复制代码 代码如下: str1.IndexOf("字"): //查找"字"在str1中的索引值(位置) str1.IndexOf("字串")://查找"字串"的第一个字符在str1中的索引值(位置) str1.IndexOf("字",start,end)://从str1第start+1个字符起,查找end个字符,查找"字

  • C# List<T> Contains<T>()的用法小结

    泛型List<T>中有一个比较列表是否已包含对象的方法Contains<T>(),今天在网上搜了一个用法,记录下来,备查. 要用此方法比较我们的自定义对象,首先要有一个比较器, 要注意的是,这里的比较器是实现IEqualityComparer<T>接口的,不要写成IComparer<T>. 如下: 复制代码 代码如下: /// <summary>    /// 描    述:弹出模型对象列表比较器(根据ID比较)    /// </summ

  • C# 数组中的 indexOf 方法及使用

    具体代码如下所示: var array=['REG','2018','2018']; array.indexOf('REG') // 0 array.indexOf('R') // -1 array.indexOf('2018′) // 1 array.indexOf(2018) // -1 arr.indexOf('orange') 输出 0 因为 'orange' 是数组的第 0 个元素,匹配到并返回下标. arr.indexOf('o') 输出 -1 因为此方法不会在每一个元素的基础上再次

  • C#实现判断字符串中是否包含中文的方法

    本实例展示了C#实现判断字符串中是否包含中文的方法,是一个非常实用的功能,对初学者来说有一定的借鉴学习价值,具体实现方法如下: 主要功能代码如下: /// <summary> /// 判断字符串中是否包含中文 /// </summary> /// <param name="str">需要判断的字符串</param> /// <returns>判断结果</returns> public static bool Has

  • C#判断字符串中是否包含指定字符串及contains与indexof方法效率问题

    正文  #方法一:使用string.Contains方法 string.Contains是大小写敏感的,如果要用该方法来判断一个string是否包含某个关键字keyword,需要把这个string和这个keyword都转成小写或大写再调用Contains方法: string key = "bbb"; string temp = "aaaBBBcccDDD"; bool isContains= temp.ToLower().Contains(key.ToLower()

  • php 字符串中是否包含指定字符串的多种方法

    编写程序的时候,经常要处理字符串,最基本就是字符串的查找,在php检测字符串中是否包含指定字符串可以使用正则,如果你对正则不了解,那么有几个函数可以为您提供方便. 1. strstr strstr() 函数搜索一个字符串在另一个字符串中的第一次出现. 该函数返回字符串的其余部分(从匹配点).如果未找到所搜索的字符串,则返回 false. 代码如下: <?php /*如手册上的举例*/ $email = 'user@example.com'; $domain = strstr($email, '@

  • strpos() 函数判断字符串中是否包含某字符串的方法

    用php的strpos() 函数判断字符串中是否包含某字符串的方法 判断某字符串中是否包含某字符串的方法 if(strpos('www.idc-gz.com','idc-gz') !== false){ echo '包含'; }else{ echo '不包含'; } PHP strpos() 函数 strpos() 函数返回字符串在另一个字符串中第一次出现的位置. 如果没有找到该字符串,则返回 false. 语法 strpos(string,find,start) 参数 描述 string 必需

  • java查找字符串中的包含子字符串的个数实现代码

    1. 用indexof的方法: public class Test11 { private static int counter = 0; /** * @param args */ public static void main(String[] args) { String str ="sdSS**&HGJhadHCASch& ^^"; int i = stringNumbers(str); System.out.println(i); } public static

  • iOS 截取字符串中两个指定字符串中间的字符串方法

    例如,要截取一个字符串中,两个指定字符串中间的字符串,OC截取方法如下: // 要截取 "> 和 </ 之间的汉字内容: @implementation ViewController - (void)viewDidLoad { [super viewDidLoad]; NSString *string = @"<a href=\"http\">这是要截取的内容</a>"; NSRange startRange = [st

  • java判断字符串中是否包含中文并过滤中文

    java判断字符串中是否包含中文并过滤掉中文,具体内容如下 1.判断字符串中是否包含中文方法封装 /** * 判断字符串中是否包含中文 * @param str * 待校验字符串 * @return 是否为中文 * @warn 不能校验是否为中文标点符号 */ public static boolean isContainChinese(String str) { Pattern p = Pattern.compile("[\u4e00-\u9fa5]"); Matcher m = p

  • 判断以逗号分隔的字符串中是否包含某个数的实例

    1.首先将字符串变成字符串数组 2.将字符串数组转为List集合 3.利用List集合中的contains()方法,判断是否包含某个数 @Test public void test2222(){ String ids = "1,2,3,45,35"; String[] values = ids.split(","); List<String> list = Arrays.asList(values); if(list.contains("4&q

  • Java 判断字符串中是否包含中文的实例详解

    Java 判断字符串中是否包含中文的实例详解 Java判断一个字符串是否有中文是利用Unicode编码来判断,因为中文的编码区间为:0x4e00--0x9fbb, 不过通用区间来判断中文也不非常精确,因为有些中文的标点符号利用区间判断会得到错误的结果.而且利用区间判断中文效率也并不高,例如:str.substring(i, i + 1).matches("[\\一-\\?]+"),就需要遍历整个字符串,如果字符串太长效率非常低,而且判断标点还会错误.这里提高 一个高效准确的判断方法,使

  • Java判断字符串中是否包含中文方法

    今天和同事在讨论一个问题,需要检查"输入的字符串中是否包含中文",刚开始想到是用正则表达式,正则表达式中是以[u4e00-u9fa5]来全匹配字符是否是中文,但现在面临的问题是这个字符串中还可能包含英文字符.数字.特殊字符,一时也没想出能匹配该场景的正则表达式,后来在网上搜了下,可以使用Matcher类来解决该问题,大致的代码实现如下: import java.util.regex.Matcher; import java.util.regex.Pattern; public clas

随机推荐