面试问题总结

本贴最后更新于 2026 天前,其中的信息可能已经时移世易
  1. java 中的关键字 final 可以用来修饰什么,分别起什么作用。
  2. 请说明 ArrayList,Vector,LinkedList 的存档性能和特性。
  3. String,StringBuffer,StringBuilder 有什么区别。
  4. swith 是否能作用在 byte 上,是否能作用在 long 上,是否能作用在 strng 上。
  5. 存在表 T(a,b,c,d),要根据字段 c 排序后取第 21-30 条记录显示,请写出 sql 文。
  6. 查出 user 表中 username 相同的记录,显示 username 和重复的次数,给出 sql。
  7. float 是多少位的。
  8. 设计四个线程,其中两个线程每次对 J 增加 1,另外两个线程每次对 J 减 1,写出程序或者思路。
  9. a.hashCode()有什么作用?与 a.equals(b)有什么关系?
  10. 写出 hashMap 的数据结构。
  11. 简述 MVC 设计模式。
  12. 什么是 Java 优先级队列。
  13. 简述一下 spring,都用过 spring 的什么?
  14. 说一下数据库的索引。数据库隔离级别。
  15. statement 与 PreparedStatement 的区别,如何防止 sql 注入。
  16. 简述一下 restful,设计一个 url 要注意什么。
  17. 如何进行单元测试的。
  18. 选用了 base 跟 solo,如何实现的数据同步。
  19. 说几个常用算法。
  20. 下面程序会输出什么值?
    int count = 0;
    for(count++;count++ < 10; count++)
    System.out.println(count);
    
  21. 简述 form 表单提交 POST 方法与 GET 方法在字符编码,http 协议等方面的区别。
  22. ArrayList,LinkedList,HashMap 的区别。
  23. 介绍一下 Spring 的事务管理,使用什么设计模式实现。
  24. 一个 HTTP 请求从开始到结束都经历哪些过程,简写流程图即可。
  25. synchronize 关键字与 volatile 关键字的作用和区别。
  26. 说一下内连接,左连接,右连接。
  27. 给 list 排序(我记得是有个 collections.sort),说出这个,又问了一个什么排序的,忘记了。
  28. 写两个链表,将其合并排序,如何操作不多占用内存。(完全没任何思路,对链表就不熟哇···)
  29. 多线程是 void,无返回值的,如果用多线程从不同的数据库中读取到数据,如何将读取到的信息合并。(题目记得不是很清楚了,应该精髓记住了,大体就是没有返回值,那如何合并多线程取得的东西。一个同事跟我说出力到文件中,然后合并文件)
  30. 写出单例模式。

上面基本就是这次面试问过的能记住的问题。有些记不住了。那些问高并发的,算法的,都被我自动忽略了。我是真不懂那些呀~上面这些其实还是蛮基础的,但是很多你懂,不一定记得准确,说就更不一定说得齐全了。

下面这些是之前在网上看到的,就粘贴过来了。有兴趣的看看。

spring 主要考 ioc,aop 底层实现,事务,spring mvc 原理
ioc 就有可能问反射和类加载,这就会牵涉 jvm 的东西
互联网公司面试还有三个东西最好看看,消息队列,nosql,rpc 与 soa

  1. Spring.mvc 的优势,原理,流程
  2. Mybatis 的原理优势
  3. 集合里面那些对象的原理
  4. 扩容原理,特别是 map 的底层
  5. Hashmap. Hashtable 和 cocurrentHashMap 的区别,要讲出它们各自的实现原理才行,比如 Hashmap 的扩容机制. cocurrentHashMap 的桶分割原理. 多线程安全性。
  6. 几种造线程池的方法,区别
  7. Rpc 原理
  8. Nio 和 netty,常用的接口
  9. Redis 和数据库的持久化的
  10. Memached 过程和原理
  11. 多线程时间复杂度
  12. Redis 做队列的原理
  13. zk 做订阅的原理,底层
  14. Juc 里面的锁原理
  15. 实现自己的 hashmap
  16. treemap 红黑树
  17. jvm 调优
  18. jvm 内存模型
  19. 类加载器机制
  20. 数据库索引
  21. 数据破坏索引
  22. 手写快排
  23. js 闭包
  24. nio 是否了解 阻塞之后通知机制是怎样的?
  25. Java 的序列化做什么用的 序列化 id 会出现哪些问题?
  26. 在 Java 中 Executor 和 Executors 的区别?
  27. 为什么使用 Executor 框架比使用应用创建和管理线程好?
  28. 怎么通过 linux 命令去分析 jvm 里面那个线程阻塞了
  29. Java 中用到的线程调度算法是什么?
  30. 什么是多线程中的上下文切换?
  31. classloader 结构,是否可以自己定义一个 java.lang.String 类,为什么? 双亲代理机制。
  32. 有没有做过 jvm 内存调优,如何做的,举例子,用过哪些工具?
  33. Java 中的 volatile 关键是什么作用?怎样使用它?在 Java 中它跟 synchronized 方法有什么不同?
  34. 面试官从简历里抽了一个较感兴趣的项目,让把项目简单介绍了下,针对项目问了几个技术问题
  35. 介绍 Java 中垃圾回收机制,程序员平时需要关注这个吗?为什么?请举例说明。
  36. 数据库隔离级别介绍. 举例说明。
  37. override 和 overload 的区别。
  38. 求二叉树的最大距离(即相距最远的两个叶子节点),写代码。
  39. 两个栈实现一个队列,写代码。
  40. 你觉得你的优势是什么?有什么技术薄弱点吗?
  41. 数据库 sql 调优,慢 sql 定位
  42. 索引有哪几种,区别,使用场景
  43. mysql 引擎,哪几种,区别使用场景

