面试问题总结

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

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

    325 引用 • 1395 回帖
  • 原理
    16 引用 • 44 回帖

相关帖子

24 回帖

欢迎来到这里!

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

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

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

  • 其他回帖
  • yangyujiao
    作者

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

  • 88250

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

  • yangyujiao 2
    作者

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

    1 回复
  • 查看全部回帖

推荐标签 标签

  • CodeMirror
    1 引用 • 2 回帖 • 129 关注
  • 爬虫

    网络爬虫(Spider、Crawler),是一种按照一定的规则,自动地抓取万维网信息的程序。

    106 引用 • 275 回帖
  • 招聘

    哪里都缺人,哪里都不缺人。

    190 引用 • 1057 回帖
  • 服务器

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

    125 引用 • 588 回帖
  • Git

    Git 是 Linux Torvalds 为了帮助管理 Linux 内核开发而开发的一个开放源码的版本控制软件。

    209 引用 • 358 回帖 • 1 关注
  • ZeroNet

    ZeroNet 是一个基于比特币加密技术和 BT 网络技术的去中心化的、开放开源的网络和交流系统。

    1 引用 • 21 回帖 • 638 关注
  • SendCloud

    SendCloud 由搜狐武汉研发中心孵化的项目,是致力于为开发者提供高质量的触发邮件服务的云端邮件发送平台,为开发者提供便利的 API 接口来调用服务,让邮件准确迅速到达用户收件箱并获得强大的追踪数据。

    2 引用 • 8 回帖 • 483 关注
  • SVN

    SVN 是 Subversion 的简称,是一个开放源代码的版本控制系统,相较于 RCS、CVS,它采用了分支管理系统,它的设计目标就是取代 CVS。

    29 引用 • 98 回帖 • 683 关注
  • HBase

    HBase 是一个分布式的、面向列的开源数据库,该技术来源于 Fay Chang 所撰写的 Google 论文 “Bigtable:一个结构化数据的分布式存储系统”。就像 Bigtable 利用了 Google 文件系统所提供的分布式数据存储一样,HBase 在 Hadoop 之上提供了类似于 Bigtable 的能力。

    17 引用 • 6 回帖 • 73 关注
  • Kotlin

    Kotlin 是一种在 Java 虚拟机上运行的静态类型编程语言,由 JetBrains 设计开发并开源。Kotlin 可以编译成 Java 字节码,也可以编译成 JavaScript,方便在没有 JVM 的设备上运行。在 Google I/O 2017 中,Google 宣布 Kotlin 成为 Android 官方开发语言。

    19 引用 • 33 回帖 • 65 关注
  • Redis

    Redis 是一个开源的使用 ANSI C 语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value 数据库,并提供多种语言的 API。从 2010 年 3 月 15 日起,Redis 的开发工作由 VMware 主持。从 2013 年 5 月开始,Redis 的开发由 Pivotal 赞助。

    286 引用 • 248 回帖 • 62 关注
  • Firefox

    Mozilla Firefox 中文俗称“火狐”(正式缩写为 Fx 或 fx,非正式缩写为 FF),是一个开源的网页浏览器,使用 Gecko 排版引擎,支持多种操作系统,如 Windows、OSX 及 Linux 等。

    8 引用 • 30 回帖 • 406 关注
  • Latke

    Latke 是一款以 JSON 为主的 Java Web 框架。

    71 引用 • 535 回帖 • 787 关注
  • SQLServer

    SQL Server 是由 [微软] 开发和推广的关系数据库管理系统(DBMS),它最初是由 微软、Sybase 和 Ashton-Tate 三家公司共同开发的,并于 1988 年推出了第一个 OS/2 版本。

    21 引用 • 31 回帖 • 1 关注
  • Telegram

    Telegram 是一个非盈利性、基于云端的即时消息服务。它提供了支持各大操作系统平台的开源的客户端,也提供了很多强大的 APIs 给开发者创建自己的客户端和机器人。

    5 引用 • 35 回帖 • 2 关注
  • 房星科技

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

    6 引用 • 141 回帖 • 585 关注
  • CAP

    CAP 指的是在一个分布式系统中, Consistency(一致性)、 Availability(可用性)、Partition tolerance(分区容错性),三者不可兼得。

    11 引用 • 5 回帖 • 608 关注
  • 持续集成

    持续集成(Continuous Integration)是一种软件开发实践,即团队开发成员经常集成他们的工作,通过每个成员每天至少集成一次,也就意味着每天可能会发生多次集成。每次集成都通过自动化的构建(包括编译,发布,自动化测试)来验证,从而尽早地发现集成错误。

    15 引用 • 7 回帖 • 1 关注
  • Mobi.css

    Mobi.css is a lightweight, flexible CSS framework that focus on mobile.

    1 引用 • 6 回帖 • 733 关注
  • 开源中国

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

    7 引用 • 86 回帖
  • CentOS

    CentOS(Community Enterprise Operating System)是 Linux 发行版之一,它是来自于 Red Hat Enterprise Linux 依照开放源代码规定释出的源代码所编译而成。由于出自同样的源代码,因此有些要求高度稳定的服务器以 CentOS 替代商业版的 Red Hat Enterprise Linux 使用。两者的不同在于 CentOS 并不包含封闭源代码软件。

    238 引用 • 224 回帖 • 1 关注
  • Dubbo

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

    60 引用 • 82 回帖 • 597 关注
  • AngularJS

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

    12 引用 • 50 回帖 • 474 关注
  • 思源笔记

    思源笔记是一款隐私优先的个人知识管理系统,支持完全离线使用,同时也支持端到端加密同步。

    融合块、大纲和双向链接,重构你的思维。

    22376 引用 • 89569 回帖
  • Bug

    Bug 本意是指臭虫、缺陷、损坏、犯贫、窃听器、小虫等。现在人们把在程序中一些缺陷或问题统称为 bug(漏洞)。

    75 引用 • 1737 回帖 • 3 关注
  • QQ

    1999 年 2 月腾讯正式推出“腾讯 QQ”,在线用户由 1999 年的 2 人(马化腾和张志东)到现在已经发展到上亿用户了,在线人数超过一亿,是目前使用最广泛的聊天软件之一。

    45 引用 • 557 回帖 • 66 关注
  • 单点登录

    单点登录(Single Sign On)是目前比较流行的企业业务整合的解决方案之一。SSO 的定义是在多个应用系统中,用户只需要登录一次就可以访问所有相互信任的应用系统。

    9 引用 • 25 回帖