一、前言

本部分内容主要包含以下:

Java集合

Java反射

Java注解

Java反射

Java IO

其他面试点

以上内容都是Java中的基础知识,对于Java的学习很有帮助。其中集合、反射、IO等都是面试常问知识点,是必须要掌握的,因此整理在本部分当中。

一、Java集合类简介:

Java集合大致可以分为Set、List、Queue和Map四种体系。

其中Set代表无序、不可重复的集合;List代表有序、重复的集合;而Map则代表具有映射关系的集合。Java 5 又增加了Queue体系集合,代表一种队列集合实现。

Java集合就像一种容器,可以把多个对象(实际上是对象的引用,但习惯上都称对象)“丢进”该容器中。从Java 5 增加了泛型以后,Java集合可以记住容器中对象的数据类型,使得编码更加简洁、健壮。

1.Java集合和数组的区别:

①.数组长度在初始化时指定,意味着只能保存定长的数据。而集合可以保存数量不确定的数据。同时可以保存具有映射关系的数据(即关联数组,键值对 key-value)。

②.数组元素即可以是基本类型的值,也可以是对象。集合里只能保存对象(实际上只是保存对象的引用变量),基本数据类型的变量要转换成对应的包装类才能放入集合类中。

2.Java集合类之间的继承关系:

Java的集合类主要由两个接口派生而出:Collection和Map,Collection和Map是Java集合框架的根接口。

图中,ArrayList,HashSet,LinkedList,TreeSet是我们经常会有用到的已实现的集合类。

Map实现类用于保存具有映射关系的数据。Map保存的每项数据都是key-value对,也就是由key和value两个值组成。Map里的key是不可重复的,key用户标识集合里的每项数据。

图中,HashMap,TreeMap是我们经常会用到的集合类。

二、Collection接口:

1.简介

Collection接口是Set,Queue,List的父接口。Collection接口中定义了多种方法可供其子类进行实现,以实现数据操作。由于方法比较多,就偷个懒,直接把JDK文档上的内容搬过来。

1.1.接口中定义的方法

可以看出Collection用法有:添加元素,删除元素,返回Collection集合的个数以及清空集合等。

其中重点介绍iterator()方法,该方法的返回值是Iterator。

1.2.使用Iterator遍历集合元素

Iterator接口经常被称作迭代器,它是Collection接口的父接口。但Iterator主要用于遍历集合中的元素。

Iterator接口中主要定义了2个方法:

下面程序简单示范了通过Iterator对象逐个获取元素的逻辑。

public class IteratorExample {

public static void main(String[] args){

//创建集合,添加元素

Collection days = new ArrayList();

for(int i =0;i<10;i++){

Day day = new Day(i,i*60,i*3600);

days.add(day);

}

//获取days集合的迭代器

Iterator iterator = days.iterator();

while(iterator.hasNext()){//判断是否有下一个元素

Day next = iterator.next();//取出该元素

//逐个遍历,取得元素后进行后续操作

.....

}

}

}