下面是一个在外企工作 8 年人,给传统 it 转互联网方面的面试建议。

  1. 算法基础
    写 java 的基本上都是做应用系统的,用到算法的机会几乎没有,所以一般不会考。但是如果工作年限比较长,保不齐面试官怀疑你的编程能力,故意要考考,所以快排. 堆排. 逆转链表. 遍历二叉树之类的基础还是复习复习吧。
    如果面的是 bat 核心部门,担心碰见装逼人士的话,也可以提前复习下《编程之美》之类的。

  2. java 基础
    hashmap 面试官最喜欢考,一定要搞明白原理。
    treemap 知道就可以,应该没人闲的蛋疼考红黑树。
    threadlocal 面试官也喜欢考,要搞明白原理
    反射. 动态代理. ioc. aop 复习下吧,几乎必考
    nio. aio 几乎都会问,抽空写写例程,知道 netty mina
    class loader: 知道双亲委派,如果知道 tomcat. jetty class loader 异同更佳

  3. gc
    gc 很多面试官都喜欢考
    面试前背熟各种 gc 算法的区别,理解原理。
    G1 很多面试官自己都不明白,没时间就不用管。

  4. 高并发
    传统 IT 一般接触不到高并发,不过没关系按下面说的做,应付面试问题不大
    把 java.util.concurrent 下面所有的包和类通读一遍,理解原理. 记住核心代码. 写例程,网上有很多 concurrent 相关类原理解析的文章,对着文章看源代码理解起来问题不大。
    有些类代码很复杂比如 aqs,看不明白就算了,也不用太花功夫,记住原理即可,因为大部分面试官也不明白。
    一定要写例程,例程最好跟你的业务能扯上一点点关系,这样面试的时候就是你实际项目里面的代码了。
    面试官喜欢考的类有:ConcurrentHashMap. 读写锁. Condition. 线程池. Barrier. CountDownLatch. Callable. BlockingQueue

  5. hdfs 和 mr
    传统 IT 一般也接触不到,如果不想准备就算了,如果想准备的话,就在自己的开发机上撘 3 个 linux 虚机, 按照网上的教程自己一步一步撘一个 hadoop 环境出来,然后找几个实际业务中生成出来的 log,写几个 mr 程序处理一下。
    面试的时候就可以很谦虚的说,实际项目里面用过,但是用的不多

  6. application server
    websphere. weblogic. jboss 之类的就不用准备了,应该没人问你这些啦。
    有时间的话,看看 tomcat 和 jetty 的源代码,重点看线程模型和 io,这将是一个很好的加分项

  7. 数据库
    oracle. sybase. db2 不会有人关心了,如果之前没用过 mysql 的话,找本介绍 innodb 原理的书好好通读一遍吧。
    理解 myisam 和 innodb 的区别
    理解关系型数据库索引的原理,理解一些简单的索引优化的原则。
    面试官很喜欢给出一堆 where 子句,考索引. 复合索引什么情况下起作用

  8. 缓存
    一致性哈希很多面试官喜欢考,提前准备下吧。

  9. ssh 框架
    这些没搞过就没搞过吧,这种框架层面的东西,对于一个有经验的 java 码农,学起来也就是分分钟的事情。
    不过你也可以说这些我没用过,但是我知道原理,然后说一堆动态代理. cglib 的原理出来,也是加分。

打赏 10 积分后可见
10 积分 • 44 打赏
  • 面试

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

    324 引用 • 1395 回帖 • 4 关注
  • 原理
    16 引用 • 44 回帖

相关帖子

24 回帖

