java.util.List.subList
来源:互联网 发布:淘宝怎么看确认收货 编辑:程序博客网 时间:2024/04/30 15:04
原文链接: http://www.cnblogs.com/gaojing/archive/2012/06/17/java-list-sublist-caution.html
java.util.List中有一个subList方法,用来返回一个list的一部分的视图。
List<E> subList(int fromIndex, int toIndex);
它返回原来list的从[fromIndex, toIndex)之间这一部分的视图,之所以说是视图,是因为实际上,返回的list是靠原来的list支持的。
所以,你对原来的list和返回的list做的“非结构性修改”(non-structural changes),都会影响到彼此对方。
所谓的“非结构性修改”,是指不涉及到list的大小改变的修改。相反,结构性修改,指改变了list大小的修改。
那么,如果涉及到结构性修改会怎么样呢?
如果发生结构性修改的是返回的子list,那么原来的list的大小也会发生变化;
而如果发生结构性修改的是原来的list(不包括由于返回的子list导致的改变),那么返回的子list语义上将会是undefined。在AbstractList(ArrayList的父类)中,undefined的具体表现形式是抛出一个ConcurrentModificationException。
因此,如果你在调用了sublist返回了子list之后,如果修改了原list的大小,那么之前产生的子list将会失效,变得不可使用。
tips: 如何删除一个list的某个区段,比如删除list的第2-5个元素?
方法是: 可以利用sublist的幕后还是原来的list的这个特性,比如
list.subList(from, to).clear();
这样就可以了.
示例代码:
public static void main(String[] args) { List<String> parentList = new ArrayList<String>(); for(int i = 0; i < 5; i++){ parentList.add(String.valueOf(i)); } List<String> subList = parentList.subList(1, 3); for(String s : subList){ System.out.println(s);//output: 1, 2 } //non-structural modification by sublist, reflect parentList subList.set(0, "new 1"); for(String s : parentList){ System.out.println(s);//output: 0, new 1, 2, 3, 4 } //structural modification by sublist, reflect parentList subList.add(String.valueOf(2.5)); for(String s : parentList){ System.out.println(s);//output:0, new 1, 2, 2.5, 3, 4 } //non-structural modification by parentList, reflect sublist parentList.set(2, "new 2"); for(String s : subList){ System.out.println(s);//output: new 1, new 2 } //structural modification by parentList, sublist becomes undefined(throw exception) parentList.add("undefine");// for(String s : subList){// System.out.println(s);// }// subList.get(0); }
一个很有趣的思考:如何最高效的实现一个list的split方法?
参见:http://stackoverflow.com/questions/379551/java-split-a-list-into-two-sub-lists。
/** Split a list into two sublists. The original list will be modified to * have size i and will contain exactly the same elements at indices 0 * through i-1 as it had originally; the returned list will have size * len-i (where len is the size of the original list before the call) * and will have the same elements at indices 0 through len-(i+1) as * the original list had at indices i through len-1. */ <T> List<T> split(List<T> list, int i){ List sub=list.subList(0,i); List two=new ArrayList(sub); sub.clear(); // since sub is backed by one, this removes all sub-list items from one }
- java.util.List.subList
- java.util.List.subList
- java.util.List.subList
- 使用java.util.List.subList
- java.util.List.subList注意事项
- java.util.List.subList分析
- java.util.List中subList方法
- 关于java.util.List.subList用法
- 使用java.util.List.subList心得
- java.util.List.subList() 使用注意事项
- java.util.List接口的方法subList()的使用注意事项
- java.util.List里的subList方法使用
- java.util.List接口的方法subList()的使用注意事项
- 使用java.util.List.subList时最好小心点
- java.util.List接口的方法subList()的使用注意事项
- java.util.List接口的方法subList()进行分页
- 使用java.util.List.subList时最好小心点
- 使用java.util.List.subList时最好小心点
- 购物车设计思路
- IOS缓存管理之YYCache使用
- 改变 placeholder 颜色、字体大小
- Permutation
- 在java开发过程中什么时候使用ByteArrayInputStream和ByteArrayOuitputStream?
- java.util.List.subList
- LFU与LRU的不同
- 欢迎使用CSDN-markdown编辑器
- IO文件管理
- Java生成随机数工具类,进制之间的转换工具类,获取指定时间,时间格式转换工具类
- linux安装eclipse出现exit code =13时的解决办法
- Java生成随机数工具类,进制之间的转换工具类,获取指定时间,时间格式转换工具类
- php之错误日志(error log)
- Linux内核编译,启动带linux内核的模拟器。