java面试题带链接

下面是在网下下载的,不知道哪来的了,发出来方便查看

一、Java基础

1. String类为什么是final的。

https://www.zhihu.com/question/31345592

2. HashMap的源码,实现原理,底层结构

get(key)方法时获取keyhash值,计算hash&(n-1)得到在链表数组中的位置first=tab[hash&(n-1)],先判断firstkey是否与参数key相等,不等就遍历后面的链表找到相同的key值返回对应的Value值即可

http://blog.youkuaiyun.com/tuke_tuke/article/details/51588156

3. 说说你知道的几个Java集合类:listsetqueuemap实现类咯。。。

http://blog.youkuaiyun.com/csp277/article/details/46462605

4. 描述一下ArrayListLinkedList各自实现和区别

http://blog.youkuaiyun.com/u013673242/article/details/43272005

5. Java中的队列都有哪些,有什么区别。

http://blog.youkuaiyun.com/u012881904/article/details/51491736

6. 反射中,Class.forNameclassloader的区别

http://blog.youkuaiyun.com/qq_27093465/article/details/52262340

javaclass.forName()classLoader都可用来对类进行加载。
class.forName()前者除了将类的.class文件加载到jvm中之外,还会对类进行解释,执行类中的static块。
classLoader只干一件事情,就是将.class文件加载到jvm中,不会执行static中的内容,只有在newInstance才会去执行static块。
Class.forName(name, initialize, loader)带参函数也可控制是否加载static块。并且只有调用了newInstance()方法采用调用构造函数,创建类的对象

7. Java7Java8的新特性(baidu问的,BT)

https://www.cnblogs.com/justcooooode/p/7701260.html

8. Java数组和链表两种结构的操作效率,在哪些情况下(从开头开始,从结尾开始,从中间开始),哪些操作(插入,查找,删除)的效率高

9. Java内存泄露的问题调查定位:jmapjstack的使用等等

Jmap  得到运行java程序的内存分配的详细情况。例如实例个数,大小等 

jstack能得到运行java程序的java stacknative stack的信息。可以轻松得知当前线程的

 

10. stringstringbuilderstringbuffer区别

StringBuffer 字符串变量(线程安全)StringBuilder 字符串变量(非线程安全

11. hashtablehashmap的区别

http://blog.youkuaiyun.com/bruce_suxin/article/details/78787875

http://blog.youkuaiyun.com/fujiakai/article/details/51585767

13 .异常的结构,运行时异常和非运行时异常,各举个例子

http://blog.youkuaiyun.com/qq_27093465/article/details/52268531

14. String a= “abc” String b = “abc” String c = new String(“abc”) String d = “ab” + “c” .他们之间用 == 比较的结果

15. String 类的常用方法

https://www.cnblogs.com/ABook/p/5527341.html

16. Java 的引用类型有哪几种

http://blog.youkuaiyun.com/qq_27093465/article/details/52460738

17. 抽象类和接口的区别

http://blog.youkuaiyun.com/fenglibing/article/details/2745123

18. java的基础类型和字节大小。

19. Hashtable,HashMap,ConcurrentHashMap 底层实现原理与线程安全问题(建议熟悉 jdk 源码,才能从容应答)

HashMap不是线程安全的,ConcurrentHashMap是线程安全的

https://www.cnblogs.com/binyue/p/4545550.html

20. 如果不让你用Java Jdk提供的工具,你自己实现一个Map,你怎么做。说了好久,说了HashMap源代码,如果我做,就会借鉴HashMap的原理,说了一通HashMap实现

21. Hash冲突怎么办?哪些解决散列冲突的方法?

http://blog.youkuaiyun.com/lightty/article/details/11191971

22. HashMap冲突很厉害,最差性能,你会怎么解决?On)提升到logn)咯,用二叉排序树的思路说了一通

23. rehash