欢迎来到这里!

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

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

    消灭 0 回复

  • FYeed

    全是 Java OC 在边上瑟瑟发抖

    1 回复
  • yangyujiao
    作者

    当年领导想让我做 ios,我还把 oc 基础看完了··· 但是后来还是继续做 Java 了···

  • relyn

    不错,作为一些知识点收藏了,很好奇隐藏的是什么

  • sucre

    鸡肋

  • tmedivh

    大街上的哈萨克

    1 回复
  • yangyujiao
    作者

    这是什么意思呀。

  • wuhongxu

    好东西,感谢分享,我对 java 的理解实在是太浅了

  • yourShitCode

    感觉这 10 分花的不值..............

    1 回复
  • yangyujiao
    作者

    等你赢取了白富美,记得回来感谢我

  • cqlancer

    感谢分享经验~

  • moreandmore

    😋

  • Eddie

    最近想辞职

    2 回复
  • 88250 1

    年底了怎么会有这种想法?而且今年很多公司裁员,辞了可能会不好找,尽量不要动。

    2 回复
  • Ahian

    学来学去,发现这些知识都是建立在理论学科之上的,比如说数学

  • Eddie

    同期进公司的人今年人都走光了。部门除了管理层外,找不到一个在公司任职 3 年以上的人。

  • yangyujiao 2
    作者

    我最近也听到很多离职的朋友说工作不好找,我觉得可以等年后再说。年后可能用人需求会大一些,因为人员流动的多啊,好多人都是等着拿了年终在走啊。

    1 回复
  • senowang

    那是明年在走,因为年终奖在明年初才发。。。

    1 回复
  • 88250

    一些公司因为最近的税改政策,会选择在今年内发年终,税改搞得动作挺大的。

  • wenandlu

    多少年前的东西了还来挖,发帖的时候我还是个刚毕业的萌新

    1 回复
  • yangyujiao
    作者

    这个帖子见证你的成长啊。

  • ZephyrJung

    首页这个改动有点奇怪,这么多评论,都导向同一个文章岂不是重复?

    1 回复
  • Eddie

    怎么说的好像没有什么时间是容易找工作的。

  • 88250

    这是因为抽取回帖的算法太糙了,会继续改进,多谢反馈。

请输入回帖内容 ...

