zoukankan      html  css  js  c++  java
  • JavaSE知识-16(List集合)

    去除ArrayList中重复字符串元素方式

    • 案例演示
      • 需求:ArrayList去除集合中字符串的重复值(字符串的内容相同)
      • 思路:创建新集合方式
    package com.hwh.list;
    import java.util.ArrayList;
    import java.util.Iterator;
    public class Demo1_ArrayList {
    	public static void main(String[] args) {
    			ArrayList list = new ArrayList();
    			list.add("a");
    			list.add("a");
    			list.add("b");
    			list.add("b");
    			list.add("c");
    			list.add("c");
    			list.add("c");
    			list.add("c");
    			
    			ArrayList newList = getSingle(list);
    			System.out.println(newList);
    		}
    		/*
    		 * 创建新集合将重复元素去掉
    		 * 1,明确返回值类型,返回ArrayList
    		 * 2,明确参数列表ArrayList
    		 * 
    		 * 分析:
    		 * 1,创建新集合
    		 * 2,根据传入的集合(老集合)获取迭代器
    		 * 3,遍历老集合
    		 * 4,通过新集合判断是否包含老集合中的元素,如果包含就不添加,如果不包含就添加
    		 */
    		public static ArrayList getSingle(ArrayList list) {
    			ArrayList newList = new ArrayList();					//1,创建新集合
    			Iterator it = list.iterator();							//2,根据传入的集合(老集合)获取迭代器
    			
    			while(it.hasNext()) {									//3,遍历老集合
    				Object obj = it.next();								//记录住每一个元素
    				if(!newList.contains(obj)) {						//如果新集合中不包含老集合中的元素
    					newList.add(obj);								//将该元素添加
    				}
    			}
    			return newList;
    		}
    	}
    

    去除ArrayList中重复自定义对象元素

    • A:案例演示
      • 需求:ArrayList去除集合中自定义对象元素的重复值(对象的成员变量值相同)
    • B:注意事项
      • contains方法判断是否包含,底层依赖equals方法, remove方法判断是否删除,底层依赖的是equals方法, 而Object类中equals比较地址值, 需要重写equals()方法的

    如果没有重写, 运行结果为[Person [name=张三, age=23], Person [name=张三, age=23], Person [name=李四, age=24], Person [name=李四, age=24], Person [name=李四, age=24], Person [name=李四, age=24]] 并没去除重复

    package com.hwh.list;
    import java.util.ArrayList;
    import java.util.Iterator;
    import com.hwh.bean.Person;
    	@SuppressWarnings({ "rawtypes", "unchecked" })
    public class Demo2_ArrayList {
    	public static void main(String[] args) {
    
    				ArrayList list = new ArrayList();				//创建集合对象
    				list.add(new Person("张三", 23));
    				list.add(new Person("张三", 23));
    				list.add(new Person("李四", 24));
    				list.add(new Person("李四", 24));
    				list.add(new Person("李四", 24));
    				list.add(new Person("李四", 24));
    				
    				ArrayList newList = getSingle(list);			//调用方法去除重复
    				System.out.println(newList);//[Person [name=张三, age=23], Person [name=李四, age=24]]
    				//list.remove(new Person("张三", 23));
    				//System.out.println(list);//[Person [name=张三, age=23], Person [name=李四, age=24], Person [name=李四, age=24], Person [name=李四, age=24], Person [name=李四, age=24]]
    			}
    			/*
    			 * 创建新集合将重复元素去掉
    			 * 1,明确返回值类型,返回ArrayList
    			 * 2,明确参数列表ArrayList
    			 * 
    			 * 分析:
    			 * 1,创建新集合
    			 * 2,根据传入的集合(老集合)获取迭代器
    			 * 3,遍历老集合
    			 * 4,通过新集合判断是否包含老集合中的元素,如果包含就不添加,如果不包含就添加
    			 */
    			public static ArrayList getSingle(ArrayList list) {
    				ArrayList newList = new ArrayList();					//1,创建新集合
    				Iterator it = list.iterator();							//2,根据传入的集合(老集合)获取迭代器
    				
    				while(it.hasNext()) {									//3,遍历老集合
    					Object obj = it.next();								//记录住每一个元素
    					if(!newList.contains(obj)) {						//如果新集合中不包含老集合中的元素
    						newList.add(obj);								//将该元素添加
    					}
    				}
    				return newList;
    			}
    		}
    

    LinkedList的特有功能

    • A:LinkedList类概述
    • B:LinkedList类特有功能
      • public void addFirst(E e)及addLast(E e)
      • public E getFirst()及getLast()
      • public E removeFirst()及public E removeLast()
      • public E get(int index);
    package com.hwh.list;
    import java.util.LinkedList;
    public class Demo3_LinkedList {
    	@SuppressWarnings({ "rawtypes", "unchecked" })
    	public static void main(String[] args) {
    
    				LinkedList list = new LinkedList();
    				list.addFirst("a");
    				list.addFirst("b");
    				list.addFirst("c");
    				list.addFirst("d");
    				list.addLast("e");
    				//dcbae
    				System.out.println(list.getFirst());//d
    				System.out.println(list.getLast());//e
    				System.out.println(list.removeFirst());//d
    				System.out.println(list.removeLast());//e
    				
    				System.out.println(list.get(1));//b
    				System.out.println(list);//[c, b, a]
    			}
    		}
    

    栈和队列数据结构

      • 先进后出
    • 队列
      • 先进先出

    用LinkedList模拟栈数据结构的集合并测试

    • 案例演示
      • 需求:请用LinkedList模拟栈数据结构的集合,并测试
      • 创建一个类将Linked中的方法封装
    package com.hwh.list;
    import java.util.LinkedList;
    public class Demo4_LinkedList {
    	public static void main(String[] args) {
    				//demo1();
    				Stack s = new Stack();
    				s.in("a");								//进栈
    				s.in("b");
    				s.in("c");
    				s.in("d");
    				
    				while(!s.isEmpty()) {					//判断栈结构是否为空
    					System.out.println(s.out());		//dcba//弹栈
    				}
    			}
    
    			@SuppressWarnings({ "unchecked", "rawtypes" })
    			public static void demo1() {
    				LinkedList list = new LinkedList();					//创建集合对象
    				list.addLast("a");1
    				list.addLast("b");
    				list.addLast("c");
    				list.addLast("d");
    				
    				/*System.out.println(list.removeLast());
    				System.out.println(list.removeLast());
    				System.out.println(list.removeLast());
    				System.out.println(list.removeLast());*/
    				
    				while(!list.isEmpty()) {
    					System.out.println(list.removeLast());
    				}
    			}
    		}
    
    package com.hwh.list;
    import java.util.LinkedList;
    public class Stack {
    	private LinkedList list = new LinkedList();	
    	/*
    	 * 模拟进栈方法
    	 */
    	public void in(Object obj) {
    		list.addLast(obj);
    	}
    	
    	/*
    	 * 模拟出栈
    	 */
    	public Object out() {
    		return list.removeLast();
    	}
    	
    	/*
    	 * 模拟栈结构是否为空
    	 */
    	
    	public boolean isEmpty() {
    		return list.isEmpty();
    	}
    }
    

    泛型概述和基本使用

    • A:泛型概述
    • B:泛型好处
      • 提高安全性(将运行期的错误转换到编译期)
      • 省去强转的麻烦
    • C:泛型基本使用
      • <>中放的必须是引用数据类型
    • D:泛型使用注意事项
      • 前后的泛型必须一致,或者后面的泛型可以省略不写(1.7的新特性菱形泛型)
    package com.hwh.generic;
    import java.util.ArrayList;
    import java.util.Iterator;
    import com.hwh.bean.Person;
    public class Demo1_Generic {
    	public static void main(String[] args) {
    				demo1();
    				//int[] arr = new byte[5];							//数组要保证前后的数据类型一致
    				//ArrayList<Object> list = new ArrayList<Person>();	//集合的泛型要保证前后的数据类型一致
    				//ArrayList<Object> list = new ArrayList<>();		//1.7版本的新特性,菱形泛型
    				ArrayList<Object> list = new ArrayList<>();			//泛型最好不要定义成Object,没有意义
    				list.add("aaa");
    				list.add(true);
    			}
    
    			public static void demo1() {
    				ArrayList<Person> list = new ArrayList<Person>();
    			//	list.add(110);
    			//	list.add(true);
    				list.add(new Person("张三", 23));
    				list.add(new Person("李四", 24));
    				
    				Iterator<Person> it = list.iterator();
    				while(it.hasNext()) {
    					//System.out.println(it.next());//Person [name=张三, age=23] Person [name=李四, age=24]
    					
    					//System.out.println(it.next().getName() + "..." + it.next().getAge());//张三...24//next方法只能调用一次,如果调用多次会将指针向后移动多次
    					Person p = it.next();			
    					System.out.println(p.getName() + "..." + p.getAge());//张三...23 李四...24
    				}
    			}
    		}
    

    ArrayList存储字符串和自定义对象并遍历泛型版

    • A:案例演示
      • ArrayList存储字符串并遍历泛型版
    package com.hwh.generic;
    import java.util.ArrayList;
    import java.util.Iterator;
    import com.hwh.bean.Person;
    public class Demo2_Generic {
    	public static void main(String[] args) {
    		
    				//demo1();
    				ArrayList<Person> list = new ArrayList<>();
    				list.add(new Person("张三", 23));
    				list.add(new Person("李四", 24));
    				list.add(new Person("王五", 25));
    				list.add(new Person("赵六", 26));
    				
    				Iterator<Person> it = list.iterator();
    				while(it.hasNext()) {
    					Person p = it.next();							//将集合中的每一个元素用Person记录
    					System.out.println(p.getName() + "..." + p.getAge());
    				}
    			}
    
    			public static void demo1() {
    				ArrayList<String> list = new ArrayList<>();			//创建集合对象
    				list.add("a");
    				list.add("b");
    				list.add("c");
    				list.add("d");
    				
    				Iterator<String> it = list.iterator();
    				while(it.hasNext()) {
    					System.out.println(it.next());
    				}
    			}
    		}
    

    泛型接口的概述和使用

    • A:泛型接口概述
      • 把泛型定义在接口上
    • B:定义格式
      • public interface 接口名<泛型类型>
    • C:案例演示
      • 泛型接口的使用
    package com.hwh.generic;
    public class Demo4_Generic {
    	public static void main(String[] args) {
    			}
    		}
    
    		interface Inter<T> {
    			public void show(T t);
    		}
    
    		/*class Demo implements Inter<String> {		//推荐用这种
    
    			@Override
    			public void show(String t) {
    				System.out.println(t);
    			}
    			
    		}*/
    
    		class Demo<T> implements Inter<T> {			//没有必要在实现接口的时候给自己类加泛型
    
    			@Override
    			public void show(T t) {
    				System.out.println(t);
    			}
    		}
    

    泛型高级之通配符

    • A:泛型通配符<?>
      • 任意类型,如果没有明确,那么就是Object以及任意的Java类了
    • B:? extends E
      • 向下限定,E及其子类
    • C:? super E
      • 向上限定,E及其父类
    package com.hwh.bean;
    public class Student extends Person{
    	public Student() {
    		super();
    	}
    
    	public Student(String name, int age) {
    		super(name, age);
    	}
    }
    
    package com.hwh.generic;
    import java.util.ArrayList;
    import com.hwh.bean.Person;
    import com.hwh.bean.Student;
    public class Demo5_Generic {
    	public static void main(String[] args) {
    				//List<?> list = new ArrayList<Integer>();			//当右边的泛型是不确定时,左边可以指定为?
    				ArrayList<Person> list1 = new ArrayList<>();
    				list1.add(new Person("张三", 23));
    				list1.add(new Person("李四", 24));
    				list1.add(new Person("王五", 25));
    				
    				ArrayList<Student> list2 = new ArrayList<>();
    				list2.add(new Student("赵六", 26));
    				list2.add(new Student("周七", 27));
    				
    				list1.addAll(list2);
    				System.out.println(list1);
    			}
    		}
    

    运行结果为[Person [name=张三, age=23], Person [name=李四, age=24], Person [name=王五, age=25], Person [name=赵六, age=26], Person [name=周七, age=27]]

    增强for的概述和使用

    • A:增强for概述
      • 简化数组和Collection集合的遍历
    • B:格式:
    •   for(元素数据类型 变量 : 数组或者Collection集合) {
        	使用变量即可,该变量就是元素
        }
      
    • C:案例演示
      • 数组,集合存储元素用增强for遍历
    • D:好处
      • 简化遍历
    package com.hwh.jdk5;
    import java.util.ArrayList;
    import com.hwh.bean.Person;
    public class Demo1_Foreach {
    	public static void main(String[] args) {
    				demo1();
                }
    
    			public static void demo1() {
    				int[] arr = {11,22,33,44,55};
    				for (int i : arr) {
    					System.out.println(i);
    				}
    				
    				ArrayList<String> list = new ArrayList<>();
    				list.add("a");
    				list.add("b");
    				list.add("c");
    				list.add("d");
    				
    				for (String string : list) {
    					System.out.println(string);
    				}
    			}
    		}
    

    运行结果为11 22 33 44 55 a b c d

    ArrayList存储字符串和自定义对象并遍历增强for版

    • 增强for循环底层依赖的是迭代器(Iterator)
    package com.hwh.jdk5;
    
    import java.util.ArrayList;
    
    import com.hwh.bean.Person;
    
    public class Demo1_Foreach {
    
    	public static void main(String[] args) {
    				demo2();
    			}
    			
    			public static void demo2() {
    				ArrayList<Person> list = new ArrayList<>();
    				list.add(new Person("张三", 23));
    				list.add(new Person("李四", 24));
    				list.add(new Person("王五", 25));
    				list.add(new Person("赵六", 26));
    				
    				for (Person person : list) {
    					System.out.println(person);
    				}
    			}
    		}
    

    运行结果为Person [name=张三, age=23]
    Person [name=李四, age=24]
    Person [name=王五, age=25]
    Person [name=赵六, age=26]

    三种迭代的能否删除

    • 普通for循环,可以删除,但是索引要--
    • 迭代器,可以删除,但是必须使用迭代器自身的remove方法,否则会出现并发修改异常
    • 增强for循环不能删除
    package com.hwh.jdk5;
    
    import java.util.ArrayList;
    import java.util.Iterator;
    public class Demo1_Foreach {
    	public static void main(String[] args) {
    		ArrayList<String> list = new ArrayList<>();
    		list.add("a");
    		list.add("b");
    		list.add("b");
    		list.add("c");
    		list.add("d");
    
    		// 1,普通for循环删除,索引要--
    		  /*for(int i = 0; i < list.size(); i++){
    			  if("b".equals(list.get(i))) {
    				  //list.remove(i); //[a, b, c, d]
    				  	//remove(i)移除列表中指定位置的元素(可选操作)。将所有的后续元素向左移动(将其索引减 1)。
    				  list.remove(i--); //[a, c, d] //通过索引删除元素 
    				  } 
    		  }*/
    		 
    			//2,迭代器删除
    		/*Iterator<String> it = list.iterator();
    			while(it.hasNext()) {
    				if("b".equals(it.next())) {
    					//list.remove("b");			//不能用集合的删除方法,因为迭代过程中如果集合修改会出现并发修改异常java.util.ConcurrentModificationException
    					it.remove();  //[a, c, d]
    				}
    			}*/
    			
    			/*也可改用for循环
    			  for(Iterator<String> it2 = list.iterator(); it2.hasNext();) {
    				if("b".equals(it2.next())) {
    					//list.remove("b");							//不能用集合的删除方法,因为迭代过程中如果集合修改会出现并发修改异常
    					it2.remove();
    				}
    			}*/
    		// 3,增强for循环,增强for循环不能删除,只能遍历//java.util.ConcurrentModificationException
    				for (String string : list) {
    					if("b".equals(string)) {
    						list.remove("b");
    					}
    				}
    		System.out.println(list);
    	}
    }
    

    静态导入的概述和使用

    • A:静态导入概述
    • B:格式:
      • import static 包名….类名.方法名;
      • 可以直接导入到方法的级别
    • C:注意事项
      • 方法必须是静态的,如果有多个同名的静态方法,容易不知道使用谁?
        这个时候要使用,必须加前缀。由此可见,意义不大,所以一般不用,但是要能看懂。
    package com.hwh.jdk5;
    public class Demo3_ChangeableArgs {
    	public static void main(String[] args) {
    				int[] arr = {11,22,33,44,55};
    				//print(arr);//11 22 33 44 55
    				print(11,22,33,44,55);//22 33 44 55
    				System.out.println("---------------");
    				//print(); 输出空
    			}
    			
    			/*public static void print(int[] arr) {
    				for (int i = 0; i < arr.length; i++) {
    					System.out.println(arr[i]);
    				}
    			}*/
    			
    			public static void print(int x, int ... arr) {	//可变参数其实是一个数组, 可变参数肯定是最后一个
    				for (int i = 0; i < arr.length; i++) {
    					System.out.println(arr[i]);
    				}
    			}
    		}
    

    Arrays工具类的asList()方法的使用

    • A:案例演示
      • Arrays工具类的asList()方法的使用
      • Collection中toArray(T[] a)泛型版的集合转数组
    package com.hwh.jdk5;
    import java.util.ArrayList;
    import java.util.Arrays;
    import java.util.List;
    public class Demo4_AsList {
    	public static void main(String[] args) {
    			/**
    			 * 数组转换成集合
    			 * 数组转换成集合虽然不能增加或减少元素,但是可以用集合的思想操作数组,也就是说可以使用其他集合中的方法
    			 */
    
    				//demo1();
    				//demo2();
    				//集合转数组,加泛型的
    				ArrayList<String> list = new ArrayList<>();
    				list.add("a");
    				list.add("b");
    				list.add("c");
    				list.add("d");
    				
    				String[] arr = list.toArray(new String[10]);		//当集合转换数组时,数组长度如果是小于等于集合的size时,转换后的数组长度等于集合的size
    																	//如果数组的长度大于了size,分配的数组长度就和你指定的长度一样
    				for (String string : arr) {
    					System.out.println(string);//a b c d null null null null null null
    				}
    			}
    
    			public static void demo2() {
    				//int[] arr = {11,22,33,44,55};			
    				//List<int[]> list = Arrays.asList(arr);			//基本数据类型的数组转换成集合,会将整个数组当作一个对象转换
    				//System.out.println(list);//[[I@15db9742]
    				Integer[] arr = {11,22,33,44,55};					//将数组转换成集合,数组必须是引用数据类型
    				List<Integer> list = Arrays.asList(arr);
    				System.out.println(list);//[11, 22, 33, 44, 55]
    			}
    
    			public static void demo1() {
    				String[] arr = {"a","b","c"};
    				List<String> list = Arrays.asList(arr);				//将数组转换成集合
    				//list.add("d");					//java.lang.UnsupportedOperationException				//不能添加
    				System.out.println(list);//[a, b, c]
    			}
    		}
    

    集合嵌套之ArrayList嵌套ArrayList

    package com.hwh.list;
    import java.util.ArrayList;
    import com.hwh.bean.Person;
    public class Demo5_ArrayListArrayList {
    	public static void main(String[] args) {
    			/**
    			 * * 案例演示
    			 * 集合嵌套之ArrayList嵌套ArrayList
    			 * 案例:
    			 * 我们学科,学科又分为若个班级
    			 * 整个学科一个大集合
    			 * 若干个班级分为每一个小集合
    			 */
    
    				ArrayList<ArrayList<Person>> list = new ArrayList<>();
    				
    				ArrayList<Person> first = new ArrayList<>();				//创建第一个班级
    				first.add(new Person("杨幂", 30));
    				first.add(new Person("李冰冰", 33));
    				first.add(new Person("范冰冰", 20));
    				
    				ArrayList<Person> second = new ArrayList<>();
    				second.add(new Person("黄晓明", 31));
    				second.add(new Person("赵薇", 33));
    				second.add(new Person("陈坤", 32));
    				
    				//将班级添加到学科集合中
    				list.add(first);
    				list.add(second);
    				
    				//遍历学科集合
    				for(ArrayList<Person> a : list) {
    					for(Person p : a) {
    						System.out.println(p);
    					}
    				}
    			}
    		}
    
  • 相关阅读:
    全栈程工程师
    月薪8000的程序员和月薪2万的程序员差别在哪里?
    原型中的访问
    关于 基本类型和复合类型 用== 判断的小问题
    使用原型解决构造函数问题
    前端工程师学习路线 --书籍
    程序员成长之路
    GIT学习(1) Pull和Fetch
    OO面向对象编程:第四单元总结及课程总结
    OO面向对象编程:第三单元总结
  • 原文地址:https://www.cnblogs.com/albieh/p/12288777.html
Copyright © 2011-2022 走看看