热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

※Java初级常见面试题①

2022春招面试指南:Java岗位基础篇(适用于各大企业招聘Java初级工程师岗位,附配套MD文档)_哔哩哔哩_bilibi

2022春招面试指南:Java岗位基础篇(适用于各大企业招聘Java初级工程师岗位,附配套MD文档)_哔哩哔哩_bilibili

 


1.JDK1.8的新特性


- Lamda表达式

- 接口中新增默认方法和静态方法

- Stream API

- 新时间日期API

- 方法



2. 自定义异常在Java中如何运用,如何自定义异常?


- 系统中有些错误符合语法,但不符合业务逻辑

- 在分层的软件结构中,通常是在表现层表示统一对系统其他层次的异常进行捕获处理

自定义异常:自定义编译时异常.a.定义一个异常类继承Exception.b.重写构造器。c.在出现异常的地方用throw new 自定义对象抛出!编译时异常是编译阶段就报错,提醒更加强烈,一定需要处理!!自定义运行时异常.a.定义一个异常类继承RuntimeException.b.重写构造器。c.在出现异常的地方用throw new 自定义对象抛出!提醒不强烈,编译阶段不报错!!运行时才可能出现!!


3.怎样声明一个类不会被继承,什么场景下会用?


用final修饰,类不会被继承

如果类中的所有方法没有重写的需要,当前类没有子类也罢

比如Math类



4.HashMap为什么要使用红黑树? 


红黑树(Red Black Tree) 是一种自平衡二叉查找树
>二叉查找树->左小右大的二叉树
>二叉树->节点的度不大于2的有序树
>>①非黑即红②根黑③叶黑④红黑相间⑤到叶同黑1.节点是RED或者BLACK2.根节点是BLACK3.叶子节点(外部节点,空节点)都是BLACK4.RED节点的子节点都是BLACK,RED节点的parent都是BLACK(从根节点到叶子节点的所有路径上不能有2个连续的RED节点)5.从任一节点到叶子节点的所有路径都包含相同数目的BLACK节点

 在JDK1.8版本后,java对HashMap做了改进,在链表长度大于8的时候,将后面的数据存在红黑树中,以加快检索速度

红黑树查找,插入,删除的时间复杂度最坏为o(log{_{2}}n)

链表查找,插入,删除的时间复杂度最坏为o(n)



5.Java的异常处理机制是什么?


                        抛出异常 ~> throw

                / 

异常处理 -       捕获异常 ~> try...catch...finally

                \       

                        声明异常 ~> throws



 6.描述下Object常用的方法


Object类是Java中的祖宗类。
一个类要么默认继承了Object类,要么间接继承了Object类。toString 定义一个对象的字符串表现形式

-- 默认是返回当前对象在堆内存中的地址信息:com.example.Student@735b478 类的全限名@内存地址
-- 直接输出对象名称,默认会自动调用toString()方法,所以输出对象toString()调用可以省略不写
-- 父类toString()方法存在的意义就是为了被子类重写,以便返回对象的内容信息输出!!

equals
-- 默认是比较两个对象的地址是否相同。
-- 直接比较两个对象的地址是否相同完全可以用“==”替代equals。所以equals存在的意义是为了被子类重写,以便程序员可以自己来定制比较规则。
-- 需求:只要两个对象的内容一样,我们就认为他们是相等的。hashCode
必须掌握的hashcode()方法_Java笔记虾-CSDN博客
-- 通过对象的内部地址(也就是物理地址)转换成一个整数,然后该整数通过hash函数的算法就得到了hashcode。所以,hashcode是什么呢?就是在hash表中对应的位置。
-- HashCode的存在主要是为了查找的快捷性,HashCode是用来在散列存储结构中确定对象的存储地址的
wait notify notifyAll
-- wait方法,可以让当前线程进入等待唤醒状态,并释放锁
-- notifyAll唤醒所有wait线程或notify随机唤醒一个wait线程,唤醒的线程再去公平竞争锁。
-- 只能在同步函数或代码块中使用wait、notify和notifyAllclone 返回一个对象的副本 深克隆 浅克隆
finalized


7.Java中的自增是线程安全的吗,如何实现线程安全的自增?


不安全

如何保证变量访问的原子性呢?
-- a.加锁实现线程安全:synchronized或lock 性能不好!(1)同步代码块。(2)同步方法。(3)lock显示锁。
-- b.基于CAS方式的原子类:如AtomicInteger()


8. Synchronized和CAS都可以保证多线程环境下共享数据的安全性。那么他们两者有什么区别?


一个悲观,一个乐观

