if (iIndex <= ()) {
deleteString += (iIndex, ());
}
return deleteString;
}
第三种方法
原理同上,只不过查找要删除字符位置采用String类中的函数执行,效率不如上面的高,代码如下:
public String deleteCharString2(String sourceString, char chElemData) {
String deleteString = “”;
int iIndex = 0;
int tmpCount = 0;
do {
tmpCount = (chElemData, iIndex);
if (tmpCount > 0) {
deleteString += (iIndex, tmpCount);
}
if (tmpCount != -1) {
iIndex = tmpCount + 1;
}
} while (tmpCount != -1);
if (iIndex <= ()) {
deleteString += (iIndex, ());
}
return deleteString;
}
第四种方法
原理与上方基本一致,只不过这次采用倒序方式,这里的坑就更多了,一定要注意索引的取值范围和是否合法,代码如下:
public String deleteCharString3(String sourceString, char chElemData) {
String deleteString = “”;
int iIndex = ();
int tmpCount = 0;
do {
tmpCount = (chElemData, iIndex - 1);
if (tmpCount < () && tmpCount >= 0) {
deleteString = (tmpCount + 1, iIndex) + deleteString;
}
if (tmpCount != -1) {
iIndex = tmpCount;
}
} while (tmpCount != -1);
if (iIndex >= 0) {
deleteString = (0, iIndex) + deleteString;
}
return deleteString;
}
第五种方法
通过采用正则的方式和replaceAll函数,本种方法要注意特殊字符,例如正则中的 “.”字符,需要对特殊字符进行转义,代码如下:
public String deleteCharString4(String sourceString, char chElemData) {
String deleteString = “”;
final String strTable = “|^$*+?.(){}\”;
String tmpRegex = “[”;
for (int i = 0; i < (); i++) {
if ((i) == chElemData) {
tmpRegex += “\”;
break;
}
}
tmpRegex += chElemData + “]”;
deleteString = (tmpRegex, “”);
return deleteString;
}
第六种方法
采用正则的方式将字符串分割成几个子字符串,再将子字符串进行拼接,代码如下:
public String deleteCharString5(String sourceString, char chElemData) {
String deleteString = “”;
final String strTable = “|^$*+?.(){}\”;
String tmpRegex = “[”;
for (int i = 0; i < (); i++) {
if ((i) == chElemData) {
tmpRegex += “\”;
break;
}
}
tmpRegex += chElemData + “]”;
String[] tmpStringArray = (tmpRegex);
for (int i = 0; i < ; i++) {
deleteString += tmpStringArray[i];
}
return deleteString;
}
第七种方法
将字符编程可读序列,在通过 String 类中的方法替换,代码如下:
public String deleteCharString6(String sourceString, char chElemData) {
String tmpString = “”;
tmpString += chElemData;
(0, 0);
String deleteString = “”;
deleteString = (tmpString, (0, 0));
return deleteString;
}
第八种方法
把原字符串转化为字符数组,然后原理与直接插入排序原理类似,代码如下:
public String deleteCharString7(String sourceString, char chElemData) {
String deleteString = “”;
char[] Bytes = ();
int iSize = ;
for (int i = - 1; i >= 0; i–) {
if (Bytes[i] == chElemData) {
for (int j = i; j < iSize - 1; j++) {
Bytes[j] = Bytes[j + 1];
}
iSize–;
}
}
for (int i = 0; i < iSize; i++) {
deleteString += Bytes[i];
}
return deleteString;
}
第九种方法
原理与 第一种方法 类似,本次采用 stringBuffer 类中的 append 方法进行操作,我认为效率应该高于第一种。
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
如果你觉得这些内容对你有帮助,可以扫码获取!!(备注Java获取)
最后
为什么我不完全主张自学?
①平台上的大牛基本上都有很多年的工作经验了,你有没有想过之前行业的门槛是什么样的,现在行业门槛是什么样的?以前企业对于程序员能力要求没有这么高,甚至十多年前你只要会写个“Hello World”,你都可以入门这个行业,所以以前要入门是完全可以入门的。
②现在也有一些优秀的年轻大牛,他们或许也是自学成才,但是他们一定是具备优秀的学习能力,优秀的自我管理能力(时间管理,静心坚持等方面)以及善于发现问题并总结问题。
如果说你认为你的目标十分明确,能做到第②点所说的几个点,以目前的市场来看,你才真正的适合去自学。
除此之外,对于绝大部分人来说,报班一定是最好的一种快速成长的方式。但是有个问题,现在市场上的培训机构质量参差不齐,如果你没有找准一个好的培训班,完全是浪费精力,时间以及金钱,这个需要自己去甄别选择。
我个人建议线上比线下的性价比更高,线下培训价格基本上没2W是下不来的,线上教育现在比较成熟了,此次疫情期间,学生基本上都感受过线上的学习模式。相比线下而言,线上的优势以我的了解主要是以下几个方面:
①价格:线上的价格基本上是线下的一半;
②老师:相对而言线上教育的师资力量比线下更强大也更加丰富,资源更好协调;
③时间:学习时间相对而言更*,不用裸辞学习,适合边学边工作,降低生活压力;
④课程:从课程内容来说,确实要比线下讲的更加深入。
应该学哪些技术才能达到企业的要求?(下图总结)
《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》,点击传送门即可获取!
格:线上的价格基本上是线下的一半;
②老师:相对而言线上教育的师资力量比线下更强大也更加丰富,资源更好协调;
③时间:学习时间相对而言更*,不用裸辞学习,适合边学边工作,降低生活压力;
④课程:从课程内容来说,确实要比线下讲的更加深入。
应该学哪些技术才能达到企业的要求?(下图总结)
[外链图片转存中…(img-JsyEmM70-1711980683748)]
[外链图片转存中…(img-O5RFr0GT-1711980683748)]
《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》,点击传送门即可获取!