java集合基础_java常用集合基础知识

【纯出自个人笔记,如有错误,望改正,谢谢哈!

10e12d57ce6042798b6d9bdae3515ec4.gif学习~】

一、Java集合

1、集合类:容器类 装对象的(不能存放基本数据类型,但是里面看到的其实是包装类型)

java.util包

ArrayList底层是一个对象数组

--------------------------------------------------------------------------------------------

List中是可以存放重复元素的。Set是不能有重复元素.

Ⅰ:ArrayList:

a. 添加 :

add();里面可以存放字符串或者基本包装类型

ArrayList也可以存放布尔类型和对象

ArrayList list=new ArrayList();

list.add(1,"aa");这是指将aa字符串存放在arraylist集合索引的1位置(添加到指定位置);

list.size();是获取元素的个数,和数组的length,字符串的length()差不多。

list.add(list1);add里面还是可以放集合的

b.修改 :

list.set(0,200);这是修改指定位置的元素,这里是指修改了arraylist集合0索引的值该为200;集合的索引和数组的下标差不多。

c.获得 :

list.get(0);获得,这是获得list集合里的0索引处的值。它返回的类型是Object(Object obj=list.get(0);) 然后可以直接输出这s.o.p(obj);打印出来的就是list集合的元素

d.遍历集合:

用for循环也可以,但是集合List集合一般都用迭代器遍历集合(Iterator,下面介绍)

e.清空集合元素:

list.clear();清空掉集合中所有的元素,如果清空,输出就一对中括号“[]”表示集合里面没有元素了。o(∩_∩)o

f.移除/删除 集合中的元素:

remove();这是删除集合中的某个元素。比如list.remove(1);这就是删除掉集合中索引为1的元素(第二个),list.remove("aa");这是删除掉集合中的元素,就是如果集合中有aa的字符串,就删掉。  -----list.remove(new Integer(12));注意这种:要删除集合中的数值,就必须要这样(要指定包装类)否则删除的就是索引为12的元素,如果元素个数没有13个,那么就会出现 下标越界异常。

---------------------------------------------------------------------------------------

Ⅱ:LinkedList:ArrayList便于进行修改、获得值的操作  LinkedList便于进行增加和删除操作

a.添加元素:

LinkedList添加元素也是add();基本用法和ArrayList差不多。但是LinkedList多了2个功能:addFirst()和addLast();这2个,比如list.addFirst("asd");这是在集合的第一个位置放置asd的字符串;list.addLast("aa");这是在集合的最后一个位置放置aa字符串;

b.遍历:

和arraylist也是一样的。既可以用For循环遍历,也可以用迭代器遍历,推荐迭代器。 需要注意的是:在迭代器循环体内是不可以直接对集合进行添加删除操作的。

---------------------------------------------------------------------------------------------

Ⅲ:Stack类表示后进先出(LIFO)的对象堆栈(继承自Vector)。

a.添加元素

stack添加元素是用push()方法的,比如:s.push("aaa");这是指在statck中添加aaa元素压入栈中

b.移除元素:

s.pop();这是移除栈顶的元素  是栈顶

c.查看元素:

Syso(s.peek());查看栈顶的元素,表示只查看不剔除。

---------------------------------------------------------------------------------------------

Ⅳ:Vector  底层是对象数组,线程安全的(同步)

Vector非常类似ArrayList,但是Vector是同步的。由Vector创建的Iterator,虽然和ArrayList创建的 Iterator是同一接口,但是,因为Vector是同步的,当一个Iterator被创建而且正在被使用,另一个线程改变了Vector的状态(例如,添加或删除了一些元素),这时调用Iterator的方法时将抛出ConcurrentModificationException,因此必须捕获该异常。

---------------------------------------

以上是List 列表的知识点

===================================================================================

下面是Set 集的知识点回顾:

===================================================================================

Set   不能有重复的元素、没有索引

Ⅰ、HashSet

a.添加元素:

set.add("aa"); set.add(new Object());基本上也差不多

b.清除元素用的也是clear();

c.移除  remove()的用法

d,遍历HashSet: 注意,这里只能用迭代器(Iterator)遍历,因为Set集中是没有索引的,所以不能用for。

例如: Iterator it = set.iterator();

while(it.hasNext()){

Object temp = it.next();

System.out.println(temp);

}

