Java学習Day22--コレクションコレクション

ジェネリック

ジェネリックス:型パラメーター化、パラメーター化された型、パラメーターとして型を渡す

<大文字は複数あります>

ジェネリックの入力型は参照型のみになります

書かれていない場合、デフォルトのオブジェクト

public class TypeDemo<T,E> {
    
    
    T name;
    E color;

    public T test(E e){
    
    
        return null;
    }
    public static void main(String[] args) {
    
    

        TypeDemo<String,Integer>t = new TypeDemo();
        t.test(1);
        t.color=1;
        t.name="Str";


        ArrayList lis = new ArrayList();
        lis.add("a");
        lis.add(1);
        lis.add(true);

        for (int i = 0; i < lis.size(); i++) {
    
    
            Object sc = lis.get(i);
            if (sc instanceof String) {
    
    
                String s1 = (String) sc;
            }
            if (sc instanceof Integer) {
    
    
                Integer s2 = (Integer) sc;
            }
            if (sc instanceof Boolean) {
    
    
                Boolean s3 = (Boolean) sc;
            }

        }

    }
}

コレクションのコンセプト

コレクションは、要素を保持するために使用されるコンテナです

配列はコンテナでもあります。長さが定義されると、変更することはできず、同じタイプのデータのみを格納できます。

データを格納するために多くのコレクションクラスを提供するのはなぜですか?

1.コレクションの長さは可変です

2.さまざまなデータストレージ、さまざまな操作モード(配列、リンクリスト、ツリー、ハッシュテーブル)

集合システム

ここに画像の説明を挿入

コレクションインターフェイスのメソッド

デフォルトでは、任意のデータタイプをコレクションに格納できます。ジェネリックを使用して、同じタイプのデータを格納することをお勧めします。

 public static void main(String[] args) {
    
    
        //String类型,只能传入String类型数据
        Collection<String> c = new ArrayList<String>();
        c.add("abc");//添加数据
        c.add("ab");
        c.add("a");
        c.add("b");
        c.add("c");
        c.add("d");
        //c.clear();//清空数组
        System.out.println(c.remove("a"));//删除指定元素,有则返回true
        System.out.println(c.remove("f"));//没有返回false
        System.out.println(c.contains("a"));//是否包含
        System.out.println(c.isEmpty());//是否为空
        //有条件的删除
        c.removeIf(new Predicate<String>() {
    
    
            @Override
            public boolean test(String s) {
    
    
                return s.startsWith("a");//如果以a开头的都被删除
            }
        });
        System.out.println(c);
        c.stream().forEach((a)-> System.out.println(a));
        /*
        集合转数组
         */
        Object [] obj  =c.toArray();
        String [] str = c.toArray(new String[c.size()]);
        System.out.println(Arrays.toString(str));
        System.out.println(Arrays.toString(obj));
        /*
        数组转集合
         */
        Collection c1=Arrays.asList(1,2,3,4);
        ArrayList alist = new ArrayList<>(c1);
        System.out.println(alist.remove(1));
        System.out.println(alist);
       test(1,2,3,4);
    }
    /*
    int...a 可变长度的参数,本质是一个数组
    一个参数列表中只能有一个可变长度的参数,并且只能放在参数列表的末尾
     */
    public static void test(int a,int...b){
    
    
        System.out.println(a);
        System.out.println(Arrays.toString(b));
    }

ここに画像の説明を挿入

ここに画像の説明を挿入

インターフェイス機能の一覧表示

重複する要素を保存できます

順序付け(要素が格納されている順序で配置)

配列リスト

最下層は、配列の実装、高速クエリ、低速の追加と削除です

作成の開始時に、デフォルトの長さの配列が最下層に作成されます。配列のコンテンツがいっぱいになると、新しい配列は元のサイズの1.5倍に拡張されます。

短所:拡張後、要素を保存できず、スペースが無駄になります

LinkedList

低レベルのリンクリストの実装、遅いクエリ、速い追加と削除

