String的subString方法,并没有创建一个新的字符数组,只是将offset和count换到了对应的地方。
这样就产生了内存泄露的一个隐患——原来完整的字符串仍然被新的String引用所指向。
例如:从爬取下来的网页中,抽取出其标题,并将标题存入到一个HashMap中,实际上整个网页字符串都不会被清除。随着时间推移,你可能在内存中保存下来了所有的被下载到的网页。
这样,就可以理解利用String来构造String的意思了——public String(String original);
如果试图构造的String,是从原来某个更长一些的字符串中截取的一部分,那么通过调用一次构造函数,将重新创建一个仅仅包含需要的字符的字符串数组。
也就是源码中的:
而如果传入的构造函数的参数String,就是一个它自身,那么根据java设计的字符串的不变性原理,就不会创建新的字符串数组来。