/**
* 1
* @hashCode&equals的处理:
* 1-只要覆写了equals,必须复写hashCode.
* 2-因为Set存储的是不重复的对象,依据hashCode和equals进行判断,所以Set存储的对象必须覆写这两个方法
* 3-如果自定义对象作为Map的键,那么必须覆写hashCode和equals
* @注意:String因为覆写了hashCode和equals方法,所以可以直接作为key使用
*/
public class day1019 {
public static void main(String[] args) {
Map<Item1,String> hashmap = new HashMap<Item1, String>();
hashmap.put(new Item1("f1","f2"),"it1");
hashmap.put(new Item1("f1","f2"),"it1");
/**
* hashMap使用put方法之前会调用hash方法取获取key的hashCode值,
* 然后根据hash方法返回的boolean值来决定put操作
*/
System.out.println(hashmap.size());//没有继承equals和hashcode的时候是2
//继承之后是1
}
} class Item1{
private String field1;
private String field2; public Item1(String field1, String field2) {
this.field1 = field1;
this.field2 = field2;
} public String getField1() {
return field1;
} public void setField1(String field1) {
this.field1 = field1;
} public String getField2() {
return field2;
} public void setField2(String field2) {
this.field2 = field2;
} /**
* 按照默认的重载equals和hashcode
* @param o
* @return
*/
@Override
public boolean equals(Object o) {
if (this == o) return true;
if (o == null || getClass() != o.getClass()) return false; Item1 item1 = (Item1) o;
/**
* 还比较了里面属性的值是否一致
*/
if (field1 != null ? !field1.equals(item1.field1) : item1.field1 != null) return false;
return field2 != null ? field2.equals(item1.field2) : item1.field2 == null;
} @Override
public int hashCode() {
int result = field1 != null ? field1.hashCode() : 0;
result = 31 * result + (field2 != null ? field2.hashCode() : 0);
return result;
}
}
public class SetLearning {

    public static void main(String[] args) {
/**2
* 判断所有集合内部的元素是否为空,使用isEmpty()方法,而不使用size() = 0;
* 原因:某些集合,前者的复杂度为O(1)
*/
Map<String ,String> stringMap = new HashMap<>();
if (stringMap.isEmpty()){
System.out.println("no element");
} /**3
* 使用java.util.stream.Collectors类的toMap()方法转为Map集合时
* 一定要使用含参数类型为BinaryOperator,参数名为mergeFunction的方法,
* 否则当出现相同key值时会抛出IllegalStateException异常
*/ /**4
* 使用java.util.stream.Collectors类的toMap()方法转为Map集合时
* 当value为null时会抛NPE异常
*/
}
}
/**5
* ArrayList的subList结果不可强转为ArrayList,否则抛异常ClassCastException;
* @注意:sublist()返回的是ArrayList内部类Sublist,并不是ArrayList本身,而是一个视图
*/
public class day10191 {
public static void main(String[] args) {
List<String> arrayList = new ArrayList<String>();
arrayList.add("1");
arrayList.add("2");
arrayList.add("3");
arrayList.add("4");
System.out.println(arrayList);
try{
ArrayList<String> a = (ArrayList<String>) arrayList.subList(0,2);
}catch (Exception e){
System.out.println(e.getMessage());
}
List<String> list = arrayList.subList(0,2);
System.out.println(arrayList);
System.out.println(list);
}
/**
* re:
* [1, 2, 3, 4]
* java.util.ArrayList$SubList cannot be cast to java.util.ArrayList
* [1, 2, 3, 4]
* [1, 2]
*/
}
/**
*14
* 不要再foreach循环进行元素的remove和add操作,
* @remove元素使用Iterator方式
* 如果并发操作,需要对Iterator对象加锁
*/
public class day10193 {
public static void main(String[] args) {
List<String> list = new ArrayList<String>();
list.add("x");
list.add("x");
list.add("y");
list.add("y");
list.add("z");
list.add("z");
// for (int i = 0; i < list.size(); i++) {
// String s = list.get(i);
// if (s.equals("z")){
// list.remove(s);//执行这个的时候,其实list的长度会变化,元素会前移
// }
// }
System.out.println(list);//[x, x, y, y, z]
// 正确的方法:
Iterator<String> iterator = list.iterator();
while (iterator.hasNext()){
String next = iterator.next();
if (next.equals("z")){
iterator.remove();
}
}
System.out.println(list); }
}

