1.基礎(chǔ)知識:
數(shù)組:
1.弊端:數(shù)組長度不可變 內(nèi)容可變
2.特點(diǎn):有序 可重復(fù)
集合:
1.特點(diǎn):無序 不重復(fù)
2.集合的元素個數(shù)是可變的
添加元素
add
adAll
3.集合數(shù)組的相關(guān)方法
刪除元素:remove
獲取元素個數(shù):size
是否包含?一個元素:contains
是否為空:isEmpty
集合?比較:equals
注意用法:
判斷兩個集合是否相同
Collection<String>t2=new ArrayList<>();
t2.add("asdas");
if(t1.equals(t2)){
System.out.println("兩個集合相同");
}else{
System.out.println("兩個集合不相同");
}
清空:clear
4.集合的遍歷
1.使用Iterator來遍歷
hasNext 判斷是否有元素
next 獲取下一個對象
remove 刪除當(dāng)前遍歷過后的對象
5.進(jìn)一步用法
//集合里面只能存放對象
// byte char int long float double boolean
//包裝類
// Byte Char Integer Long Float Double Boolean
//自動將基本數(shù)據(jù)包裝為對應(yīng)的類
ArrayList<Integer> score = new ArrayList<>();
score.add(2);
score.add(3);//在末尾添加
score.add(0, 1);//在指定位插入
System.out.println(score);
//訪問指定元素
score.get(1);
//修改一個元素
score.set(0, 0);
System.out.println(score);
//刪除
score.remove(0);//刪除指定位置的元素
System.out.println(score);
score.remove((Integer) 3);//刪除指定的對象
System.out.println(score);
score.clear();//刪除所有 清空
System.out.println(score);
ArrayList<Integer> a2 = new ArrayList<>();
a2.add(1);
a2.add(2);
a2.add(3);
//將一個集合里面的內(nèi)容添加到當(dāng)前集合中
score.addAll(a2);
System.out.println(score);
ArrayList<Integer> a3 = new ArrayList<>();
a3.add(1);
a3.add(2);
score.retainAll(a3);//取兩個集合的交集
System.out.println(score);
//訪問某個對象在集合里面的索引
ArrayList<Integer> a4 = new ArrayList<>();
a4.add(1);
a4.add(2);
a4.add(2);
a4.add(2);
System.out.println(a4.indexOf(2));
System.out.println(a4.lastIndexOf(2));//最后出現(xiàn)的位置
//將ArrayList轉(zhuǎn)化為普通數(shù)組
Integer[] objects = new Integer[a4.size()];
a4.toArray(objects);
for (Integer i : objects) {
System.out.println(i);
}
System.out.println("----------");
Object[] objects1 = a4.toArray();
for (Object i : objects1) {
System.out.println(i);
}
System.out.println("----------");
Iterator iterator = a4.iterator();
while (iterator.hasNext()) {
System.out.println(iterator.next());
}
//刪除某個范圍內(nèi)的對象
block
Lambda表達(dá)式
return (var1) -> {
return !this.test(var1);
};
return 20;
System.out.println("-----------");
// 獲取集合某個范圍的?子集合
List<Integer> integers = a4.subList(1, 3);
System.out.println(integers);
2.數(shù)組相關(guān)操作的實現(xiàn):
公用部分
class ArrayClass{
public void test(int[] target,show s) {
for(int element:target){
s.customshow(element);
}
}
}
//必須是接口 這個接口里面只有一個方法
interface show{
void customshow(int element);
}
class PXDClass implements show{
@Override
public void customshow(int element) {
System.out.println(element);
}
}
1.使用方式: 定義一個類實現(xiàn)接口
ArrayClass ac = new ArrayClass();
int[] num = {1,2,3,4,5,6};
PXDClass pc = new PXDClass();
ac.test(num, pc);
2.使用匿名類
ArrayClass ac = new ArrayClass();
int[] num = {1,2,3,4,5,6};
ac.test(num, new show() {
@Override
public void customshow(int element) {
System.out.println(element);
}
});
3.為了讓Lambda表達(dá)式晚些執(zhí)行带兜,我們需要用函數(shù)式接口接收Lambda表達(dá)式
如果參數(shù)是一個接口類對象揍异,且接口里面只有一個方法
把這個方法作為參數(shù)傳遞過去 可以省略方法名
int[] num = {1, 2, 3, 4, 5, 6};
new ArrayClass().test(num, (int element) -> {
System.out.println(element);
});
4.如果只有一個參數(shù) 參數(shù)類型可以省略
int[] num = {1, 2, 3, 4, 5, 6};
new ArrayClass().test(num, (int element) -> {
System.out.println(element);
});
5.如果代碼塊里面只有一行語句 大括號可以省略
int[] num = {1, 2, 3, 4, 5, 6};
new ArrayClass();.test(num,element ->System.out.println(element) );
3.實現(xiàn)集合的篩選
public class Myclass {
public static void main(String[] args) {
List<Person>list =new ArrayList<>();
Person p1 = new Person();
p1.age=20;
p1.name="小王";
Person p2=new Person();
p2.name="小李";
p2.age=29;
Person p3=new Person();
p3.name="小哈";
p3.age=31;
Person p4=new Person();
p4.name="王博";
p4.age=27;
list.add(p1);
list.add(p2);
list.add(p3);
list.add(p4);
int agecount=0;
int wangcount=0;
for (Person p:list){
if(p.age>30){
agecount++;
}
if(p.name.contains("王")){
wangcount++;
}
}
System.out.println(agecount+" "+wangcount);
class Person{
String name ;
int age;
}
}
public Person(){
}
}
4.創(chuàng)建一個集合中的比較器
ArrayList<Integer>a1=new ArrayList<>();
a1.add(2);
a1.add(1);
a1.add(4);
a1.add(3);
a1.add(5);
a1.sort(new PXDCompare());
System.out.println(a1);
class PXDCompare implements Comparator{
//什么時候需要自己手動創(chuàng)建比較器
//如果系統(tǒng)默認(rèn)提供的方法不能完成我們的比較
//
@Override
public int compare(Object o, Object t1) {
int mo = (int)o;
int mt1 = (int)t1;
return mo - mt1;
}
}
5.心得
今天的內(nèi)容還好就是上課太困了,下來好好復(fù)習(xí)一下內(nèi)容,上課懵逼的點(diǎn)掌握得也ok叮阅,知識還是有點(diǎn)雜亂,缺乏梳理泣特,得花時間來仔細(xì)整理牢固 東哥布置的任務(wù)思索一下還是不得其解明天上課加油吧