package exer;
import org.junit.Test;
import java.util.ArrayList;
import java.util.HashSet;
import java.util.List;
/**
*
*
* @create 2022-04-05 16:32
*/
public class CollectionTest {
//练习:在List内去除重复数字值,要求尽量简单
public static List duplicateList(List list){
HashSet set=new HashSet();
set.addAll(list);
return new ArrayList(set);
}
@Test
public void test2(){
List list=new ArrayList();
list.add(new Integer(1));
list.add(new Integer(2));
list.add(new Integer(2));
list.add(new Integer(3));
list.add(new Integer(3));
List list2=duplicateList(list);
for(Object integer:list2){
System.out.println(integer);
}
}
@Test
public void test3(){
HashSet set=new HashSet();
Person p1=new Person(1001,"AA");
Person p2=new Person(1002,"BB");
set.add(p1);
set.add(p2);
System.out.println(set);
p1.name="CC";
set.remove(p1);
System.out.println(set);
set.add(new Person(1001,"CC"));
System.out.println(set);
set.add(new Person(1001,"AA"));
System.out.println(set);
}
}
package exer;
/**
*
*
* @create 2022-04-05 16:48
*/
public class Person {
int id;
String name;
public Person(int id, String name) {
this.id = id;
this.name = name;
}
public Person() {
}
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
@Override
public String toString() {
return "exer.Person{" +
"id=" + id +
", name='" + name + '\'' +
'}';
}
@Override
public boolean equals(Object o) {
if (this == o) return true;
if (o == null || getClass() != o.getClass()) return false;
Person person = (Person) o;
if (id != person.id) return false;
return name != null ? name.equals(person.name) : person.name == null;
}
@Override
public int hashCode() {
int result = id;
result = 31 * result + (name != null ? name.hashCode() : 0);
return result;
}
}
package exer1;
/**
*MyDate类包含:
private成员变量year,month,day;并为每一个属性定义 getter, setter 方法;
*
* @create 2022-04-05 16:57
*/
public class MyDate implements Comparable{
private int year;
private int month;
private int day;
public MyDate(int year, int month, int day) {
this.year = year;
this.month = month;
this.day = day;
}
public MyDate() {
}
public int getYear() {
return year;
}
public void setYear(int year) {
this.year = year;
}
public int getMonth() {
return month;
}
public void setMonth(int month) {
this.month = month;
}
public int getDay() {
return day;
}
public void setDay(int day) {
this.day = day;
}
@Override
public String toString() {
return "MyDate{" +
"year=" + year +
", month=" + month +
", day=" + day +
'}';
}
@Override
public int compareTo(Object o) {
if(o instanceof MyDate){
MyDate m=(MyDate)o;
//比较年
int minusYear=this.getYear()- m.getYear();
if(minusYear != 0){
return minusYear;
}
//比较月
int minusMonth=this.getMonth()-m.getMonth();
if(minusMonth!=0){
return minusMonth;
}
//比较日
int minusDay=this.getDay()-m.getDay();
return minusDay;
}
throw new RuntimeException("传入的数据类型不一致!");
}
}
package exer1;
/**
* 定义一个Employee类。
该类包含:private成员变量name,age,birthday,其中 birthday 为 MyDate 类的对象;
并为每一个属性定义 getter, setter 方法;
并重写 toString 方法输出 name, age, birthday
*
* @create 2022-04-05 17:17
*/
public class Employee implements Comparable{
private String name;
private int age;
private MyDate birthday;
public Employee() {
}
public Employee(String name, int age, MyDate birthday) {
this.name = name;
this.age = age;
this.birthday = birthday;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
public MyDate getBirthday() {
return birthday;
}
public void setBirthday(MyDate birthday) {
this.birthday = birthday;
}
@Override
public String toString() {
return "Employee{" +
"name='" + name + '\'' +
", age=" + age +
", birthday=" + birthday +
'}';
}
//按name排序
@Override
public int compareTo(Object o) {
if(o instanceof Employee){
Employee e=(Employee)o;
return this.name.compareTo(e.name);
}
throw new RuntimeException("传入的数据类型不一致!");
}
}
package exer1;
import org.junit.Test;
import java.util.Comparator;
import java.util.Iterator;
import java.util.TreeSet;
/**
*
* * 创建该类的 5 个对象,并把这些对象放入 TreeSet 集合中
分别按以下两种方式对集合中的元素进行排序,并遍历输出:
1). 使Employee 实现 Comparable 接口,并按 name 排序
2). 创建 TreeSet 时传入 Comparator对象,按生日日期的先后排序。
* @create 2022-04-05 17:23
*/
public class EmployeeTest {
//问题二:按生日日期的先后排序
@Test
public void test2(){
TreeSet set=new TreeSet(new Comparator() {
@Override
public int compare(Object o1, Object o2) {
if(o1 instanceof Employee && o2 instanceof Employee) {
Employee e1 = (Employee) o1;
Employee e2 = (Employee) o2;
MyDate b1 = e1.getBirthday();
MyDate b2 = e2.getBirthday();
return b1.compareTo(b2);
}
throw new RuntimeException("出错啦!!!");
}
});
Employee e1 = new Employee("liudehua",55,new MyDate(1965,5,4));
Employee e2 = new Employee("zhangxueyou",43,new MyDate(1987,5,4));
Employee e3 = new Employee("guofucheng",44,new MyDate(1987,5,9));
Employee e4 = new Employee("liming",51,new MyDate(1954,8,12));
Employee e5 = new Employee("liangzhaowei",21,new MyDate(1978,12,4));
set.add(e1);
set.add(e2);
set.add(e3);
set.add(e4);
set.add(e5);
Iterator iterator=set.iterator();
while(iterator.hasNext()){
System.out.println(iterator.next());
}
}
//问题一:使用自然排序
@Test
public void test1(){
TreeSet set=new TreeSet();
Employee e1 = new Employee("liudehua",55,new MyDate(1965,5,4));
Employee e2 = new Employee("zhangxueyou",43,new MyDate(1987,5,4));
Employee e3 = new Employee("guofucheng",44,new MyDate(1987,5,9));
Employee e4 = new Employee("liming",51,new MyDate(1954,8,12));
Employee e5 = new Employee("liangchaowei",21,new MyDate(1978,12,4));
set.add(e1);
set.add(e2);
set.add(e3);
set.add(e4);
set.add(e5);
Iterator iterator=set.iterator();
while(iterator.hasNext()){
System.out.println(iterator.next());
}
}
}
package java0;
import org.junit.Test;
import java.util.*;
/**
* 一、map实现类的结构
* |-----Map:双列数据,存储key-value对的数据
* |-----HashMap:作为Map的主要实现类;线程不安全的,效率高;可以存储null的key和value
* |-----LinkedHashMap:保证在遍历map元素时,可以按照添加的顺序实现遍历
* 原因:在原有的HashMap底层结构基础上,添加了一对指针,指向前一个和后一个元素
* 对于频繁的遍历操作,此类执行效率高于HashMap
* |----TreeMap:保证按照添加的key-value对进行排序,实现排序遍历。此时考虑key的自然排序或定制排序
* 底层使用红黑树
* |-----Hashtable:作为古老的实现类:线程安全的,效率低;不能存储null的key和value
* |-----Properties:常用来处理配置文件。key和value都是String类型。
*
*
* HashMap的底层:数组+链表(jdk7及以前)
* 数组+链表+红黑树(jdk8)
*
* 二、map结构的理解
* Map中的key:无序的、不可重复的,使用set存储所有的key----》key所在的类要重写equals()和hashcode()
* Map中的value:无序的、可重复的,使用Collection存储所有的value ---》value所在的类要重写equals()
*
* 一个键值对:key-value构成了一个Entry对象。
* Map中的entry:无序的、不可重复的,使用Set存储所有的entry。
*
* 三、HashMap的底层实现原理?以jdk7为例说明:
*
* HashMap map=new HashMap();
* 在实例化以后,底层创建了长度是16的一维数组Entry[] table.
*
* ...可能已经执行过多次put...
* map.put(key1,value1);
* 首先,调用key1所在类的hashCode()计算key1哈希值,此哈希值经过某种算法计算以后,得到在Entry数组中的存放位置
* 如果此位置上的数据为空,此时的key1-value1添加成功。----情况1
* 如果此位置上的数据不为空(意味着此位置上存在一个或多个数据(以链表形式存在),比较key1和已经存在的一个或多个数据的哈希值
* 如果key1的哈希值和已经存在的数据的哈希值都不相同,此时key1-value1添加成功。---》情况2
* 如果key1的哈希值和已经存在的某一个数据(key2-value2)的哈希值相同,继续比较:调用key1所在类的equals()方法,比较:
* 如果equals()返回false,此时key1-value1添加成功。----情况3
* 如果equals()返回true,使用value1替换value2.
*
*
* 关于情况2和情况3,此时key1-value1和原来的数据以链表的方式存储。
*
* 在不断的添加过程中,会涉及到扩容问题,当超出临界值(且要存放的位置非空时),扩容.
* 默认的扩容方式:扩容为原来容量的2倍,并将原有的数据复制过来。
*
*
*
* jdk8相较于jdk7在底层实现方面的不同:
* 1. new HashMap():底层没有创建一个长度为16的数组。
* 2. jdk8底层的数组是:Node[],而非Entry[]
* 3. 首次调用put()方法时,底层创建长度为16的数组。
* 4. jdk7底层结构只有:数组+链表。
* jdk8中底层结构:数组+链表+红黑树
* 4.1 形成链表时,七上八下(jdk7:新的元素指向旧的元素。jdk8:旧的元素指向新的元素)
* 4.2 当数组的某一个索引位置上的元素以链表形式存在的数据个数 >8且当前数组的长度 >64时,
* 此时此索引位置上的数据改为使用红黑树存储。
*
* 五、map中定义的方法
* 添加、删除、修改操作:
* Object put(Object key,Object value):将指定key-value添加到(或修改)当前map对象中
* void putAll(Map m):将m中的所有key-value对存放到当前map中
* Object remove(Object key):移除指定key的key-value对,并返回value。
* void clear():清空当前map中的所有数据
* 元素查询的操作:
* Object get(Object key):获取指定key对应的value。
* boolean containsKey(Object key):是否包含指定的key
* boolean containsValue(Object value):是否包含指定的value
* int size():返回map中key-value的个数
* boolean isEmpty():判断当前map是否为空
* boolean equals(Object obj):判断当前map和参数对象obj是否相等。
*
* 元视图操作的方法:
* Set keySet():返回所有key构成的Set集合
* Collection values():返回所有value构成的Collection集合
* Set entrySet():返回所有key-value对构成的Set集合。
*
*
*
*
*
*
*
*
* @create 2022-04-06 10:24
*/
public class MapTest {
@Test
public void test1(){
Map map=new HashMap();
map.put(null,123);
}
@Test
public void test2(){
Map map=new HashMap();
map=new LinkedHashMap();
map.put(123,"AA");
map.put(345,"BB");
map.put(12,"CC");
System.out.println(map);
}
@Test
public void test3(){
Map map=new HashMap();
map.put("AA",123);
map.put(45,123);
map.put("BB",56);
map.put("AA",88);
System.out.println(map);
Map map1=new HashMap();
map1.put("CC",111);
map1.put("CD",123);
map.putAll(map1);
System.out.println(map);
Object value=map.remove("CC");
System.out.println(value);
System.out.println(map);
map.clear();
System.out.println(map.size());
System.out.println(map);
}
@Test
public void test4(){
Map map=new HashMap();
map.put("AA",123);
map.put(45,123);
map.put("BB",56);
System.out.println(map.get(45));
boolean isExit=map.containsKey("BB");
System.out.println(isExit);
isExit=map.containsValue(123);
System.out.println(isExit);
map.clear();
System.out.println(map.isEmpty());
}
@Test
public void test5(){
Map map = new HashMap();
map.put("zz",23);
map.put("AA",56);
map.put("BB",123);
map.put(45,1234);
// Set set=map.keySet();
Set set= map.keySet();
System.out.println(map);
Iterator iterator=set.iterator();
while(iterator.hasNext()){
System.out.println(iterator.next());
}
// LinkedHashSet set1=new LinkedHashSet();
// set1.addAll(set);
// Iterator iterator1=set1.iterator();
// while(iterator1.hasNext()){
// System.out.println(iterator1.next());
// }
Collection values=map.values();
for(Object obj: values){
System.out.println(obj);
}
System.out.println();
//遍历所有key-value
//方式一:entrySet()
Set entrySet=map.entrySet();
Iterator iterator1=entrySet.iterator();
while(iterator1.hasNext()){
Object obj=iterator1.next();
Map.Entry entry=(Map.Entry)obj;
System.out.println(entry.getKey()+"----"+entry.getValue());
}
System.out.println();
//方式二:
Set keySet=map.keySet();
Iterator iterator2=keySet.iterator();
while(iterator2.hasNext()){
Object key=iterator2.next();
Object value=map.get(key);
System.out.println(key+"---"+value);
}
}
}
package java0;
import org.junit.Test;
import java.util.*;
/**
*
*
* @create 2022-04-06 16:39
*/
public class TreeMapTest {
//向TreeMap中添加key-value,要求key必须是由同一个类创建的对象
//按照key排序
//自然排序
@Test
public void test1(){
TreeMap map=new TreeMap();
User u1=new User("aTom",23);
User u2=new User("bTom12",24);
User u3=new User("cTom13",25);
User u4=new User("dTom145",26);
map.put(u1,98);
map.put(u2,99);
map.put(u3,999);
map.put(u4,999999);
Set entrySet=map.entrySet();
Iterator iterator=entrySet.iterator();
while(iterator.hasNext()){
Object obj=iterator.next();
Map.Entry entry=(Map.Entry)obj;
System.out.println(entry.getKey()+"------"+entry.getValue());
}
}
@Test
public void test2(){
TreeMap map=new TreeMap(new Comparator() {
@Override
public int compare(Object o1, Object o2) {
if(o1 instanceof User && o2 instanceof User){
User u1=(User)o1;
User u2=(User)o2;
return Integer.compare(u1.getAge(),u2.getAge());
}
throw new RuntimeException("错误");
}
});
User u1 = new User("Tom",23);
User u2 = new User("Jerry",32);
User u3 = new User("Jack",20);
User u4 = new User("Rose",18);
map.put(u1,98);
map.put(u2,89);
map.put(u3,76);
map.put(u4,100);
Set entrySet=map.entrySet();
Iterator iterato1=entrySet.iterator();
while(iterato1.hasNext()){
Object obj=iterato1.next();
Map.Entry entry=(Map.Entry)obj;
System.out.println(entry.getKey()+"---"+entry.getValue());
}
}
}
package java0;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.util.Properties;
/**
* @author nkc
* @create 2022-04-07 22:45
*/
public class PropertiesTest {
public static void main(String[] args) {
FileInputStream fis=null;
try {
Properties pros = new Properties();
fis = new FileInputStream("jdbc.properties");
pros.load(fis);
String name=pros.getProperty("name");
String password=pros.getProperty("password");
System.out.println("name="+name+",password="+password);
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
} finally {
if(fis!=null){
try {
fis.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
}
}
package java0;
import org.junit.Test;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collections;
import java.util.List;
/**
*
*
*
* @create 2022-04-08 10:30
*/
public class CollectionTest {
@Test
public void test2(){
List list=new ArrayList();
list.add(123);
list.add(43);
list.add(765);
list.add(-97);
list.add(0);
List dest= Arrays.asList(new Object[list.size()]);
System.out.println(dest.size());
Collections.copy(dest,list);
System.out.println(dest);
/*
Collections 类中提供了多个 synchronizedXxx()方法,
该方法可使指定集合包装成线程同步的集合,从而可以解决多线程并发访问集合时的线程安全问题。
*/
//返回的list1即为线程安全的List
List list1=Collections.synchronizedList(list);
}
@Test
public void test1(){
List list=new ArrayList();
list.add(123);
list.add(43);
list.add(765);
list.add(765);
list.add(765);
list.add(-97);
list.add(0);
System.out.println(list);
// Collections.reverse(list);
// Collections.shuffle(list);
// Collections.sort(list);
// Collections.swap(list,1,2);
int frequency=Collections.frequency(list,765);
System.out.println(list);
System.out.println(frequency);
}
}