java-规约-集合的更多相关文章

  1. 【Java】集合_学习笔记

    一.集合 1.集合类也称容器类,主要负责保存.盛装其他数据. 2.集合可以保存数量不确定的数据,保存具有映射关系的数据(也称关联数组). 3.Java5后提供一些多线程安全的集合类,放在java.ut ...

  2. java的集合框架最全详解

    java的集合框架最全详解(图) 前言:数据结构对程序设计有着深远的影响,在面向过程的C语言中,数据库结构用struct来描述,而在面向对象的编程中,数据结构是用类来描述的,并且包含有对该数据结构操作 ...

  3. 谈谈Java的集合组件

    让我们一起谈谈Java的集合组件 我们在使用Java的时候,都会遇到并使用到Java的集合.在这里通过自己的理解和网上的资源对Java的集合方面的使用做一个简单的讲解和总结. Java主要分为3个集合 ...

  4. java.util 集合框架集合

    java的集合框架为程序提供了一种处理对象组的标准方式.设计了一系列标准泛型接口: ⑴Collection ()接口,扩展了Iterable接口,位于集合层次结构的顶部,因此所有的集合都实现Colle ...

  5. Java基础——集合框架

    Java的集合框架是Java中很重要的一环,Java平台提供了一个全新的集合框架.“集合框架”主要由一组用来操作对象的接口组成.不同接口描述一组不同数据类型.Java平台的完整集合框架如下图所示: 上 ...

  6. Java学习-集合(转)

    在编写java程序中,我们最常用的除了八种基本数据类型,String对象外还有一个集合类,在我们的的程序中到处充斥着集合类的身影!java中集合大家族的成员实在是太丰富了,有常用的ArrayList. ...

  7. java的集合框架之一

    java是一套很成熟的东西,很多商用的东西都喜欢用它,用的人多,稳定.不过一般也不怎么说起它,因为太常见了,私下里说,写java应用层得就像农民工,每一处都是搭积木,根据设计师的东西如何优雅地搭好积木 ...

  8. 浅谈Java的集合框架

    浅谈Java的集合框架 一.    初识集合 重所周知,Java有四大集合框架群,Set.List.Queue和Map.四种集合的关注点不同,Set 关注事物的唯一性,List 关注事物的索引列表,Q ...

  9. Java之集合初探(一)

    一.集合概述.区别 集合是一种容器,数组也是一种容器 在Java编程中,装各种各样的对象(引用类型)的叫做容器. 为什么出现集合类? 面向对象语言对事物的体现都是以对象的形式,所以为了方便对多个对象的 ...

  10. Java面向对象 集合(下)

      Java面向对象 集合(下) 知识概要:               (1)Map集合的体系结构 (2)Map集合的方法 (3)HashMap TreeMap (4)集合框架中的常用工具类 ( ...

随机推荐

  1. Python 中 selenium 库

    目录 selenium 基础语法 一. 环境配置 1. 安装环境 2. 配置参数 3. 常用参数搭配 4. 分浏览器启动 二. 基本语法 1. 元素定位 2. 控制浏览器操作 3. 操作元素的方法 3 ...

  2. 从这3个方面考虑BI工具,选型一选一个准

    BI工具在很多场合都能听到,那么BI工具有什么功能呢?能给企业带来什么?好用的BI工具长什么样?今天跟着小编走近BI工具,一探究竟! 首先要了解BI工具的定义,什么是BI工具.BI工具是指利用现代数据 ...

  3. C++的两种实例化方式

    C++中,类有两种实例化方式.一种是有new关键字,一种没有new关键字.那么,这两种实例化方式有什么区别呢? A a;//(1) a存在于栈上 A* a = new A();//(2) a存在于堆中 ...

  4. 执行上下文与同步上下文 | ExecutionContext 和 SynchronizationContext

    原文连接:执行上下文与同步上下文 - .NET 并行编程 (microsoft.com) 执行上下文与同步上下文 斯蒂芬 6月15日, 2012 最近,我被问了几次关于 ExecutionContex ...

  5. WPF中TreeView控件SelectedItemChanged方法的MVVM绑定

    问题描述:左侧treeview控件中点击不同类别的节点时,右侧的页面会显示不同的权限.比如对于My Publications,拥有Modify和Delete两种权限,对于My Subscription ...

  6. mysql集群--基于centos7

    1 MySQL主从备份 主机:192.168.43.8 从机:192.168.43.6 条件:主机和从机都安装了mysql,开启了二进制日志 安装mysql (mysql 和 mysql-server ...

  7. Codeforces Round #750 (Div. 2) E. Pchelyonok and Segments

    传送门 题目大意: 给一个序列,可以在这个序列中从左至右选若干个段,第i段的长度为i,对于任意的段i,段内元素和S[i]<S[i+1],求在该序列中最多可以选出几段. 思路:设dp[i][j]为 ...

  8. c语言刷lleetcode记录

    155. 最小栈 笔记: 在push(压栈)的时候思路: typedef struct MinStack{ int data; struct MinStack *next; } MinStack; / ...

  9. pandas模块篇(终章)及初识mataplotlib

    今日内容概要 时间序列 针对表格数据的分组与聚合操作 其他函数补充(apply) 练习题(为了加深对DataFrame操作的印象) mataplotlib画图模块 今日内容详细 时间序列处理 时间序列 ...

  10. FaE:基于符号知识的适应性和可解释的神经记忆

    原创作者 | 朱林 论文解读: Facts as Experts: Adaptable and Interpretable Neural Memory over Symbolic Knowledge ...