当前位置: 首页 > wzjs >正文

网站描述作用注册公司需要几个人员

网站描述作用,注册公司需要几个人员,邯郸渊博网络有限公司,手工艺品外贸出口公司网站建设方案目录 一、Set集合1.Set集合特点2.Set集合分类3.hashSet底层原理:(基于哈希表存储数据的)代码演示 5.hashSet集合元素的去重操作(有些情况搞不动)代码演示 6.LinkedHashSet的底层原理(不常用,所以没有代码演…

目录

  • 一、Set集合
    • 1.Set集合特点
    • 2.Set集合分类
    • 3.hashSet底层原理:(基于哈希表存储数据的)
      • 代码演示
    • 5.hashSet集合元素的去重操作(有些情况搞不动)
      • 代码演示
    • 6.LinkedHashSet的底层原理(不常用,所以没有代码演示)
    • 7.TreeSet的底层原理
      • 代码演示

一、Set集合

1.Set集合特点

无序:添加数据的顺序和获取出的数据顺序不一致;不重复;不索引。

2.Set集合分类

  • Hashset:无序、不重复、无索引
  • LinkedHashSet:有序、不重复、无索引
  • TreeSet:排序(从小到大派、不重复、无索引

注意:Set常用到的方法,基本上就是Collection提供的,自己几乎没有额外新增一些常用功能。

3.hashSet底层原理:(基于哈希表存储数据的)

(1)哈希值:就是一个int类型的随机值,java中每个对象都有一个哈希值。java中的所有对象,都可以调用Object类提供的hashCode方法,返回该对象的哈希值。
格式:

public  int hashCode():

(2)对象哈希值的特点:

  • 同一个对象多次调用hashCode()方法返回的哈希值是相同的。
  • 不同的对象,它们的哈希值大概率不相等,但也有可能会相等(哈希碰撞).

(3)哈希表:

  • JDK8之前:哈希表=数组+链表
  • JDK8开始:哈希表=数组+链表+红黑树
  • 哈希表是一种增删改查数据,性能都比较好的数据结构。

(4)过程:(jDK8之前)

  • 1.使用HashSet创建一个默认长度为16的数组,默认加载因子为0.75,数组名table。(注意:ArrayList创建的长度是10)
  • 2.使用元素的哈希值对数组的长度做运算计算出应存入的位置。
  • 3.判断当前位置是否为null,如果是null直接存入
  • 4.如果不为null,表示有元素,则调用equals方法比较,相等,不存;不相等,存入;
  • 注意:JDK8之前,新元素存入数组,占老元素位置,老元素挂下面;JDK8之后,新元素直接挂在老元素下面。
  • 5.如果存入的数据超过16*0.75,就会扩容为原来的2倍。
  • JDK8之后,当链表长度超过8,且数组长度》=64时,自动将链表转成红黑树。

红黑树:就是可以自平衡的二叉树,红黑树是一种增删改查数据性能相对较好的结构。

代码演示

package com.item.demo1hashset;import java.util.*;
public class SetDemo1 {public static void main(String[] args) {Set<String> set =new HashSet<>();//一行经典的代码set.add("java");set.add("java");set.add("鸿蒙");set.add("鸿蒙");set.add("电商设计");set.add("电商设计");set.add("新媒体");set.add("大数据");System.out.println(set);//[java, 新媒体, 鸿蒙, 电商设计, 大数据]System.out.println("============");Set<String> set1 =new LinkedHashSet<>();set1.add("java");set1.add("java");set1.add("鸿蒙");set1.add("鸿蒙");set1.add("电商设计");set1.add("电商设计");set1.add("新媒体");set1.add("大数据");System.out.println(set1);//[java, 鸿蒙, 电商设计, 新媒体, 大数据]System.out.println("============");Set<Double> set2 =new TreeSet<>();//一行经典的代码set2.add(5.1);set2.add(5.1);set2.add(1.0);set2.add(2.0);set2.add(1.0);set2.add(3.0);set2.add(2.0);set2.add(5.4);System.out.println(set2);//[1.0, 2.0, 3.0, 5.1, 5.4]System.out.println("=============");String s1="acd";String s2="abc";System.out.println(s1.hashCode());//96386System.out.println(s1.hashCode());//96386System.out.println(s2.hashCode());//96354System.out.println(s2.hashCode());//96354}
}

5.hashSet集合元素的去重操作(有些情况搞不动)

需求:
创建一个存储学生对象的集合,存储多个学生对象,要求:多个学生对象的成员变量值相同时,我们就认为是同一个对象,要求只保留一个。
分析:
1.定义学生类,创建HashSet集合对象,创建学生对象。
2.把学生添加到集合。
结论:如果希望Set集合认为2个内容一样的对象是重复的,必须重写对象的hashCode()和equals()方法

代码演示

主类代码:

package com.item.demo1hashset;
import java.util.*;
public class SetDemo2 {public static void main(String[] args) {Student s1 = new Student("小王", 18, "北京", "123456");Student s2 = new Student("小李", 19, "北京", "987654");Student s3 = new Student("小王", 18, "北京", "123456");Student s4 = new Student("小李", 189, "北京", "987654");Set<Student> set = new HashSet<Student>();set.add(s1);set.add(s2);set.add(s3);set.add(s4);System.out.println(set);//在没有写equals和hashcode方法时,没有去重!!!,因为这些在java里面每次创建一个新的对象,则地址不一样,存入也不一样。}
}

Student类代码:

package com.item.demo1hashset;import java.util.Objects;public class Student {private String name;private int age;private String address;private String phone;public Student() {}public Student(String name, int age, String address, String phone) {this.name = name;this.age = age;this.address = address;this.phone = phone;}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 String getAddress() {return address;}public void setAddress(String address) {this.address = address;}public String getPhone() {return phone;}public void setPhone(String phone) {this.phone = phone;}//这里写入equals和hashCode方法@Overridepublic boolean equals(Object o) {//1.如果自己和自己比返回trueif (this == o) return true;//2.如果o为空或者o不是Student类型返回falseif (o == null || getClass() != o.getClass()) return false;//3.将o转换成Student类型Student student = (Student) o;//4.比较属性是否相同return age == student.age && Objects.equals(name, student.name) && Objects.equals(address, student.address) && Objects.equals(phone, student.phone);}@Overridepublic int hashCode() {return Objects.hash(name, age, address, phone);}@Overridepublic String toString() {return "Student{" +"name='" + name + '\'' +", age=" + age +", address='" + address + '\'' +", phone='" + phone + '\'' +'}'+"\n";}
}

6.LinkedHashSet的底层原理(不常用,所以没有代码演示)

依然是基于哈希表(数组、链表、红黑树)实现的。
但是,它的每个元素都额外的多了一个双链表的机制记录它前后元素的位置。

7.TreeSet的底层原理

基于红黑树实现的排序
注意:
1.对于数值类型:Integer,Double,默认按照数值本身的大小进行升序排序
2.对于字符串类型,默认按照首字符的编号升序排序
3.对于自定义类型如Student对象,TreeSet默认是无法直接排序的。
解决方法:
1.对象类实现一个Comparable比较接口,重写compare方法,指定大小比较规则。
2.public TreeSet(Comparator c)集合自带比较器Comparator对象,指定比较规则。

代码演示

主类代码:

package com.item.demo1hashset;import java.util.*;
public class SetDemo3 {public static void main(String[] args){Set<Teacher> teachers1=new TreeSet<>();teachers1.add(new Teacher("小王", 18,3245.2));teachers1.add(new Teacher("小李", 19,3345.3));teachers1.add(new Teacher("小孙", 20,3609.4));teachers1.add(new Teacher("小张", 18,2780.3));System.out.println(teachers1);//不修改就无法去重//解决方法2:Set<Teacher> teachers=new TreeSet<>(new Comparator<Teacher>() {@Overridepublic int compare(Teacher o1, Teacher o2) {return Double.compare(o2.getSalary(), o1.getSalary());//降序}});//继续简化//Set<Teacher> teachers=new TreeSet<>((o1, o2)->Double.compare(o2.getSalary(), o1.getSalary()));teachers.add(new Teacher("小王", 18,3245.2));teachers.add(new Teacher("小李", 19,3345.3));teachers.add(new Teacher("小孙", 20,3609.4));teachers.add(new Teacher("小张", 18,2780.3));System.out.println(teachers);//解决方法//1,对象类实现一个Comparable比较接口,重写compare方法,指定大小比较规则。//2.public TreeSet(Comparator c)集合自带比较器Comparator对象,指定比较规则。//解决方法2:Set<Teacher> teachers2=new TreeSet<>();teachers2.add(new Teacher("小王", 18,3245.2));teachers2.add(new Teacher("小李", 19,3345.3));teachers2.add(new Teacher("小孙", 20,3609.4));teachers2.add(new Teacher("小张", 18,2780.3));System.out.println(teachers);}
}

Teacher类代码:

package com.item.demo1hashset;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
@Data
@NoArgsConstructor
@AllArgsConstructor
public class Teacher implements Comparable<Teacher>{private String name;private int age;private double salary;@Overridepublic String toString() {return "Teacher{" +"name='" + name + '\'' +", age=" + age +", salary=" + salary +'}'+"\n";}//解决方法1:重写方法,比较两个对象的大小@Overridepublic int compareTo(Teacher o) {//按照年龄升序return this.getAge()-o.getAge();}
}

文章转载自:

http://A8hPSU1L.Lfdmf.cn
http://DiBqfMDD.Lfdmf.cn
http://bYs6zuqr.Lfdmf.cn
http://urNLYhvx.Lfdmf.cn
http://9zAjwG4T.Lfdmf.cn
http://Kb6uUFH3.Lfdmf.cn
http://WBIccCHn.Lfdmf.cn
http://s2VhO9e3.Lfdmf.cn
http://naCUxT9H.Lfdmf.cn
http://dBnhyJyX.Lfdmf.cn
http://9maoTGMZ.Lfdmf.cn
http://SnYD5W2d.Lfdmf.cn
http://ttbJnJ8W.Lfdmf.cn
http://GFDe1fRm.Lfdmf.cn
http://OHMSm8BI.Lfdmf.cn
http://TTbdjfON.Lfdmf.cn
http://YZWypD1I.Lfdmf.cn
http://ZRT9MWps.Lfdmf.cn
http://8DTS5sFQ.Lfdmf.cn
http://46RzBD8B.Lfdmf.cn
http://4h1NRmhq.Lfdmf.cn
http://C73nCLR5.Lfdmf.cn
http://touIhtlR.Lfdmf.cn
http://kbnPL6rs.Lfdmf.cn
http://9KJTQ46T.Lfdmf.cn
http://NzrVvyMx.Lfdmf.cn
http://sy8U5vdp.Lfdmf.cn
http://fHwOjhCL.Lfdmf.cn
http://XGttUFFb.Lfdmf.cn
http://17Gdy9jL.Lfdmf.cn
http://www.dtcms.com/wzjs/688419.html

相关文章:

  • 深圳网站设计廊坊公司哪个搜索引擎最好
  • 自建站推广html电影网站模板下载
  • 用asp做网站优势wordpress 附件id
  • 某网站seo诊断分析和优化方案wordpress自定义搜索
  • 做深度的互联网站seo网站建设
  • 如何建设大型电子商务网站网站建设及推广外包
  • 联系方式 响应式网站汽车网站建设论坛
  • 购物网站制作怎么做培训课程设计
  • 网站建设项目的工作分解手机前端开发软件工具
  • 人才网站开发方案建设专业网站运营团队
  • 正品手表网站wordpress导航字体大小
  • 网站建设顾问英语公司 网站 苏州
  • 网站建设公司浙江山东建设厅网站是什么
  • 网站怎么做能赚钱吗电子商城网站建议书
  • 玩具网站建设服务公司如何查注册商标是别人注册过的
  • 怎么在ppt上做网站百度问一问官网
  • 丹阳做网站的yy直播间
  • 昆明网站建设方案外包毕业设计做系统网站好
  • 网站设计考虑因素打开自己的网站是别人的域
  • 上海网站制作培训百度招聘2022年最新招聘
  • 南宁做棋牌网站的公司国内最好的crm软件
  • 做关于车的网站好wordpress自定义json
  • 做本地化的返利网站怎么样网站服务器查询工具
  • wordpress子站点用户无角色网站的优势
  • 小型网站建设公司优化专业的公司
  • 广州力科网站建设公司阿里云怎么建网站
  • 免费网站源码建站系统番禺建设银行网站首页
  • 网站开发人员周报网站轮播效果怎么做的
  • 国外网站国内备案建设一个网站要多少费用
  • 网站设计样式创建网站要申请域名吗