创建字符串对象的方式
通过“ ”创建对象‘
String s=“love”; 通过构造器创建对象
new string 用字符数组来创建字符串对象
char[] chars={‘a’,‘b’,‘中’,‘国’};String s1=new String(chars); 字节数组来创建字符串对象
btye[ ] bytes={97,98,99,65,66}String s2=new String(bytes); 通过" "和用构造器来创建对象有何区别?
使用第一种方式:
以" "方式创建对象,在字符串常量池中存储相同内容只会在其中存储一份通过构造器new对象,每new一次都会产生一个新的对象,放在堆内存中 或者使用第二种方式:
双引号创建的字符串对象,在字符串常量池中存储同一个通过new构造器创建的字符串对象,在堆内存中分开存储 String常用API
比较两个值是否相等:
==判断地址是否相同,equails判断内容是否相同 计算字符串的长度:
s.length() ====>4 截取字符串的某一个字符:
s.charAt(1) ====>o 把字符串转换成字符数组:
char[] chars=s.tocharArray() ====>{‘l’,‘o’,‘v’,‘e’}; 截取一段内容(包括前不包括后)
s.substring(0,3) ====>lo 从当前索引一直取到末尾:
s.substring(2) ====>ve 进行替换
s.replace(“ov”,"***"); ====>l***e 判断是否包含:
s.contains(“ov”) ====>false,因为上一步已经进行了替换 以…开始
s.startswith(“l*”); ====>true 将字符串分割成字符串数组返回
name1=“1,2,3,4”;name1.split(","); ArrayList集合
特性:
集合是大小不固定,可以动态变化的,,,,,数组类型确定,长度确定并且元素是可以重复的,元素存在索引存储在堆内存中 ArrayList集合常用API
ArrayList的创建:
ArrayList list=new ArrayList();
添加数据:
list.add(“java”); 可重复添加数据
获取数据:
list.get(0); 获取下标为0的数据
指定索引添加数据:
list.add(1,“java”); 指定索引添加数据,如果改位置已经有数据,则该位置及其以后的数据都将向后移动
ArrayList,其中的E为指定的泛型
带泛型的创建:
ArrayList list1=new ArrayList<>();
获取集合的大小:
list1.size
删除下标为n的数据:
list.remove(n)
根据具体值进行删除:
list.remove(“mybatis”);如果其中有相同的元素,将删除第一次出现的元素返回true或false
根据下标替换:
list.set(0,”咿呀咿呀哟“) 将下标为0的元素,替换为咿呀咿呀哟
注意:
集合和泛型都不支持基本数据类型,只能支持引用数据类型Object
贴心面经 remove注意:
for(int i = 0 ; i< scores.size() ; i++){
int score=scores.get(i);
if(score<80){
score.remove(i);
}
}
system.out.println("scores");
这样会出现一个问题有的元素会被漏删除
此程序的主要目的是将小于80分的成绩进行删除,假设score中存放的是{89,45, 65, 79,92},则在程序执行后会输出{89,65,92},显然可以看出有一些需要被删除的数据没有被删除。
为什么会出现漏删的问题呢?
此循环在遍历时,是通过指针变量控制进行循环的,指针变量在第一次比较时处在下标为0的位置,再进行数值的比较,89不小于80,指针变量移动到下标为1的位置,进行判断,45小于80,将会进入if判断的内部,会被remove掉,在被删除后,后面的65, 79,92这些元素会自动向前移动,此时集合会变成{89,65, 79,92},指针接着向下一个位置移动,将79带入进行的条件判断,79小于80,这样79就会被移除,其他元素自动向前移动,此时集合变为{89,65,92},这样65即使不符合条件,也会被跳过,所以有了漏删的现象。
总结一下:因为在删除元素比较时,前者符合条件,被删除了。后面的元素会自动移动到它的前一个位置,指针指向的位置移动到下一个元素的位置,所以会有漏删的问题。
那么增么解决这一个问题呐?
方案一:
将i在if语句中进行i–;
修改后的代码:
for(int i = 0 ; i< scores.size() ; i++){
int score=scores.get(i);
if(score<80){
score.remove(i--);
}
}
system.out.println("scores");
方案二:
倒序遍历
修改后的代码:
for(int i = scores.size() ; i>=0 ; i++){
int score=scores.get(i);
if(score<80){
score.remove(i);
}
}
system.out.println("scores");



