首页 > 编程语言 >Java基础(集合)

Java基础(集合)

时间:2024-05-26 17:00:50浏览次数:28  
标签:Java String list 基础 add Student 集合 new public

一、集合概述

集合:可以存储任意类型的对象,并且长度可变的类

集合类位与java.util包中

集合类的继承体系如下图。

二、Collection接口

Collection是所有单列集合的父接口,定义了单列集合通用的一些方法,常用方法如下图。

开发中基本使用其子接口。

三、List接口

3.1List接口简介

List接口继承自Collection接口。

List集合允许出现重复的元素,所有的元素以线性方式存储,可以通过索引访问集合中的指定元素,元素的存入顺序和取出顺序一致。

List集合常用特有方法如下图。

3.2ArrayList集合

ArrayList是List接口的一个实现类,内部封装了一个长度可变的数组对象。

ArrayList集合查找元素便捷,不适合增删操作。

eg.

import java.util.*;
public class Main{
    public static void main(String[] args){
        ArrayList list = new ArrayList();
        list.add(1);
        list.add(2);
        list.add(3);
//打印元素长度
        System.out.println(list.size());
//打印指定位置元素
        System.out.println(list.get(1));
    }
}

3.3LinkedList集合

LinkedList集合是List接口的另一个实现类,内部维护了一个双向循环链表。

LinkedList集合增删效率高。

LinkedList集合常用特有方法如下图。

eg.

import java.util.*;
public class Main{
    public static void main(String[] args){
        LinkedList list = new LinkedList();
        list.add(1);
        list.add(2);
        list.add(4);
//指定位置插入元素
        list.add(2,3);
//删除指定位置元素
        list.remove(2);
    }
}

3.4Iterator接口

Iterator接口也是集合中的一员,但主要用于迭代访问(遍历)Collection中的元素,因此Iterator对象也称为迭代器。

Iterator对象在遍历集合时,内部采用指针的方式来跟踪集合中的元素。

遍历元素时,首先调用集合的iterator()方法获得迭代器对象,然后用hasNext()方法判断集合中是否存在下一个元素,如果存在则用next()方法取出元素,否则说明已到达集合末尾,停止遍历。

eg.

import java.util.*;
public class Main{
    public static void main(String[] args){
        ArrayList list = new ArrayList();
        list.add(1);
        list.add(2);
        list.add(3);
        Iterator it = list.iterator();
        while(it.hasNext()){
            Object obj = it.next();
            System.out.println(obj);
        }
    }
}

注意:集合在迭代器运行期间调用集合对象的remove()方法删除了元素,会导致迭代器预期的迭代次数发生改变,出现并发修改异常,如:

import java.util.*;
public class Main{
    public static void main(String[] args){
        ArrayList list = new ArrayList();
        list.add(1);
        list.add(2);
        list.add(3);
        Iterator it = list.iterator();
        while(it.hasNext()){
            Object obj = it.next();
            if(1.equals(obj)){
                list.remove(obj);   
            }
        }
    }
}

修改方式1:

import java.util.*;
public class Main{
    public static void main(String[] args){
        ArrayList list = new ArrayList();
        list.add(1);
        list.add(2);
        list.add(3);
        Iterator it = list.iterator();
        while(it.hasNext()){
            Object obj = it.next();
            if(1.equals(obj)){
                list.remove(obj);  
                break; 
            }
        }
    }
}

修改方式2:

import java.util.*;
public class Main{
    public static void main(String[] args){
        ArrayList list = new ArrayList();
        list.add(1);
        list.add(2);
        list.add(3);
        Iterator it = list.iterator();
        while(it.hasNext()){
            Object obj = it.next();
            if(1.equals(obj)){
                it.remove(obj);   
            }
        }
    }
}

因为调用迭代器对象的remove()方法删除元素所导致的迭代次数变化,对于迭代器对象本身来说是可预知的。

3.5foreach循环