注意: 当使用Iterator对集合元素进行迭代时,把集合元素的值传给了迭代变量(就如同参数传递是值传递,基本数据类型传递的是值,引用类型传递的仅仅是对象的引用变量。

下面的程序演示了这一点:

public class IteratorExample {

public static void main(String[] args) {

List list = new ArrayList<>();

for (int i = 0; i < 10; i++) {

list.add(new MyObject(i));

}

System.out.println(list.toString());

Iterator iterator = list.iterator();//集合元素的值传给了迭代变量,仅仅传递了对象引用。保存的仅仅是指向对象内存空间的地址

while (iterator.hasNext()) {

MyObject next = iterator.next();

next.num = 99;

}

System.out.println(list.toString());

}

static class MyObject {

int num;

MyObject(int num) {

this.num = num;

}

@Override

public String toString() {

return String.valueOf(num);

}

}

}

输出结果如下:

[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]

[99, 99, 99, 99, 99, 99, 99, 99, 99, 99]

下面具体介绍Collection接口的三个子接口Set,List,Queue。

2.Set集合

简介

Set集合与Collection集合基本相同,没有提供任何额外的方法。实际上Set就是Collection,只是行为略有不同(Set不允许包含重复元素)。

Set集合不允许包含相同的元素,如果试图把两个相同的元素加入同一个Set集合中,则添加操作失败,add()方法返回false,且新元素不会被加入。

3.List集合

3.1.简介

List集合代表一个元素有序、可重复的集合,集合中每个元素都有其对应的顺序索引。List集合允许使用重复元素,可以通过索引来访问指定位置的集合元素 。List集合默认按元素的添加顺序设置元素的索引,例如第一个添加的元素索引为0,第二个添加的元素索引为1......

List作为Collection接口的子接口,可以使用Collection接口里的全部方法。而且由于List是有序集合,因此List集合里增加了一些根据索引来操作集合元素的方法。

3.2.接口中定义的方法

void add(int index, Object element): 在列表的指定位置插入指定元素(可选操作)。

boolean addAll(int index, Collection extends E> c) : 将集合c 中的所有元素都插入到列表中的指定位置index处。

Object get(index): 返回列表中指定位置的元素。

int indexOf(Object o): 返回此列表中第一次出现的指定元素的索引;如果此列表不包含该元素,则返回 -1。

int lastIndexOf(Object o): 返回此列表中最后出现的指定元素的索引;如果列表不包含此元素,则返回 -1。

Object remove(int index): 移除列表中指定位置的元素。

Object set(int index, Object element): 用指定元素替换列表中指定位置的元素。

List subList(int fromIndex, int toIndex): 返回列表中指定的 fromIndex(包括 )和 toIndex(不包括)之间的所有集合元素组成的子集。

Object[] toArray(): 返回按适当顺序包含列表中的所有元素的数组(从第一个元素到最后一个元素)。

除此之外,Java 8还为List接口添加了如下两个默认方法。

void replaceAll(UnaryOperator operator): 根据operator指定的计算规则重新设置List集合的所有元素。

void sort(Comparator c): 根据Comparator参数对List集合的元素排序。

4.Queue集合

4.1.简介

Queue用户模拟队列这种数据结构,队列通常是指“先进先出”(FIFO,first-in-first-out)的容器。队列的头部是在队列中存放时间最长的元素,队列的尾部是保存在队列中存放时间最短的元素。新元素插入(offer)到队列的尾部,访问元素(poll)操作会返回队列头部的元素。通常,队列不允许随机访问队列中的元素。

4.2.接口中定义的方法

三、Map集合

1.简介

Map用户保存具有映射关系的数据,因此Map集合里保存着两组数,一组值用户保存Map里的key,另一组值用户保存Map里的value,key和value都可以是任何引用类型的数据。Map的key不允许重复,即同一个Map对象的任何两个key通过equals方法比较总是返回false。

如下图所描述,key和value之间存在单向一对一关系,即通过指定的key,总能找到唯一的、确定的value。从Map中取出数据时,只要给出指定的key,就可以取出对应的value。

2.Map集合与Set集合、List集合的关系

①.与Set集合的关系

如果 把Map里的所有key放在一起看,它们就组成了一个Set集合(所有的key没有顺序,key与key之间不能重复),实际上Map确实包含了一个keySet()方法,用户返回Map里所有key组成的Set集合。

②.与List集合的关系

如果把Map里的所有value放在一起来看,它们又非常类似于一个List:元素与元素之间可以重复,每个元素可以根据索引来查找,只是Map中索引不再使用整数值,而是以另外一个对象作为索引。

3.接口中定义的方法

Map中还包括一个内部类Entry,该类封装了一个key-value对。Entry包含如下三个方法:

Map集合最典型的用法就是成对地添加、删除key-value对,然后就是判断该Map中是否包含指定key,是否包含指定value,也可以通过Map提供的keySet()方法获取所有key组成的集合,然后使用foreach循环来遍历Map的所有key,根据key即可遍历所有的value。下面程序代码示范Map的一些基本功能:

public class MapTest {

public static void main(String[] args){

Day day1 = new Day(1, 2, 3);

Day day2 = new Day(2, 3, 4);

Map map = new HashMap();

//成对放入key-value对

map.put("第一个", day1);

map.put("第二个", day2);

//判断是否包含指定的key

System.out.println(map.containsKey("第一个"));

//判断是否包含指定的value

System.out.println(map.containsValue(day1));

//循环遍历

//1.获得Map中所有key组成的set集合

Set keySet = map.keySet();

//2.使用foreach进行遍历

for (String key : keySet) {

//根据key获得指定的value

System.out.println(map.get(key));

}

//根据key来移除key-value对

map.remove("第一个");

System.out.println(map);

}

}

输出结果:

true

true

Day [hour=2, minute=3, second=4]

Day [hour=1, minute=2, second=3]

{第二个=Day [hour=2, minute=3, second=4]}

android java框架_【阿里P8大牛教你Android入门之路(java篇)】——Java集合框架(系列篇1)...相关推荐

  1. java代码_阿里资深工程师教你如何优化 Java 代码!

    作者 | 王超责编 | 伍杏玲 明代王阳明先生在<传习录>谈为学之道时说: 私欲日生,如地上尘,一日不扫,便又有一层.着实用功,便见道无终穷,愈探愈深,必使精白无一毫不彻方可. 代码中的& ...

  2. 单独组件_阿里P8年薪百万大牛-教你打造一个Android组件化开发框架

    作者简介 本篇来自 lucky_billy 的投稿,分享了他的开源组件化框架,详细地讲解框架形成的思路,希望对大家有所帮助. lucky_billy 的博客地址: http://blog.csdn.n ...

  3. 阿里P8大牛手把手教你!15个经典面试问题及回答思路,全套教学资料

    缘起 随着互联网企业的不断发展,产品项目中的模块越来越多,用户体验要求也越来越高,想实现小步快跑.快速迭代的目的越来越难,还有应用之间的互相调用等等问题,插件化技术应用而生.如果没有插件化技术,美团. ...

  4. 阿里java架构师+职级_阿里 P8 高级架构师年入100W+,到底什么水平?

    原标题:阿里 P8 高级架构师年入100W+,到底什么水平? 大家都知道,阿里P8高级技术专家,基本上是一线技术人能达到的最高职级,也是很多程序员追求的目标.达到年入百万的P8 Java高级架构师级别 ...

  5. 阿里P8亲自教你!熬夜整理华为最新Java笔试题

    前言 Mysql的锁机制确实非常重要,所以在这里做一个全面的总结整理,便于以后的查阅,也分享给大家. Mysql的锁机制还是有点难理解的,所以这篇文章采用图文结合的方式讲解难点,帮助大家理解,讲解的主 ...

  6. 阿里P8大牛推荐Java程序员必看的 13 本 Java 书籍

    关乎于程序员,除了做项目来提高自身的技术,还有一种提升自己的专业技能就是:多!看!书! 毕竟,书是学习的海洋呢!So,Java程序员你们准备好了吗?双手奉上Java程序员必读之热门书单. 在下面这 1 ...

  7. 阿里P8大牛用实例跟你讲明白“Java 微服务架构实战”

    全文一共十五章,核心内容为SpringBoot.SpringCloud.Docker.RabbitMQ消息组件.其中,SpringBoot是SpringMVC 技术的延伸,使用它进行程序开发会更简单, ...

  8. 阿里P8大牛总结的Java锁机制入门笔记,堪称教科书式天花板

    前言 锁机制无处不在,锁机制是实现线程同步的基础,锁机制并不是Java锁独有的,其他各种计算机语言中也有着锁机制相关的实现,数据库中也有锁的相关内容.这篇文章就是从Java入手,深入学习.理解Java ...

  9. java+set+split_阿里资深工程师教你如何优化 Java 代码!

    原标题:阿里资深工程师教你如何优化 Java 代码! 作者 | 王超 责编 | 伍杏玲 明代王阳明先生在<传习录>谈为学之道时说: 私欲日生,如地上尘,一日不扫,便又有一层.着实用功,便见 ...

最新文章

  1. 聚类之hierachical clustering算法
  2. DL之GRU:GRU算法相关论文、建立过程(基于TF)、相关思路配图集合、TF代码实现
  3. Failed to download You must enable the openssl extension to download files via https
  4. Html.RenderPartial与Html.RenderAction
  5. [Redux/Mobx] redux的thunk作用是什么?
  6. 如何让程序异常退出后重启
  7. 悬赏百万美金,检测Deepfake假视频,数据集有470G:很久不见这么壕的比赛
  8. 查询oracle数据库的表格数据类型,excel表格中如何查询数据库数据类型-我想把excel表格中的数据导入oracle数据库中,想在......
  9. 智能+大数据 在云+互联时代下创造的精准营销
  10. 8-5安装redis-sentinel
  11. 基于微信小程序的电影院购票系统丨毕业设计源码
  12. Python 自动批量生成发卡平台卡密信息并导入数据库
  13. LaTeX新人教程,30分钟从完全陌生到基本入门
  14. Flume 的使用场景详解
  15. 计算机主板复位电路的组成,主板复位电路图解 - 主板知识
  16. mysql数据库设置密码
  17. [数理工程学] 梅花易数-[宋]邵雍 宋抄本影印
  18. js直接调用系统打印机进行打印
  19. 本科毕业论文内容必须有国内外文献综述吗?
  20. 阅文与掌阅的真假繁华

热门文章

  1. face alignment---各种算法框架
  2. 数组中的对象的特征值提取生成新对象实现方法
  3. YUV采样及存储格式
  4. 【VS开发】C++调用外部程序
  5. [转载]CSS 创作指南(Beta)(css规范)
  6. [转载]一个发生在亚洲服务器上的真实故事!
  7. 2-算法 矩阵 数组类
  8. 网站登录页面php代码,一个简单的网页密码登陆php代码
  9. android 上传头像工具类,Android开发中如何实现头像的更换与上传
  10. Python+pandas设置DataFrame显示样式