整理了java开发的题-------java基础、并发

Java基础

1、List和set集合,Map集合的区别以及它们的实现类有哪些?有什么区别?
在这里插入图片描述
List 是可重复集合,Set 是不可重复集合,这两个接口都实现了 Collection 父接口。
Map 未继承 Collection,而是独立的接口,Map 是一种把键对象和值对象进行映射的集合,它的每一个元素都包含了一对键对象和值对象,Map 中存储的数据是没有顺序的, 其 key 是不能重复的,它的值是可以有重复的。
List 的实现类有 ArrayList,Vector 和 LinkedList:
ArrayList 和 Vector 内部是线性动态数组结构,在查询效率上会高很多,Vector 是线程安全的,相比 ArrayList 线程不安全的,性能会稍慢一些。
LinkedList:是双向链表的数据结构存储数据,在做查询时会按照序号索引数据进行前向或后向遍历,查询效率偏低,但插入数据时只需要记录本项的前后项即可,所以插入速度较快。
Set 的实现类有 HashSet 和 TreeSet;
HashSet:内部是由哈希表(实际上是一个 HashMap 实例)支持的。它不保证 set 元素的迭代顺序。
TreeSet:TreeSet 使用元素的自然顺序对元素进行排序,或者根据创建 set 时提供的 Comparator 进行排序。
Map 接口有三个实现类:Hashtable,HashMap,TreeMap,LinkedHashMap;Hashtable:内部存储的键值对是无序的是按照哈希算法进行排序,与 HashMap 最大的区别就是线程安全。键或者值不能为 null,为 null 就会抛出空指针异常。TreeMap:基于红黑树 (red-black tree) 数据结构实现,按 key 排序,默认的排序方式是升序。LinkedHashMap:有序的 Map 集合实现类,相当于一个栈,先 put 进去的最后出来,先进后出。
List和map的区别:一个是存储单列数据的集合,另一个是存储键和值这样的双列数据的集合,List 中存储的数据是有顺序,并且允许重复;Map 中存储的数据是没有顺序的,其 key 是不能重复的,它的值是可以有重复的。
2、HashSet 是如何保证不重复的
在向hashSet中add()元素时,判断元素是否存在的依据,不仅仅是hash码值就能够确定的,同时还要结合equles方法
HashSet 类中的add()方法:

public boolean add(E e) {
    return map.put(e, PRESENT)==null;
  }

put()方法:

 public V put(K key, V value) {
        if (key == null)
            return putForNullKey(value);
        int hash = hash(key.hashCode());
        int i = indexFor(hash, table.length);
        for (Entry<K,V> e = table[i]; e != null; e = e.next) {
            Object k;
            if (e.hash == hash && ((k = e.key) == key || key.equals(k))) {
                V oldValue = e.value;
                e.value = value;
                e.recordAccess(this);
                return oldValue;
            }
        }
        modCount++;
        addEntry(hash, key, value, i);
        return null;
    }

可以看到for循环中,遍历table中的元素,
1,如果hash码值不相同,说明是一个新元素,存;
如果没有元素和传入对象(也就是add的元素)的hash值相等,那么就认为这个元素在table中不存在,将其添加进table;
2(1),如果hash码值相同,且equles判断相等,说明元素已经存在,不存;
2(2),如果hash码值相同,且equles判断不相等,说明元素不存在,存;
如果有元素和传入对象的hash值相等,那么,继续进行equles()判断,如果仍然相等,那么就认为传入元素已经存在,不再添加,结束,否则仍然添加;

3、HashMap 是线程安全的吗,为什么不是线程安全的(最好画图说明多线程环境下不安全)?
不安全
https://coolshell.cn/articles/9606.html
hashmap如何解决冲突

在这里插入图片描述
为什么 HashMap 中 String、Integer 这样的包装类适合作为 key 键
在这里插入图片描述
4、HashMap 的扩容过程
https://www.cnblogs.com/zhuoqingsen/p/8577646.html

5、HashMap 1.7 与 1.8 的 区别,说明 1.8 做了哪些优化,如何优化的?

