2017 java 面试题

本贴最后更新于 2443 天前,其中的信息可能已经渤澥桑田

**一、Java 基础
**

1. String 类为什么是 final 的。

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

3. 说说你知道的几个 Java 集合类:list、set、queue、map 实现类咯。。。

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

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

6. 反射中,Class.forName 和 classloader 的区别

7. Java7、Java8 的新特性(baidu 问的,好 BT)

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

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

10. string、stringbuilder、stringbuffer 区别

11. hashtable 和 hashmap 的区别

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

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

15. String 类的常用方法

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

17. 抽象类和接口的区别

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

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

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

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

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

23. rehash

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

**二、Java IO
**

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

2. 讲讲 NIO。

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

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

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

**三、Java Web
**

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

2. servlet 的一些相关问题

3. webservice 相关问题

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

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

6. jsp 和 servlet 的区别

四、JVM

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

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

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

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

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

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

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

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

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

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

11. 如果想不被 GC 怎么办

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

**五、开源框架
**

1. hibernate 和 ibatis 的区别

2. 讲讲 mybatis 的连接池。

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

4. springMVC 的原理

5. springMVC 注解的意思

6. spring 中 beanFactory 和 ApplicationContext 的联系和区别

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

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

9. springIOC

10. spring AOP 的原理

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

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

**六、多线程
**

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

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

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

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

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

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

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

8. 线程间通信,wait 和 notify

9. 定时线程的使用

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

11. 进程和线程的区别

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

13. 线程的几种状态

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

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

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

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

18. volatile 的理解

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

**七、网络通信
**

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

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

3. socket 通信模型的使用,AIO 和 NIO。

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

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

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

7. http 中,get post 的区别

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

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

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

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

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

13. head 各个特点和区别

**八、数据库 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 设计,DBIO,SQL 优化,Java 优化)

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

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

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

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

**十二、其他
**

1.常用的 Linux 下的命令

  • 面试

    面试造航母,上班拧螺丝。多面试,少加班。

    324 引用 • 1395 回帖

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...
  • Ahian

    题主这是哪家的面试

    1 回复
  • 其他回帖
  • lee528066
    作者

    这是网上 copy 来的面试题。本来是内部博客自己看的。结果同步到社区了。

    1 回复
  • Angonger

    不想同步可以在你博客设置里关闭,你可以找下这个配置

