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将会失效,变得不可使用。

删除一个list的某个区段,比如删除list的第2-5个元素?

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或者string长时间存放在内存中:
1. 对于sublist()方法得到的list,貌似没有太好的办法,只能用最直接的方式:自己创建新的list,然后将需要的内容添加进去
2. 对于substring()/split()方法得到的string,可以用String类的构造函数new String(String original)来创建一个新的String,这 样会重新创建底层的char[]并复制需要的内容,不会造成"浪费"。

String类的构造函数new String(String
original)是一个非常特别的构造函数,通常没有必要使用,正如这个函数的javadoc所言 :Unless an explicit copy
of original is needed,
use of this constructor is unnecessary since Strings are immutable.
除非明确需要原始字符串的拷贝,否则没有必要使用这个构造函数,因为String是不可变的。

最新文章

  1. PacBio三代全长转录组/Iso-Seq技术及案例分析
  2. Nginx反向代理搭建配置
  3. 一道SQL面试例题 if...else 与聚集函数
  4. serialization机制
  5. div左右布局
  6. 解决VS2012新建MVC4等项目时,收到加载程序集“NuGet.VisualStudio.Interop…”的错误
  7. 下拉框上移、下移、添加、移除demo
  8. Oauth认证的时候报错:timestamp_refused
  9. New Hire Training Experience
  10. iOS 程序开发
  11. Struts2之访问路径
  12. mysql中整数类型后面的数字,比如int(11),11代表11个字节吗?
  13. jmeter数据库,charles抓包,Python循环语句
  14. linux C遍历目录下文件
  15. pip命令无法使用
  16. Effective C++学习笔记之explicit
  17. vue-12-渲染函数 &amp; JSX
  18. idea 未实现接口红线提示,重复代码波浪线提示,自动换行,控制台输出内容自动换行
  19. lucene入门创建索引——(二)
  20. IE 兼容一问题一小记

热门文章

  1. [leetcode]53Maximum Subarray动态规划经典题目:最大子串问题
  2. JAVA程序通过JNI调用C/C++库
  3. k8s之DNS服务器搭建
  4. SpringMVC的@Validated校验注解使用方法
  5. 2020 年度编程语言排行榜出炉!C 语言称霸,Java 遭遇滑铁卢…….
  6. 数据库的查询(结合YGGL.sql)
  7. IntelliJ IDEA启动界面的秘密:当编程遇到艺术
  8. LeetCode141-环形链表检测
  9. 基于Python开发数据宽表实例
  10. 【Linux】fio测试读写速度