foreach循环是一种更加简洁的for循环,也称增强for循环,用于遍历数组或集合中的元素,具体语法格式如下:

for(容器中元素类型 临时变量 : 容器变量){
    执行语句
}

eg.

import java.util.*;
public class Main{
    public static void main(String[] args){
        LinkedList list = new LinkedList();
        list.add(1);
        list.add(2);
        list.add(3);
        for(Object obj : list){
            System.out.println(obj);
        }
    }
}

注意:foreach循环遍历集合和数组时,只能访问集合中的元素,不能对其中的元素修改。

原因是只是将临时变量指向了一个新的变量,而与集合中的元素没有关系。

四、Set接口

4.1Set接口简介

Set接口继承自Collection接口,元素无序,并且都会以某种规则保证存入的元素不出现重复。

4.2HashSet集合

HashSet是Set接口的一个实现类,元素无序且不可重复。

HashSet存储元素的流程如下图。

如果存入的是自定义的类,应在定义类时重写hashCode()和equals()方法,否则不会去掉重复元素。

eg.

import java.util.HashSet;
class Student{
    String id;
    String name;
    public Student(String id, String name){
        this.id = id;
        this.name = name;
    }
//重写toString
    public String toString(){
        return id+":"+name;
    }
//重写hashCode
    public int hashCode(){
        return id.hashCode();//返回id属性的散列值
    }
//重写equals
    public boolean equals(Object obj){
        if(this == obj){return true;}//如果是同一个对象则直接返回true
        if(!(obj instanceOf Student)){return flase;}//判断对象是否为Student类型
        Student stu = (Student) obj;//强制转换为Student类型
        boolean b = this.id.equals(stu.id);//判断id值是否相等
        return b;
    }
}
public class Main{
    public static void main(String[] args){
        HashSet hs = new HashSet();
        Student stu1 = new Student("1","z");
        Student stu2 = new Student("2","l");
        Student stu3 = new Student("2","l");
        hs.add(stu1);
        hs.add(stu2);
        hs.add(stu3);
        System.out.println(hs);//输出只有前两个
    }
}

如果想让元素存储顺序一致,可以使用LinkedHashSet类,他也使用了双向链表。

4.3TreeSet集合

TreeSet可以对HashSet中的元素进行排序。

原因是因为元素的类可以实现Comparable接口,该接口强行对实现它的每个类的对象进行整体排序,这种排序被称为类的自然排序。该接口的compareTo()方法称为自然比较方法。

自定义对象必须实现Comparable接口并重写compareTo()方法实现对象元素的顺序存取。

eg.

import java.util.TreeSet;
class Student{
    String id;
    String name;
    public Student(String id, String name){
        this.id = id;
        this.name = name;
    }
//重写toString
    public String toString(){
        return id+":"+name;
    }
    @Override
    public int compareTo(Student o){
        return 0;//集合中只有一个元素
        //return 1;//怎么存就怎么取
        //return -1;//倒序取
    }
}
public class Main{
    public static void main(String[] args){
        TreeSet ts = new TreeSet();
        Student stu1 = new Student("1","z");
        Student stu2 = new Student("2","l");
        Student stu3 = new Student("2","l");
        ts.add(stu1);
        ts.add(stu2);
        ts.add(stu3);
        System.out.println(hs);
    }
}

除了自然排序,还有比较器排序。即实现Comparator接口,重写compare()方法。

eg.