推荐标签 标签

  • 架构

    我们平时所说的“架构”主要是指软件架构,这是有关软件整体结构与组件的抽象描述,用于指导软件系统各个方面的设计。另外还有“业务架构”、“网络架构”、“硬件架构”等细分领域。

    140 引用 • 441 回帖
  • 友情链接

    确认过眼神后的灵魂连接,站在链在!

    24 引用 • 373 回帖 • 1 关注
  • V2EX

    V2EX 是创意工作者们的社区。这里目前汇聚了超过 400,000 名主要来自互联网行业、游戏行业和媒体行业的创意工作者。V2EX 希望能够成为创意工作者们的生活和事业的一部分。

    17 引用 • 236 回帖 • 413 关注
  • Jenkins

    Jenkins 是一套开源的持续集成工具。它提供了非常丰富的插件,让构建、部署、自动化集成项目变得简单易用。

    51 引用 • 37 回帖
  • RIP

    愿逝者安息!

    8 引用 • 92 回帖 • 292 关注
  • Elasticsearch

    Elasticsearch 是一个基于 Lucene 的搜索服务器。它提供了一个分布式多用户能力的全文搜索引擎,基于 RESTful 接口。Elasticsearch 是用 Java 开发的,并作为 Apache 许可条款下的开放源码发布,是当前流行的企业级搜索引擎。设计用于云计算中,能够达到实时搜索,稳定,可靠,快速,安装使用方便。

    116 引用 • 99 回帖 • 271 关注
  • Electron

    Electron 基于 Chromium 和 Node.js,让你可以使用 HTML、CSS 和 JavaScript 构建应用。它是一个由 GitHub 及众多贡献者组成的活跃社区共同维护的开源项目,兼容 Mac、Windows 和 Linux,它构建的应用可在这三个操作系统上面运行。

    15 引用 • 136 回帖 • 5 关注
  • Sym

    Sym 是一款用 Java 实现的现代化社区(论坛/BBS/社交网络/博客)系统平台。

    下一代的社区系统,为未来而构建

    523 引用 • 4581 回帖 • 693 关注
  • DNSPod

    DNSPod 建立于 2006 年 3 月份,是一款免费智能 DNS 产品。 DNSPod 可以为同时有电信、网通、教育网服务器的网站提供智能的解析,让电信用户访问电信的服务器,网通的用户访问网通的服务器,教育网的用户访问教育网的服务器,达到互联互通的效果。

    6 引用 • 26 回帖 • 523 关注
  • 程序员

    程序员是从事程序开发、程序维护的专业人员。

    536 引用 • 3528 回帖
  • Kafka

    Kafka 是一种高吞吐量的分布式发布订阅消息系统,它可以处理消费者规模的网站中的所有动作流数据。 这种动作(网页浏览,搜索和其他用户的行动)是现代系统中许多功能的基础。 这些数据通常是由于吞吐量的要求而通过处理日志和日志聚合来解决。

    35 引用 • 35 回帖 • 4 关注
  • 京东

    京东是中国最大的自营式电商企业,2015 年第一季度在中国自营式 B2C 电商市场的占有率为 56.3%。2014 年 5 月,京东在美国纳斯达克证券交易所正式挂牌上市(股票代码:JD),是中国第一个成功赴美上市的大型综合型电商平台,与腾讯、百度等中国互联网巨头共同跻身全球前十大互联网公司排行榜。

    14 引用 • 102 回帖 • 409 关注
  • 开源中国

    开源中国是目前中国最大的开源技术社区。传播开源的理念,推广开源项目,为 IT 开发者提供了一个发现、使用、并交流开源技术的平台。目前开源中国社区已收录超过两万款开源软件。

    7 引用 • 86 回帖 • 1 关注
  • Chrome

    Chrome 又称 Google 浏览器,是一个由谷歌公司开发的网页浏览器。该浏览器是基于其他开源软件所编写,包括 WebKit,目标是提升稳定性、速度和安全性,并创造出简单且有效率的使用者界面。

    60 引用 • 287 回帖
  • Unity

    Unity 是由 Unity Technologies 开发的一个让开发者可以轻松创建诸如 2D、3D 多平台的综合型游戏开发工具,是一个全面整合的专业游戏引擎。

    25 引用 • 7 回帖 • 242 关注
  • 房星科技

    房星网,我们不和没有钱的程序员谈理想,我们要让程序员又有理想又有钱。我们有雄厚的房地产行业线下资源,遍布昆明全城的 100 家门店、四千地产经纪人是我们坚实的后盾。

    6 引用 • 141 回帖 • 561 关注
  • C++

    C++ 是在 C 语言的基础上开发的一种通用编程语言,应用广泛。C++ 支持多种编程范式,面向对象编程、泛型编程和过程化编程。

    106 引用 • 152 回帖 • 1 关注
  • Ant-Design

    Ant Design 是服务于企业级产品的设计体系,基于确定和自然的设计价值观上的模块化解决方案,让设计者和开发者专注于更好的用户体验。

    17 引用 • 23 回帖 • 4 关注
  • 链书

    链书(Chainbook)是 B3log 开源社区提供的区块链纸质书交易平台,通过 B3T 实现共享激励与价值链。可将你的闲置书籍上架到链书,我们共同构建这个全新的交易平台,让闲置书籍继续发挥它的价值。

    链书社

    链书目前已经下线,也许以后还有计划重制上线。

    14 引用 • 257 回帖 • 1 关注
  • 30Seconds

    📙 前端知识精选集,包含 HTML、CSS、JavaScript、React、Node、安全等方面,每天仅需 30 秒。

    • 精选常见面试题,帮助您准备下一次面试
    • 精选常见交互,帮助您拥有简洁酷炫的站点
    • 精选有用的 React 片段,帮助你获取最佳实践
    • 精选常见代码集,帮助您提高打码效率
    • 整理前端界的最新资讯,邀您一同探索新世界
    488 引用 • 383 回帖 • 2 关注
  • 互联网

    互联网(Internet),又称网际网络,或音译因特网、英特网。互联网始于 1969 年美国的阿帕网,是网络与网络之间所串连成的庞大网络,这些网络以一组通用的协议相连,形成逻辑上的单一巨大国际网络。

    96 引用 • 330 回帖
  • danl
    75 关注
  • 禅道

    禅道是一款国产的开源项目管理软件,她的核心管理思想基于敏捷方法 scrum,内置了产品管理和项目管理,同时又根据国内研发现状补充了测试管理、计划管理、发布管理、文档管理、事务管理等功能,在一个软件中就可以将软件研发中的需求、任务、bug、用例、计划、发布等要素有序的跟踪管理起来,完整地覆盖了项目管理的核心流程。

    5 引用 • 15 回帖 • 213 关注
  • sts
    2 引用 • 2 回帖 • 154 关注
  • Sandbox

    如果帖子标签含有 Sandbox ,则该帖子会被视为“测试帖”,主要用于测试社区功能,排查 bug 等,该标签下内容不定期进行清理。

    373 引用 • 1217 回帖 • 582 关注
  • PWA

    PWA(Progressive Web App)是 Google 在 2015 年提出、2016 年 6 月开始推广的项目。它结合了一系列现代 Web 技术,在网页应用中实现和原生应用相近的用户体验。

    14 引用 • 69 回帖 • 134 关注
  • OpenStack

    OpenStack 是一个云操作系统,通过数据中心可控制大型的计算、存储、网络等资源池。所有的管理通过前端界面管理员就可以完成,同样也可以通过 Web 接口让最终用户部署资源。

    10 引用 • 6 关注