e,//由Object类中继承来的hashcode、equals方法

//Set中判断是否是重复的元素的过程:

//1、调用对象的hashcode方法,看返回的哈希码值是否相同,若不相同,则认为是不同的对象

//2、若相同,则再调用equals方法进行判断,若返回false,则认为是不同的对象,否则(返回的是true)则认为是同一个对象

例如 Student stu1 = new Student(1000,"张三");

Student stu2 = new Student(1001,"张三");

// System.out.println(stu1.hashCode());

// System.out.println(stu2.hashCode());

set.add(stu1);

set.add(stu2);

-----------------------------------------------------------------------------------------------

Set:不按照索引、不按照放入的次序存储元素-->无序的

//不能存放重复元素

Ⅱ:TreeSet:具有排序功能的

a.添加元素也是add();//若放入的是数值,则按照数值大小升序排列;//若是字符串则按照字母的字 典顺序。需要注意的是:放入的元素得是同一类型的。

b//若要将自定义的对象放入TreeSet中,必须该对象所在的类是实现了Comparable接口

例如:Student stu1 = new Student(1003,"zhangsan");

Student stu2 = new Student(1000,"lisi");

Student stu3 = new Student(1001,"wangwu");

set.add(stu1);

set.add(stu2);

set.add(stu3);

Iterator it = set.iterator();

while(it.hasNext()){

Student stu = it.next();

System.out.println(stu.getId()+"\t"+stu.getName());

}

System.out.println(set);

public class Student implements Comparable{

private int id;

private String name;

>>>>>>(此处省略构造方法和set、get方法)<<<<<

@Override

public int hashCode() {

// System.out.println("调用了hashcode方法");

// return super.hashCode();

return 100;

}

@Override

public boolean equals(Object obj) {

// System.out.println("调用了equals方法");

// return super.equals(obj);

// return true;

Student stu = (Student)obj;

if(this.id==stu.id&&this.name.equals(stu.name)){

return true;

}else{

return false;

}

}

//排序规则

@Override

public int compareTo(Student stu) {

// return this.id-stu.id;//按照id的升序

// return stu.id-this.id;//按照id的降序

// return this.name.compareTo(stu.name);//按照name的升序

return stu.name.compareTo(this.name);

}

}

上面是Set集的回顾(都实现Collection接口)

===================================================================================

下面是Map映射知识点回顾

===================================================================================

/Map:映射关系   存放的是键值对key-value

Map,存放元素是put();方法

1.HashMap:不是线程安全的   key和value都可以为null(但key只能有一个null值,value可以多个)

例如 HashMap map = new HashMap();

map.put("", "");

map.put(null, null);//put()是放入元素

System.out.println(map);

2。Hashtable:1、线程安全的  古老集合  2、key和value都不能为null;获得value值:Object temp = map.get(23);//根据key获得value:-------->get(key);

例如:   map.put("sa", "abc");

map.put(23, 34);

map.put(34, "cdf");

map.put(new Object(), "value");

注意map.put(null, "as");//key不能为null

map.put("aa", null);//value也不能为null

Hashtable遍历:

Set sets = map.keySet();//返回所有的key  Map中的key是以Set形式存放的,获得所有KEY

Iterator it = sets.iterator();

while(it.hasNext()){

temp = it.next();//将key循环遍历出来

Object value = map.get(temp);//然后根据Key来遍历出value的值

System.out.println(value);

}

System.out.println(map);

3.TreeMap: key具有排序功能    key不能为null value可以为null

//若key是数值  按照数值大小的升序

/*map.put(1001, "value");

map.put(1000, "lue");

map.put(1002, "alue");*/

//若key是字符串,按照字母的字典顺序

/*map.put("bb", 23);

map.put("aa", 123);

map.put("cc", 3323);*/规则和TreeSet差不多,同样只能存放一种类型,只不过TreeMap是一种类型的key。

//若key是自定义的对象,该对象所在的类实现Comparable接口

// Student stu1 = new Student(1003,"zhangsan");

// Student stu2 = new Student(1000,"lisi");

// Student stu3 = new Student(1001,"wangwu");

// map.put(stu1, 123);

// map.put(stu2, 23);

// map.put(stu3, 323);

//

// Set sets = map.keySet();

// Iterator it = sets.iterator();

// while(it.hasNext()){

// Student stu = it.next();