import java.util.Comparator;
import java.util.TreeSet;
class Student{
    String id;
    String name;
    public Student(String id, String name){
        this.id = id;
        this.name = name;
    }
//重写toString
    public String toString(){
        return id+":"+name;
    }
}
public class Main{
    public static void main(String[] args){
        TreeSet ts = new TreeSet(new Comparator(){
            @Override
            public int compare (Object obj1, Object obj2){
                return 0;
            }    
        );
        Student stu1 = new Student("1","z");
        Student stu2 = new Student("2","l");
        Student stu3 = new Student("2","l");
        ts.add(stu1);
        ts.add(stu2);
        ts.add(stu3);
        System.out.println(hs);
    }
}

五、Map接口

5.1Map接口简介

Map接口是一种双列集合,每个元素都包含一个键值对,键和值之间存在的对应关系称为映射。

常用方法:

5.2HashMap集合

HashMap没有重复的键且键值无序。如果存入已存在的键,新的值会覆盖原来的值。

eg.遍历键值对方法

import java.util.*;
public class Main{
    public static void main(String[] args){
        HashMap map = new HashMap();
        map.put("1","a");    
        map.put("2","b"); 
        map.put("3","c");
        Set entrySet = map.entrySet();
        Iterator it = entrySet.iterator();
        while(it.hasNext()){
            Map.Entry entry = (Map.Entry)(it.next());
            Object key = entry.getKey();
            Object value = entry.getValue();
            System.out.println(key+":"+value);
        }   
    }
}

5.3TreeMap集合

Map接口提供了一个可以对集合中元素键值进行排序的类TreeMap。

键必须唯一。

TreeMap也分为自然排序和比较排序。

5.4Properties集合

Map接口中的实现类HashTable与HashMap类似,但前者线程安全。

HashTable存取元素速度很慢,目前已被取代,但子类Properties有用。

Properties主要用来存储字符串的键和值,实际开发中用来存取应用的配置项。

eg.

import java.util.*;
public class Main{
    public static void main(String[] args){
        Properties p = new Properties();
        p.setProperty("Background-color","red");
        p.setProperty("Font-size","14px");
        Enumeration names = p.propertyNames();//获取Enumeration对象所有键的枚举
        while(names.hasMoreElements()){
            String key = (String) names.nextElement();
            String value = p.getProperty(key);
            System.out.println(key+"="+value);
        }
        
    }
    
}

六、泛型

6.1泛型概述

泛型是程序设计语言的一种特性。允许程序员在使用强类型程序设计语言编写代码时定义一些可变部分,这些可变部分在运行前必须指明。

在编程中用泛型代替某个实际的类型,而后通过实际调用时传入或推导的类型来对泛型进行替换,达到代码复用。

6.2泛型类和泛型对象

泛型类是在类声明时通过一个标识表示类中某个属性的类型或者是某个方法的返回值和参数类型。

import java.util.*;
public class Main{
    public static void main(String[] args){
        ArrayList<Integer> list = new ArrayList<Integer>();
        list.add(1);
        list.add(2);
        for(Integer str : list){
            System.out.prinln(str);
        }
    }
}

6.3泛型方法

泛型方法所在的类是不是泛型类都可以。

import java.util.*;
public class Main{
    public static void main(String[] args){
        Dog dog = new Dog();
        dog.show("hello");
        dog.show(1);
        dog.show(0.5);
    }
}
class Dog{
    String eat;
    Integer age;
    public <T> void show(T t){
        System.out.println(t);
    }       
}

6.4泛型接口

泛型接口的定义

interface Infor<T>{
    public T getVar();
} 

定义泛型接口的子类有两种方式:

1.在子类实现的接口中明确给出泛型类型;

2.直接在子类后声明泛型。

6.5类型通配符

Java中集合不能协变,即List<Animal>不是List<Dog>的父类。

为了解决这个问题,Java泛型提供了类型通配符?。

eg.

import java.util.*;
public class Main{
    public static void main(String[] args){
        ArrayList<Integer> list = new ArrayList<Integer>();
        list.add(1);
        list.add(2);
        test(list);
    }
    public static void test(List<?> list){
        for(int i = 0;i<list.size();i++){
            System.out.println(list.get(i));
        }
    }
}

注意,如果使用了通配符“?”接受泛型对象,则该对象只能被接受不能修改。

七、JDK8新特性——Lambda表达式

Lambda表达式可以取代大部分的匿名内部类,在集合的便利和其它集合的操作中优化代码结构。

Lambda表达式由参数列表、箭头符号->和函数体构成。函数体既可以是一个表达式,也可以是一个语句块。

常用的语法格式如下表。

标签:Java,String,list,基础,add,Student,集合,new,public
From: https://blog.csdn.net/fwputty/article/details/138921344

相关文章