6、final finally finalize
final用于声明属性,方法和类,分别表示属性不可交变,方法不可覆盖,类不可继承。
java中的关键字,修饰符。
A).如果一个类被声明为final,就意味着它不能再派生出新的子类,不能作为父类被继承。因此,一个类不能同时被声明为abstract抽象类的和final的类。
B).如果将变量或者方法声明为final,可以保证它们在使用中不被改变.
  1)被声明为final的变量必须在声明时给定初值,而在以后的引用中只能读取,不可修改。
  2)被声明final的方法只能使用,不能重载。
这是一道再经典不过的面试题了,我们在各个公司的面试题中几乎都能看到它的身影。final、finally和finalize虽然长得像孪生兄弟一样,但是它们的含义和用法却是大相径庭。
final关键字我们首先来说说final。它可以用于以下四个地方:
1).定义变量,包括静态的和非静态的。
2).定义方法的参数。
3).定义方法。
4).定义类。
定义变量,包括静态的和非静态的。定义方法的参数
第一种情况:
如果final修饰的是一个基本类型,就表示这个变量被赋予的值是不可变的,即它是个常量;
如果final修饰的是一个对象,就表示这个变量被赋予的引用是不可变的
这里需要提醒大家注意的是,不可改变的只是这个变量所保存的引用,并不是这个引用所指向的对象。
第二种情况:final的含义与第一种情况相同。
实际上对于前两种情况,一种更贴切的表述final的含义的描述,那就是,如果一个变量或方法参数被final修饰,就表示它只能被赋值一次,但是JAVA虚拟机为变量设定的默认值不记作一次赋值。被final修饰的变量必须被初始化。初始化的方式以下几种:
1.在定义的时候初始化。
2.final变量可以在初始化块中初始化,不可以在静态初始化块中初始化。
3.静态final变量可以在定义时初始化,也可以在静态初始化块中初始化,不可以在初始化块中初始化。
4.final变量还可以在类的构造器中初始化,但是静态final变量不可以。
finally是异常处理语句结构的一部分,表示总是执行。
java的一种异常处理机制。
  finally是对Java异常处理模型的最佳补充。finally结构使代码总会执行,而不管无异常发生。使用finally可以维护对象的内部状态,并可以清理非内存资源。特别是在关闭数据库连接这方面,如果程序员把数据库连接的close()方法放到finally中,就会大大降低程序出错的几率。
