关于java中字符串求子串这个函数substring的使用,在MyEclipse打开原函数乍看到下面这段代码描述,自然会认为是从原字符串的start位置开始截取,截取的终点位置是end,构成一个新的字符串。
结果按这种方式用的时候,发现出问题了,比如:我本想去除字符串"12345"的首尾两个字符,形成新字符串"234",用了如图所示的语句,运行后的结果确是"23"。
而把substring(int start, int end)的end参数改大一位,如果所示,便可得到我想要的结果了。
可见substring(int start, int end)这个函数并不是像表面上那样理解的来截取子串,截取开始的start位置没有问题,但是end这个值并不是截取到字符串的end位置这,而是它的上一个位置。
那就进一步来看myeclipse库函数的源代码:
再看substring(start, end)函数的实现
然后看String(value, start, end - start)这个函数的实现,其实看到这里,应该能大致看出end-start为新的参数,而非直接用end值。
String函数的实现中参数count的值=end-start,这个值是子串的元素个数,而非最开始理解的一个位置,copyOfRange函数则将原字符串从from位置开始复制to-from个元素到新数组中。
综上所见,我们可以理解String substring(int start, int end),是截取原字符串中从start位置开始的end-start个字符元素组成新的字符串,所以原来那个问题:
b=“12345”;
b.substring(1,4)返回的是从原字符串1位置开始后3个元素组成的子串"234"
而b.substring(1,3)返回的从原字符串1位置开始后2个元素组成的子串"23"
或者可以这么理解:
substring(int begin,int end)
//返回序号从begin到end-1的子串
哪种方式便于理解和记忆,看个人了,简而言之就是左闭右开,使用的时候稍加注意就好。