// System.out.println(stu.getId()+"\t"+stu.getName()+"\t"+map.get(stu));

// }

// System.out.println(map);

// map.put(null, "");//key不能为null

map.put("aa", null);

~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

【有不对的地方,多多批正

a7602bb6fc46d0669cc00223cb0b3d80.gif

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/564586.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

java cookie安全_cookie的安全性问题

HTTP协议&#xff1a;(1)请求组成部分&#xff1a;请求行&#xff1a;(get或者post请求&#xff1b;请求路径(不包括主机) &#xff1b;http1.1)请求头&#xff1a;请求头是浏览器交给服务器的一些信息(比较cookie啥的)请求体&#xff1a;只有post请求有请求体&#xff0c;get请…

java幻灯片播放代码_简单常用的幻灯片播放实现代码

幻灯片自动播放图片是当前网站比较流行的一个展示方式。在网上我们能找到各种特效丰富的幻灯片插件和代码。这里项目需要&#xff0c;我自己做了一个简单的&#xff0c;就不详细讲解了&#xff0c;代码很简单。直接看效果图和代码吧。所有代码 ppt.html&#xff0c;需要提供相应…

ssms没有弹出服务器验证_powerbi报表服务器搭建链接

作品展示​www.chinapowerbi.com安装 Power BI 报表服务器所要满足的硬件和软件要求 - Power BI​docs.microsoft.comDownload 用于基于 x64 的系统的 Windows 8.1 更新程序 (KB2919442) from Official Microsoft Download Center​www.microsoft.comDownload Windows Server 2…

groovy java_在java中使用groovy怎么搞

临摹微笑一种基于Java虚拟机的动态语言&#xff0c;可以和java无缝集成&#xff0c;正是这个特性&#xff0c;很多时候把二者同时使用&#xff0c;把groovy作为java的有效补充。对于Java程序员来说&#xff0c;学习成本几乎为零。同时支持DSL和其他简介的语法(例如闭包)&#x…

mysql 类似wm concat_oracle的wm_concat()和mysql的group_concat()合并同列变成一行的用法以及和concat()合并不同列的区别...

前言标题几乎已经说的很清楚了&#xff0c;在oracle中&#xff0c;concat()函数和 “ || ” 这个的作用是一样的&#xff0c;是将不同列拼接在一起&#xff1b;那么wm_concat()是将同属于一个组的(group by)同一个字段拼接在一起变成一行。mysql是一样的&#xff0c;只不过mysq…

试图将驱动程序添加到存储区_基于容器的块存储使用

什么是块存储&#xff1f;分布式存储系统&#xff0c;为业务与数据在集群内漂移提供了自由保障&#xff0c;满足企业对于不受约束的系统环境要求。同时&#xff0c;平台仅保存迁移被改动的数据&#xff0c;而非整体增加数据量&#xff0c;实现增量备份。魔方云块存储的功能&…

如何编译和运行C++程序?

C 和C语言类似&#xff0c;也要经过编译和链接后才能运行。那么C是如何运行的呢&#xff0c;C和C的运行步骤是一样的。我们需要留意的是C源文件的后缀&#xff0c;以及GCC 中的g命令。 下图是 C/C 代码生成可执行文件的过程&#xff1a; C源文件的后缀 C语言源文件的后缀非…

堆排序java实例_堆排序(示例代码)

前言&#xff1a;网上有很多堆排序的案例&#xff0c;我只想写自己堆排序。一&#xff1a;堆结构即&#xff1a;一个父节点最多只能有两个子节点(可以没有)&#xff0c;如下图图1图2图3 图4二&#xff1a; 数组与堆结构转换假设已知堆数组 int[] a {9,7,6,4,5,1,3,2,} 则相…

python 生成图片_python生成带有表格的图片

因为工作中需要&#xff0c;需要生成一个带表格的图片例如&#xff1a;直接在html中写一个table标签&#xff0c;然后单独把表格部分保存成图片或者是直接将excel中的内容保存成一个图片刚开始的思路&#xff0c;是直接生成一个带有table标签的html文件&#xff0c;然后将这个文…

wpf xaml突然不能自动补齐代码_Xaml+C#桌面客户端跨平台初体验

