栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

Java扩展之part01 常用API(String和ArrayList)

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Java扩展之part01 常用API(String和ArrayList)

1.常用API(String和ArrayList) String

创建字符串对象的方式

通过“ ”创建对象‘

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");
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/708219.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号