Android之JAVASe基础篇-面向对象-类集(十)

前言–java类集是开发中用得最多的了吧,方便,功能强。
一、类集框架主要接口
类集主要接口!要掌握的。
接口的继承关系:
接口关系
1.List接口—List中允许有重复的数据
List

class Student{
    private String name;
    private String age;
    //无参和有参的构造
    getter/setter...
}
public class Test{
    public static void main(String[] args){
        Collection<Student> c=new ArrayList<Student>();
        c.add(new Student("刘欢",10));//Object obj=new Student("刘欢",10);
        c.add(new Student("赵四",11));
        c.add(new Student("王五",12));
        //把集合转为数组
        Object[] o=c.toArray();
        for(int i=0;i<o.length;i++){
            System.out.println(o[i]);
            //如果要根据集合中的名字取值则:
            Student s=(Student)o[i];//向下转型即可
            System.out.println("姓名:"s.getName()+'\t'+"年龄:"+s.getAge());
        }
        //直接使用迭代(遍历)输出
        Iterator it=c.iterator();
        if(it.hasNext()){
            System.out.println(it.next());//遍历输出
            //如果想直接输出名字或者年龄,则需要向下转型
            Student stu=(Student)it.next();
            System.out.println("姓名:"stu.getName()+'\t'+"年龄:"+stu.getAge());
        }
    }
}

1.1.LinkedList
LinkedList:表示的是一个链表的操作类.
LinkedList接口中的方法

import java.util.LinkedList ;
public class LinkedListDemo02{
    public static void main(String args[]){
        LinkedList<String> link = new LinkedList<String>() ;
        link.add("A") ; // 增加元素
        link.add("B") ; // 增加元素
        link.add("C") ; // 增加元素
        System.out.println("1-1、element()方法找到表头:" + link.element()) ;
        System.out.println("1-2、找完之后的链表的内容:" + link) ;
        System.out.println("2-1、peek()方法找到表头:" + link.peek()) ;
        System.out.println("2-2、找完之后的链表的内容:" + link) ;
        System.out.println("3-1、poll()方法找到表头:" + link.poll()) ;
        System.out.println("3-2、找完之后的链表的内容:" + link) ;

    }
};

1.2Queue接口:是Collection的子接口,定义如下:public interface Queue extends Collection
Queue接口中的方法

import java.util.LinkedList ;
public class LinkedListDemo03{
    public static void main(String args[]){
        LinkedList<String> link = new LinkedList<String>() ;
        link.add("A") ; // 增加元素
        link.add("B") ; // 增加元素
        link.add("C") ; // 增加元素
        System.out.print("以FIFO的方式输出:") ;
        for(int i=0;i<=link.size()+1;i++){
            System.out.print(link.poll() + "、") ;
        }
    }
};

2.Set接口–不能加入重复的元素
Set接口常用的子类:
2.1散列存放(无序):HashSet

import java.util.HashSet ;
import java.util.Set ;
public class HashSetDemo01{
    public static void main(String args[]){
        Set<String> allSet = new HashSet<String>() ;
        allSet.add("A") ;   // 增加内容
        allSet.add("B") ;   // 增加内容
        allSet.add("C") ;   // 增加内容
        allSet.add("C") ;   // 重复内容
        allSet.add("C") ;   // 重复内容
        allSet.add("D") ;   // 增加内容
        allSet.add("E") ;   // 增加内容
        System.out.println(allSet) ;
    }
};
2.2有序存放(可自动排序):TreeSet
import java.util.TreeSet ;
import java.util.Set ;
public class TreeSetDemo01{
    public static void main(String args[]){
        Set<String> allSet = new TreeSet<String>() ;
        allSet.add("C") ;   // 增加内容
        allSet.add("C") ;   // 重复内容
        allSet.add("C") ;   // 重复内容
        allSet.add("D") ;   // 增加内容
        allSet.add("B") ;   // 增加内容
        allSet.add("A") ;   // 增加内容
        allSet.add("E") ;   // 增加内容
        System.out.println(allSet) ;
    }
};

深入:使用hashCode(),equals(),取消掉重复元素,

import java.util.Set ;
import java.util.HashSet ;
class Person{
    private String name ;
    private int age ;
    public Person(String name,int age){
        this.name = name ;
        this.age = age ;
    }
    public boolean equals(Object obj){  // 覆写equals,完成对象比较
        if(this==obj){
            return true ;
        }
        if(!(obj instanceof Person)){
            return false ;
        }
        Person p = (Person)obj ;    // 向下转型
        if(this.name.equals(p.name)&&this.age==p.age){
            return true ;
        }else{
            return false ;
        }
    }
    public int hashCode(){
        return this.name.hashCode() * this.age  ; // 定义一个公式
    }
    public String toString(){
        return "姓名:" + this.name + ";年龄:" + this.age ;
    }
};
public class RepeatDemo02{
    public static void main(String args[]){
        Set<Person> allSet = new HashSet<Person>() ;
        allSet.add(new Person("张三",30)) ;
        allSet.add(new Person("李四",31)) ;
        allSet.add(new Person("王五",32)) ;
        allSet.add(new Person("王五",32)) ;
        allSet.add(new Person("王五",32)) ;
        allSet.add(new Person("赵六",33)) ;
        allSet.add(new Person("孙七",33)) ;
        System.out.println(allSet) ;
    }
};
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值