Javaプログラマのインタビュー経験と提言、MySQLのHFソウル株式(推奨コレクション)
はじめに:
本稿では、また、MySQLの顔の質問の背後にあるいくつかを共有する私の同僚×××テスト高周波・高頻度の問題私は知識を持っているすべてを手助けしたいと考えて、お薦めのほか、面接の過程でいくつかの個人的な経験のいくつかの人々にインタビューしますああ、共有します
顔の質問開発者のための主な観客が、私は、MySQLのサービスおよびその他の操作、およびより多くのコンテンツを展開するために関連していない、誰もが患者の準備ができているとミネラルウォーターの種。
ビットMySQLを学ぶためのシステムのバーストする前に、いくつかの実用的な経験があり、面接やMySQL関連の記事を見る機会は、私は知識ほとんどが気づいた知識ではあるが、これらの質問のいくつかはよく自分自身に答えることがわかった、ではなく、シリーズ。
インタビューの経験と提案
再開配達
いくつかの方法でお届け、私たちは皆知っていると信じています。な優しさなど、ジョブサイトへのプログラマ一般的に垂直の配信は、BOSSはようにフックを引くと、まっすぐに募集しています。Zhaopinが良くなって、私たちのプログラマに適していない、あなたが知っています。また、彼らはリクルーター夢中ので、もしレッスンが血だったので、私は、気にしないようにしよう、大きな牛ではありませんので。だからあなたの履歴書やあなた自身のより信頼性の高い、または補間をキャストしてみてください。
インタビュー
私は町全体にあったので、それについての話ならば、私は、通常、インタビュー+ビデオインタビュー電話インタビューを受けているので、オンサイトのインタビューではなく、形式があります。
一般的には、面接のプロセスがあまりにも悪くはありません。自分自身を導入するには、まず、コンテンツの一部が自分の主な原因が何であるかを、自分の仕事の経験のいくつか、などに焦点を当てています。これは、事前少しで準備することができますが、同様裏書として行いませんが、特別に準備は必要ありませんが、それは真実ではありません。
1人の技術のインタビュー
平均同社は、技術的なインタビューは、より可能性の高いメーカーを丸め、2〜3面接テクニックを持っていますが、研究の各ラウンドの内容は、以下の、非常に一貫性のない独自の問題のいくつかのいくつかをされています。
1.1 Javaの基礎
この時点で、通常のような、Javaのいくつかの基本的な知識を問います
同期静的クラスとメソッドの違いは何ですか修飾
原則として基礎となるデータ構造、焼き直しポインタ衝突の過程をハッシュマップ
HashMapのスレッドの安全性の問題は、なぜ、このようなスレッド安全性の問題を持っています
ConcurrentHashMapのデータ構造、基本原理は、入れて、スレッドセーフかどうかを取得します
などNIO、BIO、などのJava IOのいくつかの要素は、
1.2 Javaの高度な機能
此时问到的问题一般包含JVM,多线程的一些内容,这块建议大家多看看源码,大致如下:
Java线程池的构造方法,里面参数的含义,以及原理
volatile和ThreadLocal解决了什么问题
CAS在Java中的具体实现
Java虚拟机的构成,以及一个Java对象的生命周期,还有堆栈和方法区中存储的内容
JVM的GC过程,包括一些实际问题的分析,比如说明一个现象,让你分析可能是什么原因会导致这样的问题,应该如何对JVM参数进行调优
synchronized和Lock的区别,以及底层实现原理
Full GC和Minor GC触发的条件
GC Roots的选择
jmap,jstat,jstack等的使用场景,MAT等
ClassLoader的加载过程
CountDownLatch、CyclicBarrier和Semaphore等
Java 8 的新特性等
1.3 数据库
这里的数据库包含两种,一种一般是MySQL,另外是NoSql数据库,包括Redis、MongoDB等。一般会问的问题有:
inner join和left join等的区别
SQL调优,explain,profile等
InnoDB和Myisam的区别
ACID
数据库的事务隔离级别,以及他们分别能解决什么问题
Redis的几种数据结构
Redis是单线程还是多线程
Redis的持久化
悲观锁和乐观锁的含义
最左前缀索引,索引的数据结构,聚簇索引等(这块还没搞明白)
1.4 框架
1.4.1 Spring
因为spring是我们常用的框架,所以这块的内容会问的比较多,也会比较细。
Spring的两大特性(IoC和AOP)
Spring的bean的生命周期
Spring是如何解决Bean的循环引用问题的
AOP的两种实现方式,以及两者的区别(这里其实使用了动态代理,具体动态代理分为两种,一种是JDK的动态代理,主要使用的是JDK的反射,还有一种是CGLib,两者区别可以自己搜索,文章比较多)
AOP一般的使用场景
Spring的事务原理
1.4.2 MyBatis
这块问到的比较简单些:
$和#的区别
MyBatis和Hibernate的区别
源码,一般问的比较少
1.4.3 Dubbo
因为平时自己用到了Dubbo,所以这块会有问到:
RPC的原理
Dubbo是如何完成远程调用的
Dubbo如何进行调优
Dubbo的通信协议
Dubbo是如何实现负载均衡的
1.4.4 ZooKeeper
ZK的使用场景
ZK的选举机制
ZK的节点类型
一致性Hash原理
1.5 数据结构和算法
这块的内容是基础,如果面试官怀疑你的能力,一般一会问到这部分内容,比如树的遍历、快速排序等。
1.6 linux
一般会问一些命令的使用,然后会举一个实际的场景,让你用命令去排查问题,这块自己不是很熟,需要尽快加强。
1.7 综合题
这块的题目,面试官一般会问的比较深入。比如如何设计一个抢购系统,String转Integer等,这部分需要考验的就是一个人的临场应变能力,以及在平时工作中系统设计能力的积累,以及考虑问题是否周到等。也有可能会对你简历上面写的系统的设计进行详细的询问,所以在你写简历的时候,千万不能把自己不熟悉的内容写上去,而且自己又讲不清,这样一般会被直接pass掉。
当然也会问一些常用的maven的命令,设计模式的题目(这部分问的比较多的就是单例模式)。
2 HR面试
这块一般会问一些离职原因,当然也会问一些平时工作中遇到的问题,自己是如何解决的。如果聊得好,这时候HR会跟你谈薪资。问到目前薪资的时候,我目前是实事求是的告知的。这里,可能会有很多人报高一些,差不多的话,问题一般不大,如果太夸张的话,后续可能会有问题,比如让你提供银行流水等,差太多的话,可能会有诚信问题。
另外就是薪资涨幅的问题,我的原则是会事先对公司的规模这块进行考虑,然后结合目前的薪资,一般会设置一个范围(后来发现这样很不好,会处于被动),在当前薪资的基础上上浮30%的样子(可能各地有差异,不过这个会比较安全)。如果你很擅长谈这个,请忽略之。
此外,最重要的可能就是五险一金的缴纳了。一般小的公司会让你选择是避税还是不避税,这里面还是有点学问的。避税的话,可能你的公积金会很少。目前我遇到过两种,一种是每个月按照固定的额度给你交公积金,不论你以后的工资是否上涨,都跟公积金没有关系;还有一种是按照一个额度给你交,一般是工资的7%给你交,或者按照最低标准给你交。遇到这种情况,请自己慎重考虑是否需要接收offer。
最后,福利这块也可以问问,比如问一些年终奖,年假,加班调休等。
自己整理的一份俩百多页Java核心知识点PDF,有一说一这个核心知识宝典,可是给了我巨大的帮助,帮我斩获了很多的offer,这份pdf知识点可以分享给大家×××某人 资料即可免费领取
面试题
主要包括索引,事务,优化等方面,以在面试中高频的问句形式给出答案.
索引相关
关于MySQL的索引,曾经进行过一次总结,文章链接在这里 Mysql索引原理及其优化.
1. 什么是索引?
2. 索引是个什么样的数据结构呢?
3. Hash索引和B+树所有有什么区别或者说优劣呢?
4. 上面提到了B+树在满足聚簇索引和覆盖索引的时候不需要回表查询数据,什么是聚簇索引?
5. 非聚簇索引一定会回表查询吗?
6. 在建立索引的时候,都有哪些需要考虑的因素呢?
7. 联合索引是什么?为什么需要注意联合索引中的顺序?
8. 创建的索引有没有被使用到?或者说怎么才可以知道这条语句运行很慢的原因?
9. 那么在哪些情况下会发生针对该列创建了索引但是在查询的时候并没有使用呢?
事务相关
1. 什么是事务?
2. ACID是什么?可以详细说一下吗?
3. 同时有多个事务在进行会怎么样呢?
4. 怎么解决这些问题呢?MySQL的事务隔离级别了解吗?
5. Innodb使用的是哪种隔离级别呢?
6. 对MySQL的锁了解吗?
7. MySQL都有哪些锁呢?像上面那样子进行锁定岂不是有点阻碍并发效率了?
表结构设计
1. 为什么要尽量设定一个主键?
2. 主键使用自增ID还是UUID?
3.なぜ要件フィールドがNOT NULLとして定義されて?
4.あなたは、フィールドがストレージに使用する必要があり、ユーザーのパスワードハッシュを保存したい場合は?
ストレージエンジン関連
1.どのようなMySQLのストレージエンジンをサポートしていますか?
散乱問題
1. MySQLのvarchar型、および差はあるもののchar。
2. VARCHAR(10)とINT(10)の意味は何ですか?
3. MySQLのバイナリログいくつかのエントリの形式があります?違いは、それぞれ何ですか?
4.大ページングどのように対処するには?
5.それを消費するSQL内部の業務システムを気に?統計スロークエリとにかく?クエリを最適化する方法が遅い上?
6.上記横方向と縦方向のパーティションテーブルパーツテーブル、それらは適切な差の例を与えることができますか?
7.ストアドプロシージャとは何ですか?長所と短所は何ですか?
3つのパラダイム約8話
#9. MyBatisの
読者の福祉
上記の顔の質問については、私は、ドキュメントアーキテクチャと誰もが(ダボ、Redisの、ネッティー、飼育係、春の雲を含むビデオ素材を共有するための無料を作った顔面接の質問と回答のほとんどに関与インターネット企業のJavaプログラマを総括しました、分散、並行性の高いアーキテクチャ技術情報)、あなたの前のインタビューをレビューし、良い仕事を見つけるのに役立つことを期待して、だけでなく、あなたの情報をオンライン学習を検索するための時間を節約できます。彼らの学習を強化するために自分の時間の毎分の使用の合理化は、彼のイデオロギーの怠惰を非表示にするには、「何時間」を使用しないでください!
アクセス:簡単なデータのコンパイル×××の人が無料で入手することができます。上記の文書はまた、ああPDFを必要としています