  • java顺序结构,循环结构,选择结构,增强for循环,switch穿透现象,值匹配
    顺序结构inta=10;intb=20;intc=a+b;System.out.println(c);//按顺序执行循环结构一、For循环格式for(初始化语句;循环条件;迭代语句){循环语句体;}for(inti=0;i<5;i++){System.out.println("我爱你");}int[]is={1,2,3};for(inti=0;i<is.l......
  • java数组一篇文章搞定
    Array数组数组(Array) 是一种线性数据结构,它用一组连续的内存空间来存储一组具有相同类型的数据。这些数据可以是整数、浮点数、字符、对象等,但必须是同一种类型。数组中的每个数据元素都有一个唯一的索引值,这个索引值通常从0开始,用于访问或修改该元素。数组基本特点:1.长度......
  • Java中的变量分类(按照位置分类)
    变量按位置分通过上面类的建立我们又得到了新的概念:成员变量和局部变量成员变量:可以使用基本数据类型,也可以使用引用数据类型.java中的变量在使用时必须初始化,成员变量可以不对其初始化,系统会对其默认初始化为null或0;成员变量可以在成员方法,构造方法,代码块中使用补:成......
  • Docker Java项目部署
    将你的java项目打包为一个jar包准备Dockerfile文件#设置本镜像需要使用的基础镜像FROMjava:8#把jar包添加到镜像中ADDyylq-ds.jar/app.jar#镜像暴露的端口EXPOSE8199RUNbash-c'touch/app.jar'#容器启动命令ENTRYPOINT["java","-jar","/app.......
  • linux核心基础-权限管理
    1、更改文件的权限命令总结2、文件、目录的的rwx想要删除文件,要看是否有该文件所在目录,目录是否有w权限,才可以删除文件,且还得有x权限,才能进入文件夹。(用普通用户测试)3、环境变量1、env和set命令env命令为单个用户的环境变量命令为系统整体的环境变量[root@muserver1etc]......
  • 集合竞价选股策略实战测试
    2.3.2版本发布的集合竞价选股策略是网友吴PSYP提供的,团队按照策略实现的选股算法,最近半个月对策略进行的实战测试,从集合竞价选股开始,到股票收盘,收盘价格大于集合竞价价格,算作盈利,测试结果如下,一共12个交易日,共132只股票,其中收盘价格大于集合竞价价格的一共有105只,占80%,其中收盘涨......
  • javaSwing+JDBC+mysql校园跑管理项目(附源码下载)
    1.数据准备DELETEFROMstudents;Deletefromrunning;INSERTINTOstudents(student_id,name,age,major,grade)VALUES(1,'王小明',20,'计算机科学与技术','男'),(2,'张小红',21,'软件工程','女'),(3......
  • 【精简笔记】JavaScript基础内容大总结
    往期文章目录【精简笔记】JavaScript基础内容第一天【精简笔记】JavaScript基础内容第二天【精简笔记】JavaScript基础内容第三天【精简笔记】JavaScript基础内容第四天【精简笔记】JavaScript基础内容第五天文章目录往期文章目录前言一、JavaScript的书写位置1.......
  • JavaScript 新特性:新增声明命令与解构赋值的强大功能
    个人主页:学习前端的小z个人专栏:JavaScript精粹本专栏旨在分享记录每日学习的前端知识和学习笔记的归纳总结,欢迎大家在评论区交流讨论!ES5、ES6介绍文章目录......
  • JavaScript 系列教程 III JavaScript 代码质量
    ......