javaSE - 007 - 集合

集合:

  • 集合中只能放对象的引用,对于原生数据类型,会自动拆包和打包

1.List接口的2个实现类

  • ArrayList 实现原理是一个数组,可以打开源码看看,内容就是所添加对象的一个引用
  • LinkedList 实现原理是一个双向链表,添加对象是真正添加对象经过包装后(Entry对象),有前置引用和后置引用

2.Map

  • HashMap

3.Set(不可重复,无顺序的集合)

  • HashSet 是实现Set接口的一个主要类,里面是没有顺序的
  • TreeSet 也是Set接口的实现类,这个set是可以排序的

hash code 和 equals

纯属臆测。如下:
1.hash code能很快找到内存物理地址,(好像有个hash表维护着)
2.不同的对象,可能有相同的hashcode,但是不同的hashcode一定是不同的2个对象
3.根据第二条,就能推断出比较equals,首先得具有相同的hashcode(更直白的说:扎堆,人跟人站一起,大象跟大象站一起。然后用equals来比较适否完全相等...当比较2个对象的时候,就可以用hashcode扎堆,然后用equals比较)
4.重写equals须重写hashCode的说法,如果只重写equals(实实在在比较想等的),不重写hashcode(相当于过滤,大象只跟大象堆里的比较),很容易造成短路


public class test {
 public static void main(String[] args) {
  Set<A> s = new HashSet<A>();
  A a1= new A("liyang","26");
  A a2= new A("liyang","21");
  A a3= new A("liyang","22");
  A a4= new A("liyang","23");
  A a5= new A("liyang","26");
  
  s.add(a1);
  s.add(a2);
  s.add(a3);
  s.add(a4);
  s.add(a5);
  
  System.out.println(s);
  
      
 }

}
class A{
 String name ;
 String age;
 A(String name, String age){
  this.name = name;
  this.age = age;
 }
 @Override
 public int hashCode() {
  System.out.println(this.name + " hashcode " + this.age);
  return this .age.hashCode();
 }
 @Override
 public boolean equals(Object obj) {
  System.out.println(this.name + " equals " + this.age);
  A other = (A) obj;
  return other.name.equals(this.name);
 } 
}
输出结果:
liyang hashcode 26
liyang hashcode 21
liyang hashcode 22
liyang hashcode 23
liyang hashcode 26
liyang equals 26
以下是  System.out.println(s);造成的
liyang hashcode 22
liyang hashcode 23
liyang hashcode 26
liyang hashcode 21
[javaSEtest.A@640, javaSEtest.A@641, javaSEtest.A@644, javaSEtest.A@63f]
总结:本来equals只用了“liyang”字符串做比较,且完全相同,但是我们用hashcode是有年龄产生的,造成了短路,根本不会走equals方法,除了年龄相同的

集合迭代

Set<String> s = **new** HashSet<String>();
  s.add("liyang");
  s.add("liyang1");
  s.add("liyang2");
  s.add("liyang3");
  s.add("liyang4");
  
  Iterator i = s.iterator();
  while (i.hasNext()){
   System.out.println(i.next());
  }
 }

Comparable接口


public class test {
 public static void main(String[] args) {
  Set<Person> s = new TreeSet<Person>();
  s.add(new Person(12));
  s.add(new Person(13));
  s.add(new Person(14));
  s.add(new Person(1));
  s.add(new Person(123));
  Iterator i = s.iterator();
  while (i.hasNext()) {
   System.out.println(i.next());
  }
 }
}
class Person implements Comparable {
 int score;
 Person(int score){
  this.score = score;
 }
 @Override
 public int compareTo(Object o) {
  Person p = (Person) o;
  if (this.score > p.score) {
   return 1;
  } else if (this.score == p.score) {
   return 0;
  } else {
   return -1;
  }
 }
 public String toString(){
  return ""+this.score;
 }
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,686评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,668评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,160评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,736评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,847评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,043评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,129评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,872评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,318评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,645评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,777评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,470评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,126评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,861评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,095评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,589评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,687评论 2 351

推荐阅读更多精彩内容

  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,602评论 18 399
  • 本文出自 Eddy Wiki ,转载请注明出处:http://eddy.wiki/interview-java.h...
    eddy_wiki阅读 1,156评论 0 16
  • java笔记第一天 == 和 equals ==比较的比较的是两个变量的值是否相等,对于引用型变量表示的是两个变量...
    jmychou阅读 1,490评论 0 3
  • Java8张图 11、字符串不变性 12、equals()方法、hashCode()方法的区别 13、...
    Miley_MOJIE阅读 3,697评论 0 11
  • 今宵冷雪上新寒,残照孤灯瘦影单。 闻得北风帘外啸,飞花点点泼天漫。 (平水韵上平十四寒) ​​​
    Odette伊菲阅读 395评论 2 10