用途
String split 方法 应该都很熟悉, 就是根据 指定的字符 拆分字符串 返回一个数组的方法;
为什么突然想探究
在业务中, 我有一个需求 是根据关键字的匹配, 我采用了, 用;分割的做法, 例如 : “烟;酒;茶;” 然后在后端使用 String 的 replaceAll 把所有的; 全部替换成| 用与mysql REGEXP 做正则校验. 发现 这样是错误的 替换之后会 变成 “烟|酒|茶|” 由于 茶后面还有一个| mysql 正则 及把所有的数据都匹配出来了 然后我对数据进行了如下的处理
发现数组的长度 本该为 四个的 (包含一个空字符的) 但是实际的长度却是三个, 就猜想了,可能split方法 不仅仅是 对 字符串进行一次匹配拆分 可能还有其他的逻辑操作. 那就只能去源码 找找原因了;
我们直接打好断点采用Debug 模式去调试看看
该方法调用了一个重载的方法,第一个参数没变,第二个参数limit传了0,继续往下看
此处的list里存放的是全部的5个元素,而在下面的while循环里,可以看到是从尾部往前遍历看哪个元素长度为0,
有一个为0的就减一个长度,直到碰到第一个不为空的元素为止。进行完这个while循环之后,就截取前面的元素,转成数组返回。
对于String的split方法,如果字符串末尾刚好是匹配字符,则会自动将最后一个
空元素去掉,而字符串首部有空元素则不受影响。
对于Limit参数 是一个限制返回长度的 参数 例如上述 所说的 “烟;酒;茶;” 然后我们 使用 split(";",4) 这样的话 他就会把""空返回出来