import java.util.StringTokenizer;
public class StringHelper
{
/**
*将空值或空字符串转换为""
-
@param strOrig 原始字符串
-
@return 返回转换后的字符串
*/
public static final String convertStringNull(String strOrig)
{
String strReturn = “”;
if (strOrig == null || strOrig.equals(null))
{
strReturn = “”;
}
else
{
strReturn = strOrig.trim();
}
return strReturn;
}
/**
-
分解以特定分隔符分隔多个同一类型信息的字符串为字符串数组
-
@param strOrigin 原始字符串
-
@param separator 分隔符
-
@return 字符串数组
*/
public static final String[] parserString(String strOrigin, String separator)
{
try
{
StringTokenizer st;
String strItem;
if (strOrigin == null)
{
return null;
}
st = new StringTokenizer(strOrigin, separator);
String[] returnValue = new String[st.countTokens()];
int index = 0;
while (st.hasMoreTokens())
{
strItem = (String) st.nextToken();
if (strItem != null && strItem.trim().length() != 0)
{
returnValue[index++] = strItem;
}
}
return returnValue;
}
catch (Exception e)
{
return null;
}
}
/**
-
分解以特定分隔符分隔多个同一类型信息的字符串为字符串数组
-
@param strOrigin 原始字符串
-
@param separator 分隔符
-
@return 字符串数组
*/
public static String[] split(String strOrigin, String separator)
{
return strOrigin.split(separator);
}
/**
-
将源字符串中的某些字符串替换为新字符串
-
@param line 源字符串
-
@param oldString 要被替换的字符串
-
@param newString 替换的字符串
-
@return 替换后的字符串
*/
public static final String replace(String line, String oldString,
String newString)
{
if (line == null)
{
return null;
}
int i = 0;
if ((i = line.indexOf(oldString, i)) >= 0)
{
char[] line2 = line.toCharArray();
char[] newString2 = newString.toCharArray();
int oLength = oldString.length();
StringBuffer buf = new StringBuffer(line2.length);
buf.append(line2, 0, i).append(newString2);
i += oLength;
int j = i;
while ((i = line.indexOf(oldString, i)) > 0)
{
buf.append(line2, j, i - j).append(newString2);
i += oLength;
j = i;
}
buf.append(line2, j, line2.length - j);
return buf.toString();
}
return line;
}
/**
-
将源字符串中的某些字符串忽略大小写替换为新字符串
-
@param line 源字符串
-
@param oldString 要被替换的字符串
-
@param newString 替换的字符串
-
@return 替换后的字符串
*/
public static final String replaceIgnoreCase(String line, String oldString,
String newString)
{
if (line == null)
{
return null;
}
String lcLine = line.toLowerCase();
String lcOldString = oldString.toLowerCase();
int i = 0;
if ((i = lcLine.indexOf(lcOldString, i)) >= 0)
{
char[] line2 = line.toCharArray();
char[] newString2 = newString.toCharArray();
int oLength = oldString.length();
StringBuffer buf = new StringBuffer(line2.length);
buf.append(line2, 0, i).append(newString2);
i += oLength;
int j = i;
while ((i = lcLine.indexOf(lcOldString, i)) > 0)
{
buf.append(line2, j, i - j).append(newString2);
i += oLength;
j = i;
}
buf.append(line2, j, line2.length - j);
return buf.toString();
}
return line;
}
/*
-
将源字符串中的某些字符替换为指定的字符
-
@param str 源字符串
-
@param oldChar 要被替换的字符
-
@param newChar 替换的字符
-
@return 替换后的字符串
*/
public static String replaceChar(String str, char oldChar, char newChar)
{
str = convertStringNull(str);
if (str.length() > 0)
{
str = str.replace(oldChar, newChar);
}
return str;
}
/**
-
将传入的字符串转换为中文字符串,并将空字符串转换为""
-
@param strOrigin 原始字符串
-
@return 中文字符串
*/
public static String toChineseStr(String strOrigin)
{
if (strOrigin == null || strOrigin.equals(null))
{
strOrigin = “”;
}
else
{
strOrigin = strOrigin.trim();
}
try
{
strOrigin = new String(strOrigin.getBytes(“ISO8859_1”), “GBK”);
}
catch (Exception e)
{
}
return strOrigin;
}
/**
-
将中文字符串转换为ISO8859_1编码格式,并将空字符串转换为""
-
@param strOrigin 原始字符串(中文字符串)
-
@return 转换后的字符串
*/
public static String toStandardStr(String strOrigin)
{
if (strOrigin == null || strOrigin.equals(null))
{
strOrigin = “”;
}
else
{
strOrigin = strOrigin.trim();
}
try
{
strOrigin = new String(strOrigin.getBytes(“GBK”), “ISO8859_1”);
}
catch (Exception e)
{
}
return strOrigin;
}
/**
-
将字符串转换为utf-8编码格式
-
@param s 要转换的字符串
-
@return 转换后的字符串
*/
public static String toUtf8String(String s)
{
StringBuffer sb = new StringBuffer();
for (int i = 0; i < s.length(); i++)
{
char c = s.charAt(i);
if (c >= 0 && c <= 255)
{
sb.append©;
}
else
{
byte[] b;
try
{
b = new Character©.toString().getBytes(“utf-8”);
}
catch (Exception ex)
{
System.out.println(ex);
b = new byte[0];
}
for (int j = 0; j < b.length; j++)
{
int k = b[j];
if (k < 0)
k += 256;
sb.append(“%” + Integer.toHexString(k).toUpperCase());
}
最后我们该如何学习?
1、看视频进行系统学习
这几年的Crud经历,让我明白自己真的算是菜鸡中的战斗机,也正因为Crud,导致自己技术比较零散,也不够深入不够系统,所以重新进行学习是很有必要的。我差的是系统知识,差的结构框架和思路,所以通过视频来学习,效果更好,也更全面。关于视频学习,个人可以推荐去B站进行学习,B站上有很多学习视频,唯一的缺点就是免费的容易过时。
另外,我自己也珍藏了好几套视频资料躺在网盘里,有需要的我也可以分享给你:
2、读源码,看实战笔记,学习大神思路
“编程语言是程序员的表达的方式,而架构是程序员对世界的认知”。所以,程序员要想快速认知并学习架构,读源码是必不可少的。阅读源码,是解决问题 + 理解事物,更重要的:看到源码背后的想法;程序员说:读万行源码,行万种实践。
Spring源码深度解析:
Mybatis 3源码深度解析:
Redis学习笔记:
Spring Boot核心技术-笔记:
3、面试前夕,刷题冲刺
面试的前一周时间内,就可以开始刷题冲刺了。请记住,刷题的时候,技术的优先,算法的看些基本的,比如排序等即可,而智力题,除非是校招,否则一般不怎么会问。
关于面试刷题,我个人也准备了一套系统的面试题,帮助你举一反三:
只有技术过硬,在哪儿都不愁就业,“万般带不去,唯有业随身”学习本来就不是在课堂那几年说了算,而是在人生的旅途中不间断的事情。
人生短暂,别稀里糊涂的活一辈子,不要将就。
想法;程序员说:读万行源码,行万种实践。
Spring源码深度解析:
[外链图片转存中…(img-e1EAqZBk-1714333987593)]
Mybatis 3源码深度解析:
[外链图片转存中…(img-wu8fZp58-1714333987593)]
Redis学习笔记:
[外链图片转存中…(img-PRhwbRWx-1714333987594)]
Spring Boot核心技术-笔记:
[外链图片转存中…(img-r3P7hItl-1714333987594)]
3、面试前夕,刷题冲刺
面试的前一周时间内,就可以开始刷题冲刺了。请记住,刷题的时候,技术的优先,算法的看些基本的,比如排序等即可,而智力题,除非是校招,否则一般不怎么会问。
关于面试刷题,我个人也准备了一套系统的面试题,帮助你举一反三:
[外链图片转存中…(img-42g6kdSW-1714333987594)]
只有技术过硬,在哪儿都不愁就业,“万般带不去,唯有业随身”学习本来就不是在课堂那几年说了算,而是在人生的旅途中不间断的事情。
人生短暂,别稀里糊涂的活一辈子,不要将就。