我总结出了很多互联网公司的面试题及答案,并整理成了文档,以及各种学习的进阶学习资料,免费分享给大家。
扫描二维码或搜索下图红色VX号,加VX好友,拉你进【程序员面试学习交流群】免费领取。也欢迎各位一起在群里探讨技术。
java面试题
1.接口和抽象类的区别
抽象类 | 接口 |
抽象类中可以有默认方法 | 在java8之前,不能有默认方法 |
extends | implements |
抽象类中可以有构造器 | 接口中不能有构造器 |
抽象类中可以使用public protected | 接口中是完全是public |
添加方法时,可以不修改子类现有的代码 | 子类必须实现新添加的方法 |
2.什么是不可变对象?
不可变对象一旦被创建,状态就不能被修改。任何修改都会新创建一个新的对象,如String Integer 等包装类。
3.java中几种创建对象的方式?
①采用new的方式 ②通过反射进行创建 ③采用clone 的方式进行创建 ④通过序列化机制进行
4.equals 和hashcode()的联系?
如果连个对象的equals不相等,有可能产生的hash值会相等,可能会出现碰撞的情况,如果equals相等,那么hashcode肯定是相等的。
在hashcode中不能使用随机数
5.final、finalize、finally 的不同之处?
final 是最终的,修改的对象和变量的值不可进行更改。 finalize 在对象回收之前调用一次,但是不知道具体的时间。finally 表示,发生异常也会执行的操作。
6.线程wait()和sleep()的区别?
sleep 睡眠后不会让出资源, wait()会进行资源的让出,sleep 时间到的话就会执行,wait() 需要进行唤醒,notify() 或者notifyall()
7. Java中浅拷贝和深拷贝?
浅拷贝针对对象而言,如果对象属性是非引用型,则非引用的部分重新进行赋值,也就是clone出来的对象这些属相相互不影响,如果是引用型,则会影响,他们是
拷贝的是对象的地址。(String类型非常特殊,虽然属于引用类型,但是不能当做这个 包装类型也例外)
深拷贝:完全拷贝一个新的对象
深拷贝实例:
Object clone = super.clone(); Student st = (Student)clone; Address clone1 = (Address)st.getAddress().clone(); st.setAddress(clone1); return super.clone();
8.ThreadLocal(线程变量副本)?
threadlocal为每个变量维护一个线程变量,采用空间转化时间的方式,为每个使用该线程的变量提供一个副本。主要解决多线程中,数据不一致的问题,它的本质是数据
的隔离,Synchronized 是数据的共享。
9. JVM ?
java 虚拟机,它屏蔽了与操作平台相关的信息,这就是java虚拟机的“一次编译,到处运行”的原因。
JRE :java 程序运行的环境,普通的用户只需要安装JRE就可以了。
JDK: 是程序开发人员用来编译、调试java程序用的包,包含了JRE
10. java 内存模型?
①程序计数器 ②java虚拟机栈 ③本地方法栈 ④java堆 ⑤方法区 ⑥运行时常量池
12 . lock与synchronized 的区别?
lock还具有锁投票 定时锁等候,中断锁等候。
synchronized 如果A占着锁不放,B会一直等待。
lock 如果A 不释放,B会中断等候,去干别的事情。
①lock() 如果获得了锁,立即返回,否则一直在休眠等待
②trylock() 如果获得锁,立即返回true,否则返回false
③tryLock(long timeout,TimeUnit unit), 如果获取了锁定立即返回true,如果别的线程正持有锁,会等待参数给定的时间,在等待的过程中,如果获取了锁定,就
返回true,如果等待超时,返回false
④lockInterruptibly:如果获取了锁定立即返回,如果没有获取锁定,当前线程处于休眠状态,直到或者锁定,或者当前线程被别的线程中断
synchronized 出现异常时候,会自动释放锁,但是lock不会。
在竞争不是非常激烈的情况下,使用synchronized 比较好。激烈的话,使用lock
13. volatile 的使用场景:
为了解决多线程中,变量改变后,无法通知其他线程。使用的条件:对变量的操作不依赖当前值,改变量没有包含具有其他变量的不变式 不保证原子性
14. CAS 无锁算法?
当多个线程尝试使用CAS更改同一个变量的时候,只有一个变量能够成功,失败的线程并不会被挂起,而是被告知竞争失败。
15.线程池的作用?
① 降低资源的消耗,通过重复利用,减小创建和销毁的消耗。
② 提高相应的速度,当任务到达时候,任务不需要等待线程的创建就能够立即执行。
③ 提高线程的管理性
16 . 一直hash性
hash算法称为散列算法,就是通过散列算法,将数据存储到一个指定的地址上面,下次如果添加的时候,set就通过这个地址来进行判断这个地址是否有值。
这样就大大降低了消耗。
数组的特点:寻找地址快,插入和删除困难。
链表的特点:寻地址难,插入和删除简单。
hashMap 可以接受null键和值(线程非安全的),而hashtable 不能(线程安全的)
17 . SpringIOC (控制反转 和依赖注入)
通过注入的方式构建springbean,通过反射机制实例化bean并建立依赖关系
springbean 一般都单例模式,每一个请求会产生新的bean实例,
转载:https://www.cnblogs.com/chengyangyang/p/10399080.html
推荐内容:
2018年Java面试题整理
Java面试集合(一)
Java 多线程
【Java】泛型学习笔记
【Java】广州三本秋招经历
【Java】留下没有基础眼泪的面试题
初学Java Web(4)——Servlet学习总结
Java工程师的生活、读书、技术栈
一、面试准备-Java知识
Java 最常见的 200+ 面试题汇总