加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Java > 正文

java – 迭代列表,修改每个元素:有更快的方法吗?

发布时间:2020-12-15 02:50:40 所属栏目:Java 来源:网络整理
导读:我有一个字符串列表,我想修剪()列表中的每个元素. 目前,我正在使用ArrayList,对元素进行简单循环,并将修剪后的元素添加到返回列表中,如下所示: int listLen = listToTrim.size();ListString trimmedList = new ArrayListString( listLen );for ( int i = 0;
我有一个字符串列表,我想修剪()列表中的每个元素.

目前,我正在使用ArrayList,对元素进行简单循环,并将修剪后的元素添加到返回列表中,如下所示:

int listLen = listToTrim.size();

List<String> trimmedList = new ArrayList<String>( listLen );

for ( int i = 0; i < listLen; i++ ) {
    trimmedList.add( listToTrim.get( i ).trim() );
}

return trimmedList;

对于大型列表,会有更有效的方法吗?

解决方法

不,你很好.这和它的效率一样高效.没有魔法可以避免迭代.

有一点要记住,’但是:如果listToTrim不是随机访问列表(即它没有实现RandomAccess),那么使用Iterator(或者在内部使用Iterator的增强型for循环)而不是传统的for-loop通常效率更高.未实现RandomAccess的最值得注意的List是LinkedList.在具有600个元素的LinkedList上调用l.get(300)将必须遍历~300个元素才能获得正确的元素!

修改代码以使用增强的for循环看起来像这样:

public List<String> trimStrings(Listy<String> listToTrim) {
    List<String> trimmedList = new ArrayList<String>(listToTrim.size());
    for (String str : listToTrim) {
      trimmedList.add(str.trim());
    }
    return trimmedList;
}

如果您不再需要原始列表,则重新使用原始列表可以节省内存并提高性能:

public void trimStringsInPlace(List<String> listToTrim) {
    ListIterator<String> it = listToTrim.listIterator();
    while (it.hasNext()) {
      it.set(it.next().trim());
    }
}

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读