面试问题总结

本贴最后更新于 471 天前,其中的信息可能已经时移世易
  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 积分 • 43 打赏
  • 面试

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

    261 引用 • 1317 回帖 • 231 关注
  • 原理
    14 引用 • 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

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

请输入回帖内容 ...