在介绍HashMap的内部实现机制时提到了两个参数,DEFAULT_INITIAL_CAPACITYDEFAULT_LOAD_FACTORDEFAULT_INITIAL_CAPACITYtable数组的容量,DEFAULT_LOAD_FACTOR则是为了最大程度避免哈希冲突,提高HashMap效率而设置的一个影响因子,将其乘以DEFAULT_INITIAL_CAPACITY就得到了一个阈值threshold,当HashMap的容量达到threshold时就需要进行扩容,这个时候就要进行ReHash操作了,可以看到下面addEntry函数的实现,当size达到threshold时会调用resize函数进行扩容。

24. hashCode()  equals() 生成算法、方法怎么重写

http://blog.youkuaiyun.com/zzg1229059735/article/details/51498310

25.java为什么要重写hashCodeequals方法

http://blog.youkuaiyun.com/zknxx/article/details/53862572

26. Java中的队列都有哪些,有什么区别

 

二、Java IO

1. 讲讲IO里面的常见类,字节流、字符流、接口、实现类、方法阻塞。

https://zhidao.baidu.com/question/1703553491279513980.html

http://blog.youkuaiyun.com/love_taylor/article/details/62237002

2. 讲讲NIO

http://weixiaolu.iteye.com/blog/1479656

3. String 编码UTF-8 GBK的区别?

GBK包含全部中文字符;UTF-8则包含全世界所有国家需要用到的字符。 

 GBK是在国家标准GB2312基础上扩容后兼容GB2312的标准(好像还不是国家标准) 

 UTF-8编码的文字可以在各国各种支持UTF8字符集的浏览

 

4. 什么时候使用字节流、什么时候使用字符流?

https://www.cnblogs.com/huangliting/p/5746950.html

 

5. 递归读取文件夹下的文件,代码怎么实现

三、Java Web

1. sessioncookie的区别和联系,session的生命周期,多个服务部署时session管理。

这个是做负载均衡最基本的问题,有很多种解决方案,
第一个是用Session Sticky技术,保证有相同的SessionID请求都映射到同一台服务器上。
第二个是用Session Replication技术,就是同步你的Session信息,同一个sesssion信息每一个台服务器都保留数据。
第三个就是Session数据集中存储,常用的是memcacheredisKV存储器。
总结起来就是将存放session机台服务器都能够看的见,摸得着。可以想想现实生活中遇到类似的问题是怎么解决的,程序架构中就是这样解决的。

2. servlet的一些相关问题

http://blog.youkuaiyun.com/u010215407/article/details/51377419

3. webservice相关问题

http://blog.youkuaiyun.com/u012320542/article/details/53425272

4. jdbc连接,forname方式的步骤,怎么声明使用一个事务。举例并具体代码

http://blog.youkuaiyun.com/caomiao2006/article/details/22412755

5. 无框架下配置web.xml的主要配置内容

https://segmentfault.com/a/1190000011404088

6. jspservlet的区别

https://www.cnblogs.com/0201zcr/p/4693365.html

四、JVM

1. Java的内存模型以及GC算法

https://www.cnblogs.com/kingszelda/p/7226080.html

2. jvm性能调优都做了什么

https://www.cnblogs.com/wangzhongqiu/p/6500751.html

3. 介绍JVM7个区域,然后把每个区域可能造成内存的溢出的情况说明

http://blog.youkuaiyun.com/junlinbo/article/details/17712235

4. 介绍GC GC Root不正常引用。

http://blog.youkuaiyun.com/x_i_y_u_e/article/details/50897229

5. 自己从classload 加载方式,加载机制说开去,从程序运行时数据区,讲到内存分配,讲到String常量池,讲到JVM垃圾回收机制,算法,hotspot。反正就是各种扩展

https://segmentfault.com/a/1190000004359074?utm_source=tuicool&utm_medium=referral

6. jvm 如何分配直接内存, new 对象如何不分配在堆而是栈上,常量池解析