(给DotNet加星标&#xff0c;提升.Net技能)转自&#xff1a;大头BigHeadcnblogs.com/Big-Head/p/12614118.html前言随着 .NET 5的到来&#xff0c;微软在 .NET跨平台路上又开始了一个更高的起点。回顾.NET Core近几年的成果&#xff0c;可谓是让.NET重生了一次.ASP .NET Core跨…

vc6.0mfc中单选按钮如何分组_按钮系列02-搞定按钮和选框的14个秘诀

UI 界面当中&#xff0c;各种开关、按钮、选框控件是非常常见的组件&#xff0c;它们看起来不复杂&#xff0c;但是在实际使用的时候讲究非常之多&#xff0c;它们不仅关乎体验&#xff0c;而且涉及到一些界面逻辑问题。英文中的 「Toggle」一词&#xff0c;对应的是带有短柄的…

java某个类避免findbug检查_Findbug插件静态java代码扫描工具使用

本文转自http://blog.csdn.net/gaofuqi/article/details/22679609 感谢作者FindBugs 是由马里兰大学提供的一款开源 Java静态代码分析工具。FindBugs通过检查类文件或 JAR文件&#xff0c;将字节码与一组缺陷模式进行对比从而发现代码缺陷&#xff0c;完成静态代码分析。FindBu…

4乘4方格走的路线_苏州周边4个冷门自驾游路线景点推荐

1.崇明东滩崇明东滩湿地公园有两大看点&#xff0c;一是看候鸟迁徙&#xff0c;二是看日出和星空。东滩湿地滩涂辽阔&#xff0c;低头是大片的芦苇&#xff0c;抬头是满天斑斓的云彩&#xff0c;顺着木栈道走在公园内&#xff0c;如与大自然融为一体&#xff0c;可360度将美景收…

Spring体系结构详解

Spring 框架采用分层架构&#xff0c;根据不同的功能被划分成了多个模块&#xff0c;这些模块大体可分为 Data Access/Integration、Web、AOP、Aspects、Messaging、Instrumentation、Core Container 和 Test。 Spring的体系结构如下图所示 图中包含了 Spring 框架的所有模块…

java对外查询接口注意的地方_Java接口注意点

1、接口可以多实现&#xff1a;一个实现类可以同时实现多个接口package com.qf.demo02_interface;//定义一种规则&#xff1a;interface A{public void testA();//public void fun();}//定义另一种规则interface B{public void testB();public void fun();}//实现类&#xff0c…

Spring目录结构和基础JAR包介绍

目前 Spring 框架的最新版本是 5.1.8&#xff0c;本教程是基于 Spring 的稳定版本 3.2.13 进行讲解的。读者可以通过网址 http://repo.spring.io/simple/libs-release-local/org/springframework/spring/ 下载名称为 springframework-3.2.13.RELEASE-dist.zip 的压缩包。单击此…

自定义依赖注解无效_SpringValidation用注解代替代码参数校验解析

Spring Validation概念在原先的编码中&#xff0c;我们如果要验证前端传递的参数&#xff0c;一般是在接受到传递过来的参数后&#xff0c;手动在代码中做 if-else 判断&#xff0c;这种编码方式会带来大量冗余代码&#xff0c;十分的不优雅。因此&#xff0c;推出了用注解的方…

mysql开源许可_为什么开源数据库改变许可证?

CockroachDB 是一个开源的分布式数据库&#xff0c;最近改变了代码授权&#xff0c;放弃了 Apache 许可证。一、CockroachDB 的许可证变更CockroachDB 以前的许可证是 Apache&#xff0c;代码托管在 GitHub&#xff0c;任何人都可以访问。现在的许可证改成了"商业源码许可…

Spring 依赖注入的实现

依赖注入&#xff08;Dependency Injection&#xff0c;DI&#xff09;和控制反转含义相同&#xff0c;它们是从两个角度描述的同一个概念。 当某个 Java 实例需要另一个 Java 实例时&#xff0c;传统的方法是由调用者创建被调用者的实例&#xff08;例如&#xff0c;使用 new…

java 静态对象语法_04.Java 语法

计算机基础知识表达式(expression)&#xff1a;Java中最基本的一个运算。比如一个加法运算表达式。12是一个表达式&#xff0c;ab也是。计算机内存的最小存储单元是字节(byte)&#xff0c;一个字节就是一个8位二进制数&#xff0c;即8个bit。它的二进制表示范围从00000000~1111…