Synchronized是从悲观的角度出发:总是假设最坏的情况,每次去拿数据的时候都认为别人会修改,所以每次在拿数据的时候都会上锁,这样别人想拿这个数据就会阻塞直到它拿到锁(**共享资源每次只给一个线程使用,其它线程阻塞,用完后再把资源转让给其它线程**)。因此Synchronized我们也将其称之为**悲观锁**。jdk中的ReentrantLock也是一种悲观锁。性能较差!!CAS是从乐观的角度出发:总是假设最好的情况,每次去拿数据的时候都认为别人不会修改,所以不会上锁,但是在更新的时候会判断一下在此期间别人有没有去更新这个数据CAS这种机制我们也可以将其称之为乐观锁。综合性能较好!


9. Java的动态代理有几种实现形式


静态代理

动态代理:

-- Proxy代理(JDK的)

-- CGlib代理(第三方的)



10.集合类是怎么解决高并发的问题?


线程安全的集合类

-- Vector

-- HashTable

高性能线程安全的集合类(JUC包下)

-- ConcurrentHashMap

-- CopyOnWriteArrayList



 11.hashcode和equals如何使用?


Java的基类Object提供了一些方法,其中equals()方法用于判断两个对象是否相等

hashCode()方法用于计算对象的哈希值。equals()和hashCode()都不是final方法,都可以被重写(overwrite)。



推荐阅读
  • 本文回顾了2017年的转型和2018年的收获,分享了几家知名互联网公司提供的工作机会及面试体验。 ... [详细]
  • 深入解析ESFramework中的AgileTcp组件
    本文详细介绍了ESFramework框架中AgileTcp组件的设计与实现。AgileTcp是ESFramework提供的ITcp接口的高效实现,旨在优化TCP通信的性能和结构清晰度。 ... [详细]
  • 由二叉树到贪心算法
    二叉树很重要树是数据结构中的重中之重,尤其以各类二叉树为学习的难点。单就面试而言,在 ... [详细]
  • 本文深入探讨了MySQL中常见的面试问题,包括事务隔离级别、存储引擎选择、索引结构及优化等关键知识点。通过详细解析,帮助读者在面对BAT等大厂面试时更加从容。 ... [详细]
  • 本文将详细探讨 Java 中提供的不可变集合(如 `Collections.unmodifiableXXX`)和同步集合(如 `Collections.synchronizedXXX`)的实现原理及使用方法,帮助开发者更好地理解和应用这些工具。 ... [详细]
  • 2017-2018年度《网络编程与安全》第五次实验报告
    本报告详细记录了2017-2018学年《网络编程与安全》课程第五次实验的具体内容、实验过程、遇到的问题及解决方案。 ... [详细]
  • 本文详细介绍了Java集合框架中的Collection体系,包括集合的基本概念及其与数组的区别。同时,深入探讨了Comparable和Comparator接口的区别,并分析了各种集合类的底层数据结构。最后,提供了如何根据需求选择合适的集合类的指导。 ... [详细]
  • 前言无论是对于刚入行工作还是已经工作几年的java开发者来说,面试求职始终是你需要直面的一件事情。首先梳理自己的知识体系,针对性准备,会有事半功倍的效果。我们往往会把重点放在技术上 ... [详细]
  • Nginx 反向代理与负载均衡实验
    本实验旨在通过配置 Nginx 实现反向代理和负载均衡,确保从北京本地代理服务器访问上海的 Web 服务器时,能够依次显示红、黄、绿三种颜色页面以验证负载均衡效果。 ... [详细]
  • 版本控制工具——Git常用操作(下)
    本文由云+社区发表作者:工程师小熊摘要:上一集我们一起入门学习了git的基本概念和git常用的操作,包括提交和同步代码、使用分支、出现代码冲突的解决办法、紧急保存现场和恢复 ... [详细]
  • 深入剖析JVM垃圾回收机制
    本文详细探讨了Java虚拟机(JVM)中的垃圾回收机制,包括其意义、对象判定方法、引用类型、常见垃圾收集算法以及各种垃圾收集器的特点和工作原理。通过理解这些内容,开发人员可以更好地优化内存管理和程序性能。 ... [详细]
  • 本文档汇总了Python编程的基础与高级面试题目,涵盖语言特性、数据结构、算法以及Web开发等多个方面,旨在帮助开发者全面掌握Python核心知识。 ... [详细]
  • 本文详细记录了一位具有五年半开发经验的候选人,在华为Android高级开发职位面试过程中的经历。从早晨9点到下午5点半,经过了群体面试、技术面试、综合面试及英语面试等多个环节,最终成功通过考核。文章不仅分享了面试心得,还提供了宝贵的面试题资源。 ... [详细]
  • Barbican 是 OpenStack 社区的核心项目之一,旨在为各种环境下的云服务提供全面的密钥管理解决方案。 ... [详细]
  • NFS(Network File System)即网络文件系统,是一种分布式文件系统协议,主要用于Unix和类Unix系统之间的文件共享。本文详细介绍NFS的配置文件/etc/exports和相关服务配置,帮助读者理解如何在Linux环境中配置NFS客户端。 ... [详细]
author-avatar
海之蓝水之清清2011
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有