要素をクエリするときは、最初のノードから逆方向に検索します。要素を追加および削除するときは、他の要素の位置は移動せず、ポインタフィールドの値を変更するだけで済みます。
ここに画像の説明を挿入

ArrayListのメソッド

public static void main(String[] args) {
    
    
        /*
        调用默认无参的构造方法时,创建ArrayList对象时,并没有实际的创建数组
        在第一次添加元素时创建,默认长度为10
        ArrayList最大容量 MAX_ARRAY_SIZE = Integer.MAX_VALUE - 8
         */
        ArrayList<String> alist = new ArrayList<>();
        /*
        调用有参构造方法,创建ArrayList对象时,创建一个指定长度的数组
         */
        ArrayList<String> alist1 = new ArrayList<>(5);

        alist.add("1");
        alist.add("2");
        alist.add("3");
        alist.add("4");
        alist.add("5");
        alist.add("6");
        alist.add("7");
        alist.add("8");
        alist.add("9");
        alist.add("10");
        //当add添加元素后,数组满了之后会扩容为原来的1.5倍
        alist.add("11");
        System.out.println(alist);

        System.out.println("获取指定索引的数"+alist.get(2));
        alist.set(2,"12");//改变指定索引的元素
        System.out.println(alist);

        System.out.println(alist.indexOf("4"));//从前获取元素的索引位置
        System.out.println(alist.lastIndexOf("10"));//从后开始获取元素的索引位置

        List<String> list = alist.subList(2,5);//获取指定索引区间的元素
        System.out.println(list);

    }

ここに画像の説明を挿入

ここに画像の説明を挿入

public static void main(String[] args) {
    
    
        ArrayList<String> alist = new ArrayList<>();

        alist.add("a");
        alist.add("b");
        alist.add("d");
        alist.add("c");
        alist.add("b");

    //集合排序
        alist.sort(new Comparator<String>() {
    
    
            @Override
            public int compare(String o1, String o2) {
    
    
                return o1.compareTo(o2);
            }
        });
        System.out.println(alist);
    }

ArrayListのすべてのメソッド

 public static void main(String[] args) {
    
    
        ArrayList<String> alist = new ArrayList<>();
        alist.add("a");
        alist.add("b");
        alist.add("c");
        alist.add("d");
        alist.add("f");
        ArrayList<String> alist1 = new ArrayList<>();
        alist1.add("a");
        alist1.add("b");
        alist1.add("c");
        alist1.add("d");
        alist1.add("e");

        //alist.forEach((a)-> System.out.println(a));

        //addAll 合并两个集合中的元素,相当于求并集
       /* alist.addAll(alist1);//
        System.out.println(alist);*/

        //containsAll 是否包含另一个集合中的元素,包含则返回true
        /*System.out.println(alist.containsAll(alist1));*/

        //removeAll 删除两个集合中相同的元素,有变化则返回true,相当求差4集
        /*System.out.println(alist.removeAll(alist1));
        System.out.println(alist);*/

        //retainAll 保留两个集合中相同的元素,有变化则返回true 相当于求交集
        System.out.println(alist.retainAll(alist1));
        System.out.println(alist);
    }

removeRange保護されたメソッド、サブクラスでアクセス可能

    public static void main(String[] args) {
    
    
        MyArrayList mylist = new MyArrayList();
        mylist.add("1");
        mylist.add("2");
        mylist.add("3");
        mylist.add("4");
        mylist.add("5");
        /*
        受保护的方法,在子类中访问
        删除1-4区间的元素,包括1不包括4
         */
        mylist.removeRange(1,4);
        System.out.println(mylist);
    }

LinkedListのメソッド(未完成)

    public static void main(String[] args) {
    
    
        LinkedList<String> llist = new LinkedList<>();
        llist.add("a");
        llist.add("b");
        llist.add("c");
        llist.add("d");
        llist.add("e");
        //查找某个元素从头结点或者尾结点开始查找,所有查询效率低
        System.out.println(llist.get(3));
    }

ここに画像の説明を挿入

ここに画像の説明を挿入

おすすめ

転載: blog.csdn.net/XiaoFanMi/article/details/111594854
おすすめ