>  Q&A  >  본문

java String contains逻辑的优化

有一个"AAA,BBB"格式的字符串组成的List,有一个字符串SSS
现在想遍历List,如果字符串SSS中包含了AAA,并且包含了BBB,则返回ture。否则将List全部遍历,都不符合条件则返回false。

目前的思路是在遍历List的时候,使用split分割为String数组:["AAA","BBB"];
然后使用contains判断字符串SSS中是否包含"AAA",包含则继续判断SSS是否包含"BBB",符合条件则返回true,不符合条件则继续遍历下一条,直到遍历结束。
代码如下:

for(String tab : list){
    String listStr[] = tab.split(",");
    if (sss.contains(listStr[0]) && sss.contains(listStr[1])){
        return true;
    }
}
return false;

但是感觉这种方法效率比较低,请问各位大神有没有什么思路优化一下现在的逻辑?比如使用HashMap,正则表达式之类的实现。

PHP中文网PHP中文网2741일 전621

모든 응답(4)나는 대답할 것이다

  • PHP中文网

    PHP中文网2017-04-18 10:52:49

    Java 8을 사용하면 쉽습니다.

    으아아아

    회신하다
    0
  • 高洛峰

    高洛峰2017-04-18 10:52:49

    LZ는 HashSet 컬렉션 사용을 고려할 수 있습니다.

    회신하다
    0
  • 天蓬老师

    天蓬老师2017-04-18 10:52:49

    이 정규식이 작동하는지 테스트할 수 있나요?

    그런데 일반 문자열을 꼭 써야 한다는 건 별로 좋지 않은 느낌이에요.

    회신하다
    0
  • 迷茫

    迷茫2017-04-18 10:52:49

    으아아아

    회신하다
    0
  • 취소회신하다