7. 数组多大放在 JVM 老年代(不只是设置 PretenureSizeThreshold ,问通常多大,没做过一问便知)

8. 老年代中数组的访问方式

9. GC 算法,永久代对象如何 GC  GC 有环怎么处理

10. 谁会被 GC ,什么时候 GC

11. 如果想不被 GC 怎么办

12. 如果想在 GC 中生存 1 次怎么办

五、开源框架

1. hibernateibatis的区别

http://blog.youkuaiyun.com/abbydream/article/details/62236305

2. 讲讲mybatis的连接池。

http://blog.youkuaiyun.com/luanlouis/article/details/37671851

3. spring框架中需要引用哪些jar包,以及这些jar包的用途

https://www.cnblogs.com/BensonHe/p/3903050.html

4. springMVC的原理

5. springMVC注解的意思

6. springbeanFactoryApplicationContext的联系和区别

7. spring注入的几种方式(循环注入)

http://blog.youkuaiyun.com/a909301740/article/details/78379720

8. spring如何实现事物管理的

http://blog.youkuaiyun.com/trigl/article/details/50968079

9. springIOC

10. spring AOP的原理

11. hibernate中的1级和2级缓存的使用方式以及区别原理(Lazy-Load的理解)

12. Hibernate的原理体系架构,五大核心接口,Hibernate对象的三种状态转换,事务管理。

六、多线程

https://www.cnblogs.com/wangwanchao/p/5268249.html

 

1. Java创建线程之后,直接调用start()方法和run()的区别

http://blog.youkuaiyun.com/u010953266/article/details/46546543

2. 常用的线程池模式以及不同线程池的使用场景

http://blog.youkuaiyun.com/Mr_Smile2014/article/details/50152283

http://blog.youkuaiyun.com/xu__cg/article/details/52962991

http://blog.youkuaiyun.com/javazejian/article/details/77410889?locationNum=1&fps=1

3. newFixedThreadPool此种线程池如果线程数达到最大值后会怎么办,底层原理。

4. 多线程之间通信的同步问题,synchronized锁的是对象,衍伸出和synchronized相关很多的具体问题,例如同一个类不同方法都有synchronized锁,一个对象是否可以同时访问。或者一个类的static构造方法加上synchronized之后的锁的影响。

5. 了解可重入锁的含义,以及ReentrantLock synchronized的区别

http://blog.youkuaiyun.com/qq838642798/article/details/65441415

6. 同步的数据结构,例如concurrentHashMap的源码理解以及内部实现原理,为什么他是同步的且效率高

http://blog.youkuaiyun.com/dingji_ping/article/details/51005799

7. atomicintegerVolatile等线程安全操作的关键字的理解和使用

http://blog.youkuaiyun.com/hupitao/article/details/45227891

8. 线程间通信,waitnotify

http://blog.youkuaiyun.com/free4294/article/details/39206049

9. 定时线程的使用

10. 场景:在一个主线程中,要求有大量(很多很多)子线程执行完之后,主线程才执行完成。多种方式,考虑效率。 CountDownLatch

http://blog.youkuaiyun.com/long290046464/article/details/52999023

http://lf6627926.iteye.com/blog/1538301

11. 进程和线程的区别

12. 什么叫线程安全?举例说明

13. 线程的几种状态

http://blog.youkuaiyun.com/sinat_36042530/article/details/52565296

14. 并发、同步的接口或方法

http://blog.youkuaiyun.com/sinat_36042530/article/details/52565296

15. HashMap 是否线程安全,为何不安全。 ConcurrentHashMap,线程安全,为何安全。底层实现是怎么样的。

16. J.U.C下的常见类的使用。 ThreadPool的深入考察; BlockingQueue的使用。(takepoll的区别,putoffer的区别);原子类的实现。

http://ifeve.com/j-u-c-framework/

17. 简单介绍下多线程的情况,从建立一个线程开始。然后怎么控制同步过程,多线程常用的方法和结构

 

