[轻量级pr] 增加常用@ see , fix pulls/368、pulls/369问题

This commit is contained in:
duandazhi 2021-07-15 09:58:42 +08:00
parent 41d3f0d931
commit c842aa1cf9
2 changed files with 34 additions and 28 deletions

View File

@ -883,7 +883,7 @@ public class DateUtil extends CalendarUtil {
* <li>yyyy-MM-dd'T'HH:mm:ss.SSSZ</li> * <li>yyyy-MM-dd'T'HH:mm:ss.SSSZ</li>
* </ol> * </ol>
* *
* @param dateCharSequence 日期字符串; 常量如 {@link DatePattern#NORM_DATE_PATTERN}, {@link DatePattern#NORM_DATETIME_PATTERN} * @param dateCharSequence 日期字符串
* @return 日期 * @return 日期
*/ */
public static DateTime parse(CharSequence dateCharSequence) { public static DateTime parse(CharSequence dateCharSequence) {

View File

@ -624,8 +624,8 @@ public class CharSequenceUtil {
/** /**
* 按照断言除去字符串头尾部的断言为真的字符如果字符串是{@code null}依然返回{@code null} * 按照断言除去字符串头尾部的断言为真的字符如果字符串是{@code null}依然返回{@code null}
* *
* @param str 要处理的字符串 * @param str 要处理的字符串
* @param mode {@code -1}表示trimStart{@code 0}表示trim全部 {@code 1}表示trimEnd * @param mode {@code -1}表示trimStart{@code 0}表示trim全部 {@code 1}表示trimEnd
* @param predicate 断言是否过掉字符返回{@code true}表述过滤掉{@code false}表示不过滤 * @param predicate 断言是否过掉字符返回{@code true}表述过滤掉{@code false}表示不过滤
* @return 除去指定字符后的的字符串如果原字串为{@code null}则返回{@code null} * @return 除去指定字符后的的字符串如果原字串为{@code null}则返回{@code null}
* @since 5.7.4 * @since 5.7.4
@ -4033,39 +4033,45 @@ public class CharSequenceUtil {
char c; char c;
for (int i = 0; i < length; i++) { for (int i = 0; i < length; i++) {
c = str.charAt(i); c = str.charAt(i);
final Character preChar = (i > 0) ? str.charAt(i - 1) : null;
if (Character.isUpperCase(c)) { if (Character.isUpperCase(c)) {
// 遇到大写字母处理 final Character preChar = (i > 0) ? str.charAt(i - 1) : null;
final Character nextChar = (i < str.length() - 1) ? str.charAt(i + 1) : null; final Character nextChar = (i < str.length() - 1) ? str.charAt(i + 1) : null;
if (null != preChar && Character.isUpperCase(preChar)) {
// 前一个字符为大写则按照一个词对待例如AB if (null != preChar) {
sb.append(c); if (symbol == preChar) {
} else if (null != nextChar && (false == Character.isLowerCase(nextChar))) { // 前一个为分隔符
// 后一个为非小写字母按照一个词对待 if (null == nextChar || Character.isLowerCase(nextChar)) {
if (null != preChar && symbol != preChar) { //普通首字母大写如_Abb -> _abb
// 前一个是非大写时按照新词对待加连接符例如xAB c = Character.toLowerCase(c);
}
//后一个为大写按照专有名词对待如_AB -> _AB
} else if (Character.isLowerCase(preChar)) {
// 前一个为小写
sb.append(symbol); sb.append(symbol);
if (null == nextChar || Character.isLowerCase(nextChar)) {
//普通首字母大写如aBcc -> a_bcc
c = Character.toLowerCase(c);
}
// 后一个为大写按照专有名词对待如aBC -> a_BC
} else {
//前一个为大写
if (null == nextChar || Character.isLowerCase(nextChar)) {
// 普通首字母大写如ABcc -> A_bcc
sb.append(symbol);
c = Character.toLowerCase(c);
}
// 后一个为大写按照专有名词对待如ABC -> ABC
} }
sb.append(c);
} else { } else {
// 前后都为非大写按照新词对待 // 首字母需要根据后一个判断是否转为小写
if (null != preChar && symbol != preChar) { if (null == nextChar || Character.isLowerCase(nextChar)) {
// 前一个非连接符补充连接符 // 普通首字母大写如Abc -> abc
sb.append(symbol); c = Character.toLowerCase(c);
} }
sb.append(Character.toLowerCase(c)); // 后一个为大写按照专有名词对待如ABC -> ABC
} }
} else {
if (symbol != c
&& sb.length() > 0
&& Character.isUpperCase(sb.charAt(-1))
&& Character.isLowerCase(c)) {
// 当结果中前一个字母为大写当前为小写(非数字或字符)说明此字符为新词开始连接符也表示新词
sb.append(symbol);
}
// 小写或符号
sb.append(c);
} }
sb.append(c);
} }
return sb.toString(); return sb.toString();
} }