推荐标签 标签

  • Flume

    Flume 是一套分布式的、可靠的,可用于有效地收集、聚合和搬运大量日志数据的服务架构。

    9 引用 • 6 回帖 • 608 关注
  • Caddy

    Caddy 是一款默认自动启用 HTTPS 的 HTTP/2 Web 服务器。

    10 引用 • 54 回帖 • 139 关注
  • Node.js

    Node.js 是一个基于 Chrome JavaScript 运行时建立的平台, 用于方便地搭建响应速度快、易于扩展的网络应用。Node.js 使用事件驱动, 非阻塞 I/O 模型而得以轻量和高效。

    138 引用 • 268 回帖 • 147 关注
  • 新人

    让我们欢迎这对新人。哦,不好意思说错了,让我们欢迎这位新人!
    新手上路,请谨慎驾驶!

    51 引用 • 226 回帖
  • MongoDB

    MongoDB(来自于英文单词“Humongous”,中文含义为“庞大”)是一个基于分布式文件存储的数据库,由 C++ 语言编写。旨在为应用提供可扩展的高性能数据存储解决方案。MongoDB 是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的。它支持的数据结构非常松散,是类似 JSON 的 BSON 格式,因此可以存储比较复杂的数据类型。

    90 引用 • 59 回帖 • 4 关注
  • Dubbo

    Dubbo 是一个分布式服务框架,致力于提供高性能和透明化的 RPC 远程服务调用方案,是 [阿里巴巴] SOA 服务化治理方案的核心框架,每天为 2,000+ 个服务提供 3,000,000,000+ 次访问量支持,并被广泛应用于阿里巴巴集团的各成员站点。

    60 引用 • 82 回帖 • 614 关注
  • 禅道

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

    6 引用 • 15 回帖 • 186 关注
  • 服务器

    服务器,也称伺服器,是提供计算服务的设备。由于服务器需要响应服务请求,并进行处理,因此一般来说服务器应具备承担服务并且保障服务的能力。

    124 引用 • 580 回帖
  • Java

    Java 是一种可以撰写跨平台应用软件的面向对象的程序设计语言,是由 Sun Microsystems 公司于 1995 年 5 月推出的。Java 技术具有卓越的通用性、高效性、平台移植性和安全性。

    3169 引用 • 8208 回帖
  • AngularJS

    AngularJS 诞生于 2009 年,由 Misko Hevery 等人创建,后为 Google 所收购。是一款优秀的前端 JS 框架,已经被用于 Google 的多款产品当中。AngularJS 有着诸多特性,最为核心的是:MVC、模块化、自动化双向数据绑定、语义化标签、依赖注入等。2.0 版本后已经改名为 Angular。

    12 引用 • 50 回帖 • 437 关注
  • Ngui

    Ngui 是一个 GUI 的排版显示引擎和跨平台的 GUI 应用程序开发框架,基于
    Node.js / OpenGL。目标是在此基础上开发 GUI 应用程序可拥有开发 WEB 应用般简单与速度同时兼顾 Native 应用程序的性能与体验。

    7 引用 • 9 回帖 • 354 关注
  • Kafka

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

    35 引用 • 35 回帖 • 3 关注
  • 大数据

    大数据(big data)是指无法在一定时间范围内用常规软件工具进行捕捉、管理和处理的数据集合,是需要新处理模式才能具有更强的决策力、洞察发现力和流程优化能力的海量、高增长率和多样化的信息资产。

    89 引用 • 113 回帖
  • JWT

    JWT(JSON Web Token)是一种用于双方之间传递信息的简洁的、安全的表述性声明规范。JWT 作为一个开放的标准(RFC 7519),定义了一种简洁的,自包含的方法用于通信双方之间以 JSON 的形式安全的传递信息。

    20 引用 • 15 回帖 • 21 关注
  • TensorFlow

    TensorFlow 是一个采用数据流图(data flow graphs),用于数值计算的开源软件库。节点(Nodes)在图中表示数学操作,图中的线(edges)则表示在节点间相互联系的多维数据数组,即张量(tensor)。

    20 引用 • 19 回帖
  • DevOps

    DevOps(Development 和 Operations 的组合词)是一组过程、方法与系统的统称,用于促进开发(应用程序/软件工程)、技术运营和质量保障(QA)部门之间的沟通、协作与整合。

    45 引用 • 25 回帖 • 1 关注
  • 创业

    你比 99% 的人都优秀么?

    83 引用 • 1398 回帖
  • 开源中国

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

    7 引用 • 86 回帖
  • 反馈

    Communication channel for makers and users.

    124 引用 • 907 回帖 • 210 关注
  • abitmean

    有点意思就行了

    29 关注
  • H2

    H2 是一个开源的嵌入式数据库引擎,采用 Java 语言编写,不受平台的限制,同时 H2 提供了一个十分方便的 web 控制台用于操作和管理数据库内容。H2 还提供兼容模式,可以兼容一些主流的数据库,因此采用 H2 作为开发期的数据库非常方便。

    11 引用 • 54 回帖 • 649 关注
  • 脑图

    脑图又叫思维导图,是表达发散性思维的有效图形思维工具 ,它简单却又很有效,是一种实用性的思维工具。

    21 引用 • 58 回帖 • 1 关注
  • ZooKeeper

    ZooKeeper 是一个分布式的,开放源码的分布式应用程序协调服务,是 Google 的 Chubby 一个开源的实现,是 Hadoop 和 HBase 的重要组件。它是一个为分布式应用提供一致性服务的软件,提供的功能包括:配置维护、域名服务、分布式同步、组服务等。

    59 引用 • 29 回帖 • 19 关注
  • LaTeX

    LaTeX(音译“拉泰赫”)是一种基于 ΤΕΧ 的排版系统,由美国计算机学家莱斯利·兰伯特(Leslie Lamport)在 20 世纪 80 年代初期开发,利用这种格式,即使使用者没有排版和程序设计的知识也可以充分发挥由 TeX 所提供的强大功能,能在几天,甚至几小时内生成很多具有书籍质量的印刷品。对于生成复杂表格和数学公式,这一点表现得尤为突出。因此它非常适用于生成高印刷质量的科技和数学类文档。

    9 引用 • 32 回帖 • 152 关注
  • 支付宝

    支付宝是全球领先的独立第三方支付平台,致力于为广大用户提供安全快速的电子支付/网上支付/安全支付/手机支付体验,及转账收款/水电煤缴费/信用卡还款/AA 收款等生活服务应用。

    29 引用 • 347 回帖
  • WebComponents

    Web Components 是 W3C 定义的标准,它给了前端开发者扩展浏览器标签的能力,可以方便地定制可复用组件,更好的进行模块化开发,解放了前端开发者的生产力。

    1 引用 • 15 关注
  • 百度

    百度(Nasdaq:BIDU)是全球最大的中文搜索引擎、最大的中文网站。2000 年 1 月由李彦宏创立于北京中关村,致力于向人们提供“简单,可依赖”的信息获取方式。“百度”二字源于中国宋朝词人辛弃疾的《青玉案·元夕》词句“众里寻他千百度”,象征着百度对中文信息检索技术的执著追求。

    63 引用 • 785 回帖 • 248 关注