18. volatile的理解

19. 实现多线程有几种方式,多线程同步怎么做,说说几个线程里常用的方法

https://www.cnblogs.com/myc12143334/p/7252136.html

七、网络通信

1. http是无状态通信,http的请求方式有哪些,可以自己定义新的请求方式么。

2. socket通信,以及长连接,分包,连接异常断开的处理。

3. socket通信模型的使用,AIONIO

4. socket框架netty的使用,以及NIO的实现原理,为什么是异步非阻塞。

5. 同步和异步,阻塞和非阻塞。

6. OSI七层模型,包括TCP,IP的一些基本知识

7. http中,get post的区别

8. 说说http,tcp,udp之间关系和区别。

9. 说说浏览器访问www.taobao.com,经历了怎样的过程。

https://blog.youkuaiyun.com/guoweimelon/article/details/50880391

10. HTTP协议、  HTTPS协议,SSL协议及完整交互过程;

11. tcp的拥塞,快回传,ip的报文丢弃

12. https处理的一个过程,对称加密和非对称加密

https://blog.youkuaiyun.com/tenfyguo/article/details/40958727

13. head各个特点和区别

https://www.cnblogs.com/xiaopaipai/p/8550797.html

14. 说说浏览器访问www.taobao.com,经历了怎样的过程。

https://www.cnblogs.com/7758521gorden/p/8166777.html

八、数据库MySql

1. MySql的存储引擎的不同

2. 单个索引、联合索引、主键索引

3. Mysql怎么分表,以及分表后如果想按条件分页查询怎么办(如果不是按分表字段来查询的话,几乎效率低下,无解)

4. 分表之后想让一个id多个表是自增的,效率实现

5. MySql的主从实时备份同步的配置,以及原理(从库读主库的binlog),读写分离

6. SQL语句。。。

7. 索引的数据结构,B+

8. 事务的四个特性,以及各自的特点(原子、隔离)等等,项目怎么解决这些问题

9. 数据库的锁:行锁,表锁;乐观锁,悲观锁

10. 数据库事务的几种粒度;

11. 关系型和非关系型数据库区别

九、设计模式

1. 单例模式:饱汉、饿汉。以及饿汉中的延迟加载,双重检查

2. 工厂模式、装饰者模式、观察者模式。

3. 工厂方法模式的优点(低耦合、高内聚,开放封闭原则)

十、算法

1. 使用随机算法产生一个数,要求把1-1000W之间这些数全部生成。(考察高效率,解决产生冲突的问题)

2. 两个有序数组的合并排序

3. 一个数组的倒序

4. 计算一个正整数的正平方根

5. 说白了就是常见的那些查找、排序算法以及各自的时间复杂度

6. 二叉树的遍历算法

7. DFS,BFS算法

9. 比较重要的数据结构,如链表,队列,栈的基本理解及大致实现。

10. 排序算法与时空复杂度(快排为什么不稳定,为什么你的项目还在用)

11. 逆波兰计算器

12. Hoffman 编码

13. 查找树与红黑树

十一、并发与性能调优

1. 有个每秒钟5k个请求,查询手机号所属地的笔试题(记得不完整,没列出),如何设计算法?请求再多,比如5w,如何设计整个系统?

2. 高并发情况下,我们系统是如何支撑大量的请求的

3. 集群如何同步会话状态

4. 负载均衡的原理

5 .如果有一个特别大的访问量,到数据库上,怎么做优化(DB设计,DBIOSQL优化,Java优化)

6. 如果出现大面积并发,在不增加服务器的基础上,如何解决服务器响应不及时问题

7. 假如你的项目出现性能瓶颈了,你觉得可能会是哪些方面,怎么解决问题。

8. 如何查找 造成 性能瓶颈出现的位置,是哪个位置照成性能瓶颈。

9. 你的项目中使用过缓存机制吗?有没用用户非本地缓存

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值