finalize是Object类的一个方法,在垃圾收集器执行的时候会调用被回收对象的此方法,供垃圾收集时的其他资源回收,例如关闭文件等。
finalize:Java中的一个方法名。
Java技术使用finalize()方法在垃圾收集器将对象从内存中清除出去前,做必要的清理工作。这个方法是由垃圾收集器在确定这个对象没被引用时对这个对象调用的。它是在Object类中定义的,因此所的类都继承了它。子类覆盖finalize()方法以整理系统资源或者执行其他清理工作。finalize()方法是在垃圾收集器删除对象之前对这个对象调用的。
7、强引用 、软引用、 弱引用、虚引用
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 好的,以下是一些2023年Java面试和学习计划建议: Java面试: 1. 什么是Java虚拟机(JVM)?JVM的组成部分是什么? 2. 什么是Java中的反射?反射的优缺点是什么? 3. 什么是Java中的注解?它们有哪些用途? 4. 什么是Java中的Lambda表达式?如何使用它们? 5. 什么是Java中的异常处理?Java中有哪些类型的异常? 6. 什么是Java中的多线程?如何创建和控制线程? 7. 什么是Java中的集合框架?Java中有哪些集合类? 8. 什么是Java中的IO和NIO?它们有什么区别? 9. 什么是Java中的泛型?如何使用它们? 10. 什么是Java中的类加载器?它们有哪些类型? 学习计划建议: 1. 学习Java基础知识,包括语法、数据类型、运算符等。 2. 深入了解Java中的面向对象编程思想,掌握类、对象、继承、多态等概念。 3. 学习Java中的集合框架,包括List、Set、Map等集合类的使用。 4. 学习Java中的异常处理机制,掌握try-catch-finally结构以及自定义异常的使用。 5. 学习Java中的多线程编程,包括线程的创建、启动、等待和同步等概念。 6. 学习Java中的IO和NIO编程,包括文件读写、网络编程等。 7. 学习Java中的反射和注解机制,了解它们的作用和使用方法。 8. 学习Java中的Lambda表达式和函数式编程思想,掌握Lambda表达式的语法和使用方法。 9. 学习Java中的泛型编程,包括泛型类和泛型方法的使用。 10. 学习Java中的类加载机制,包括类加载器的种类、类加载的顺序等。 以上是一些建议,您可以根据自己的情况进行调整和修改。最重要的是不断练习,多做一些实际的项目或者练习目,以提高自己的编程能力和实践经验。 ### 回答2: 2023年的Java面试和学习计划如下: 1. Java核心知识 - Java语言基础:变量、数据类型、运算符、控制结构等 - 面向对象编程:封装、继承、多态、抽象类、接口等 - 异常处理机制:try-catch-finally、自定义异常等 - 集合框架:List、Set、Map等常用集合操作 - IO操作:文件读写、序列化等 2. Java高级特性 - 多线程和并发:线程生命周期、同步、锁机制、线程池等 - 反射和动态代理:Class类、反射调用、动态代理的概念和用法 - 泛型:泛型类型、泛型方法、通配符等 - 注解:定义和使用注解、元注解等 - Lambda表达式和函数式接口:Lambda表达式的语法和用法、函数式接口定义和使用 3. 数据库相关 - SQL语法和基本操作:增删改查、连接查询、聚合函数等 - JDBC编程:连接数据库、CRUD操作、事务管理等 - ORM框架:例如Hibernate、MyBatis的使用和原理 4. web开发相关 - Servlet和JSP:Servlet生命周期、请求响应过程、Session管理等 - Spring框架:IOC、AOP、MVC等基本概念和使用 - Spring Boot:自动配置、常用注解、项目搭建等 - RESTful API设计和使用:HTTP方法、资源定义、状态码等 学习计划如下: 1. 确定学习目标:了解面试要求和考察重点,制定合理的时间表 2. 学习基础知识:通过阅读相关教材、网上教程等掌握Java基础语法和核心知识 3. 实践项目:通过完成一些小项目或者任务来巩固理论知识,提高编程能力 4. 阅读原理文档:深入理解Java相关的原理和机制,如JVM、多线程等 5. 练习面试:刷、模拟面试,提高解决问的能力和应对压力的能力 6. 参考书籍和培训班:选择一些经典的Java开发书籍和参加培训班提高自己的学习效果 7. 学习交流:参加技术社区、技术论坛等进行学习交流,与其他Java开发者共同进步 以上是2023年Java面试整理和一个较为综合的学习计划,具体根据个人情况进行调整。成功的关键在于持续努力、实践和不断积累经验。祝你在2023年的Java面试中取得好成绩! ### 回答3: 2023年的Java面试分为三个主要方面:基础知识、核心概念和高级特性。下面是一个学习计划的建议,以帮助你准备面试。 1. 基础知识: - 熟悉Java语言的基本语法、数据类型、运算符和控制流程语句。 - 理解面向对象编程的概念,包括类、对象、继承、多态和封装。 - 学习异常处理机制、输入输出流和Java集合框架。 2. 核心概念: - 理解Java内存管理机制,包括堆和栈的区别、垃圾回收和内存泄漏。 - 学习多线程编程,包括线程的创建、同步、通信和线程池的使用。 - 熟悉Java的反射机制和注解,了解它们在框架和库中的应用。 3. 高级特性: - 学习Java的网络编程,包括Socket编程、HTTP传输和RESTful服务。 - 掌握常用的设计模式,如单例模式、工厂模式和观察者模式。 - 了解Java的新特性,如Lambda表达式、Stream API和模块化系统。 学习计划建议如下: - 设定一个合理的学习时间表,每天定期进行学习,以确保学习的连续性。 - 阅读相关的Java教程和参考资料,例如官方文档和经典的Java编程书籍。 - 实践编写Java代码,通过解决实际问来加深对知识的理解和记忆。 - 参加Java开发的线上课程、培训或是参与开源项目,积累实践经验。 - 利用在线资源,如编程网站和论坛,与其他学习者交流、分享和提问。 - 制定一个自我评估计划,定期检查自己的学习进度并找出需要加强的领域。 通过系统学习和实践,逐步提升自己的Java编程能力,并不断完善面试的准备。记住,面试并不仅仅是回答问,还要展示自己的编程思维和解决问的能力。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值