当前位置: 首页 > 编程日记 > 正文

java mongodb存base64_阿里JAVA面试分享经验【文末有福利】

基础篇

  • 参考这里的面试题:面试题写在后面了

能回答上百分之七十,基础的广度就算OK了。如果达不到,那么缺什么就赶紧补什么。广度达到了,还需要对个别热点问题有深度。每个人的精力都有限,可以适当挑选两个热点问题进行深入挖掘。比如HashMap,要不仅仅能够说上来源码是什么去实现的,还要了解JDK1.7版本到1.8版本都做了哪些改进,为什么这么改进,ConcurrentHashMap怎么实现的,针对并发场景都做了哪些优化措施,JDK1.7和1.8的实现有什么差异。了解这些可能需要花费很大精力。但是,面试的时候一但问到了这个你非常精通的知识点,就基本进入你的主场了。这个能起到一锤定音的作用,给面试官留下极强的印象,甚至直接决定了此次面试的成败。因此,至少准备那么一两个非常精通的知识点,一定不要多,但要比面试官和其他求职者都要精通。这个赌的就是运气,只要在一个问题上能给面试官上一课,就能让对方产生“你很厉害”的错觉。

所有基础知识都要做好笔记,面试前多回顾下,在配合刷下题,问题就不大了。

项目篇

要回答好项目问题,核心就是要提前做好充足的准备。首先,仔细回顾自己做过的项目。然后挑选最有价值的部分,写一篇关于这个项目的总结性文档,要讲清楚这个项目的架构,设计思路。其次是努力回想当时遇到的难点,踩过的坑,以及自己怎么思考和应对的,还有对项目后续改进的思考。这个非常重要,一定写下来。文档写出来后,还要反复提炼和补充。面试的时候就以此文档为纲领,方能做到侃侃而谈,从容应对。

情商篇

面试的时候,可能会穿插一些考察性格的问题。比如,问你为什么离职/想换工作,对技术和业务怎么看,对我们公司有什么了解,对我们的业务有什么了解,你有什么想问我的,你觉得自己有什么优点/缺点。做技术的同学往往在情商方面有所欠缺,如果没有准备的话,面试时一不小心说错一句话就可能导致前功尽弃。尤其在阿里,HR是有一票否决权的。 那么,应对此类问题的第一点就是提前预防,可以提前拿张纸,猜想对方可能会问的问题,把标准答案写出来,反复推敲,然后背下来即可。比如,“你觉得自己有什么优点”这个问题,我当时的标准答案就是,“我觉得人最难了解的就是自己,所以我想借用我前领导对我的评价,XXX是个......的人”。我的这个标准答案是基于 “第三方的评价更有可信度” 这个原理来设计的。第二点,回答问题的时候表现的谦虚一点即可,而且千万不要有负能量。比如“为什么离职/想换工作”,这个问题,不要去吐槽公司或者同事,或者表达情绪上的不满。要尽量展现出自己好学上进的一面,这一点很重要。面试官会把对你的印象记录在案的,包括你的优点和缺点。因此即便技术达不到要求,也尽量展现性格上的优点。

阿里面试流程

面试一般是四到五面,以电话面试为主。最后一轮面试时HR面试,所以只要挺过前面的技术面试一般就OK了。第一轮是考察基础,第二轮开始考察项目,沟通表达能力。第三四轮会可能有编程,要求现场写代码,或者线下完成一个指定的项目。面试官的级别在p6-p9之间,一般随着面试流程的推进而升高。技术面试通过后就是HR面了,这一轮主要考察价值观。所有面试结束后,就是一个漫长的等待了,期间会有体检,背景调查,然后发offer。这个流程会有一个月的时间,比较久。需要注意的是,面试过程中一定要保证诚实,不能有半点弄虚作假。因为一但背景调查的时候发现说谎了,不但offer会取消,还会记录到人才库里。再有一点,约好了的面试不能随意爽约,这个也会永久记录。你的每次面试的过程都会详细的记录在人才库里的,因此尽量不要留下污点,以免影响以后的面试。

面试题

本人是做java开发的,这是我参加58,搜狐,搜狗,新浪微博,百度,腾讯文学,网易以及其他一些小的创业型公司的面试常被问的问题,当然有重复,弄清楚这些,相信面试会轻松许多。

1. junit用法,before,beforeClass,after, afterClass的执行顺序

2. 分布式锁

3. nginx的请求转发算法,如何配置根据权重转发

4. 用hashmap实现redis有什么问题(死锁,死循环,可用ConcurrentHashmap

5. 线程的状态

5. 线程的阻塞的方式

6. sleep和wait的区别

7. hashmap的底层实现

8. 一万个人抢100个红包,如何实现(不用队列),如何保证2个人不能抢到同一个红包,可用分布式锁

9. java内存模型,垃圾回收机制,不可达算法

10. 两个Integer的引用对象传给一个swap方法在方法内部交换引用,返回后,两个引用的值是否会发现变化

11. aop的底层实现,动态代理是如何动态,假如有100个对象,如何动态的为这100个对象代理

12. 是否用过maven install。 maven test。git(make install是安装本地jar包)

13. tomcat的各种配置,如何配置docBase

14. spring的bean配置的几种方式

15. web.xml的配置

16. spring的监听器。

17. zookeeper的实现机制,有缓存,如何存储注册服务的

18. IO会阻塞吗?readLine是不是阻塞的

19. 用过spring的线程池还是java的线程池?

20. 字符串的格式化方法 (20,21这两个问题问的太低级了)

21. 时间的格式化方法

22. 定时器用什么做的

23. 线程如何退出结束

24. java有哪些锁?乐观锁 悲观锁 synchronized 可重入锁 读写锁,用过reentrantlock吗?reentrantlock与synmchronized的区别

25. ThreadLocal的使用场景

26. java的内存模型,垃圾回收机制

27. 为什么线程执行要调用start而不是直接run(直接run,跟普通方法没什么区别,先调start,run才会作为一个线程方法运行)

28. qmq消息的实现机制(qmq是去哪儿网自己封装的消息队列)

29. 遍历hashmap的三种方式

30. jvm的一些命令

31. memcache和redis的区别

32. mysql的行级锁加在哪个位置

33. ConcurrentHashmap的锁是如何加的?是不是分段越多越好

34. myisam和innodb的区别(innodb是行级锁,myisam是表级锁)

35. mysql其他的性能优化方式

36. linux系统日志在哪里看

37. 如何查看网络进程

38. 统计一个整数的二进制表示中bit为1的个数

39. jvm内存模型,java内存模型

40. 如何把java内存的数据全部dump出来

41. 如何手动触发全量回收垃圾,如何立即触发垃圾回收

42. hashmap如果只有一个写其他全读会出什么问题

43. git rebase

44. mongodb和hbase的区别

45. 如何解决并发问题

46. volatile的用途

47. java线程池(好像之前我的理解有问题)

48. mysql的binlog

49. 代理模式

50. mysql是如何实现事务的

51. 读写分离何时强制要读主库,读哪个从库是通过什么方式决定的,从库的同步mysql用的什么方式

52. mysql的存储引擎

53. mysql的默认隔离级别,其他隔离级别

54. 将一个链表反转(用三个指针,但是每次只发转一个)

55. spring Aop的实现原理,具体说说

56. 何时会内存泄漏,内存泄漏会抛哪些异常

57. 是否用过Autowire注解

58. spring的注入bean的方式

59. sql语句各种条件的执行顺序,如select, where, order by, group by

60. select xx from xx where xx and xx order by xx limit xx; 如何优化这个(看explain)

61. 四则元算写代码

62. 统计100G的ip文件中出现ip次数最多的100个ip

63. zookeeper的事物,结点,服务提供方挂了如何告知消费方

64. 5台服务器如何选出leader(选举算法)

65. 适配器和代理模式的区别

66. 读写锁

67. static加锁

68. 事务隔离级别

69. 门面模式,类图(外观模式)

70. mybatis如何映射表结构

71. 二叉树遍历

72. 主从复制

73. mysql引擎区别

74. 静态内部类加载到了哪个区?方法区

75. class文件编译后加载到了哪

76. web的http请求如何整体响应时间变长导致处理的请求数变少,该如何处理?用队列,当处理不了那么多http请求时将请求放到队列中慢慢处理,web如何实现队列

77. 线程安全的单例模式

78. 快速排序性能考虑

79. volatile关键字用法

80. 求表的size,或做数据统计可用什么存储引擎

81. 读多写少可用什么引擎

82. 假如要统计多个表应该用什么引擎

83. concurrenhashmap求size是如何加锁的,如果刚求完一段后这段发生了变化该如何处理

84. 1000个苹果放10个篮子,怎么放,能让我拿到所有可能的个数

85. 可重入的读写锁,可重入是如何实现的?

86. 是否用过NIO

87. java的concurrent包用过没

88. sting s=new string("abc")分别在堆栈上新建了哪些对象

89. java虚拟机的区域分配,各区分别存什么

90. 分布式事务(JTA)

91. threadlocal使用时注意的问题(ThreadLocal和Synchonized都用于解决多线程并发访问。但是ThreadLocal与synchronized有本质的区别。synchronized是利用锁的机制,使变量或代码块在某一时该只能被一个线程访问。而ThreadLocal为每一个线程都提供了变量的副本,使得每个线程在某一时间访问到的并不是同一个对象,这样就隔离了多个线程对数据的数据共享。而Synchronized却正好相反,它用于在多个线程间通信时能够获得数据共享)

92. java有哪些容器(集合,tomcat也是一种容器)

93. 二分查找算法

94. myisam的优点,和innodb的区别

95. redis能存哪些类型

96. http协议格式,get和post的区别

97. 可重入锁中对应的wait和notify

98. redis能把内存空间交换进磁盘中吗(这个应该是可以的,但是那个面试官非跟我说不可以)

99. java线程池中基于缓存和基于定长的两种线程池,当请求太多时分别是如何处理的?定长的事用的队列,如果队列也满了呢?交换进磁盘?基于缓存的线程池解决方法呢?

100. synchronized加在方法上用的什么锁

101. 可重入锁中的lock和trylock的区别

102. innodb对一行数据的读会枷锁吗?不枷锁,读实际读的是副本

103. redis做缓存是分布式存的?不同的服务器上存的数据是否重复?guava cache呢?是否重复?不同的机器存的数据不同

104. 用awk统计一个ip文件中top10

105. 对表做统计时可直接看schema info信息,即查看表的系统信息

106. mysql目前用的版本

107. 公司经验丰富的人给了什么帮助?(一般boss面会问这些)

108. 自己相对于一样的应届生有什么优势

109. 自己的好的总结习惯给自己今后的工作带了什么帮助,举例为证

110. 原子类,线程安全的对象,异常的处理方式

111. 4亿个int数,如何找出重复的数(用hash方法,建一个2的32次方个bit的hash数组,每取一个int数,可hash下2的32次方找到它在hash数组中的位置,然后将bit置1表示已存在)

112. 4亿个url,找出其中重复的(考虑内存不够,通过hash算法,将url分配到1000个文件中,不同的文件间肯定就不会重复了,再分别找出重复的)有1万个数组,每个数组有1000个整数,每个数组都是降序的,从中找出最大的N个数,N<1000

113. LinkedHashmap的底层实现

114. 类序列化时类的版本号的用途,如果没有指定一个版本号,系统是怎么处理的?如果加了字段会怎么样?

115. Override和Overload的区别,分别用在什么场景

116. java的反射是如何实现的


欢迎大家关注一个技术公众号作者

关注下方微信公众号

回复【架构】 即可领取学习资料!【先关注公众号回复即可获取】

1121e2066e6bb052e14acab38728d5d1.png

作者十余年Java经验,曾任职于1号店、大众点评、同程旅游、阿里系公司,担任过技术总监、首席架构师、team leader、系统架构师。有着多年的前后台大型分布式项目架构经验,在处理高并发、性能调优上有独到的方法论。精通Java、J2EE架构、Redis、MongoDB、Netty,消息组件如Kafka、RocketMQ。

格言:没有什么做不了的,只有想不到的。回复【架构】 即可领取学习资料!

相关文章:

win7/8SVN必备的4个服务

为什么80%的码农都做不了架构师&#xff1f;>>> 最近刚刚学会用vpn&#xff0c;某次用某软件加速系统后svn不能用了&#xff0c;反复查看&#xff0c;发现是Event Log的原因。所以和大家分享一下SVN必备的4个系统服务。 Windows Event Log Secure Socket Tunneling…

Spark集群部署(standLone)模式

安装部署&#xff1a; 1. 配置spark为1个master&#xff0c;2个slave的独立集群&#xff08;Standlone&#xff09;模式&#xff0c; 可以在VMWare中构建3台运行Ubuntu的机器作为服务器&#xff1b; master主机配置如下&#xff1a; vim /etc/hostname 编辑此文件&#xff0c;设…

读书:一百个 终身受益的 思维模型(持续更新)

《第二曲线》 刻意练习 金字塔原理

map 小模板~~~ 写的不好 继续添加

#include<map>#include<string.h>#include<iostream>using namespace std;int main(){ ///map插入 map<string,int> mp; ///<key值 val值> mp["a"]1; mp["b"]2; mp["c"]3; map<string,int…

为什么二级菜单会被挡住_二级建造师为什么这么难考?2021年二建考试也会很难吗?...

2020年二建考试难到上热搜&#xff0c;广大考生被难到怀疑人生&#xff0c;老考生一副"我看透你了"的过来人嘴脸&#xff0c;新考生只能在角落瑟瑟发抖。随着2020年二建考试逐渐落幕&#xff0c;2021年二建备考被提上日程&#xff0c;许多考生心中也逐渐产生疑问&…

Nginx与PHP(FastCGI)的安装、配置、优化

一、什么是 FastCGIFastCGI是一个可伸缩地、高速地在HTTP server和动态脚本语言间通信的接口。多数流行的HTTP server都支持FastCGI&#xff0c;包括Apache、Nginx和lighttpd等&#xff0c;同时&#xff0c;FastCGI也被许多脚本语言所支持&#xff0c;其中就有PHP。FastCGI是从…

Cobbler-自动化部署神器

Cobbler-自动化部署神器 前言&#xff1a; 网络安装服务器套件 Cobbler(补鞋匠)从前&#xff0c;我们一直在做装机民工这份很有前途的职业。自打若干年前 Red Hat 推出了 Kickstart&#xff0c;此后我们顿觉身价倍增。不再需要刻了光盘一台一台地安装 Linux&#xff0c;只要搞定…

Linux系统性能分析: I/O栈 优化

原始文件路径Mind-mapping Linux I/O栈性能分析及优化

[转]优化Flash性能

原文&#xff1a;http://www.adobe.com/devnet/flash/articles/optimizing-flash-performance.html 翻译&#xff1a;http://bbs.9ria.com/thread-156860-1-1.html 在这篇文章中&#xff0c;你会学到优化Flash Professional应用性能的策略。优化过程包括编辑你的FLA工程文档确保…

python 自动填充表单,如何在Django / Python中自动填充PDF表单?

I have PDF forms that I want to autopopulate with data from my Django web application and then offer to the user to download. What python library would let me easily pre-populate PDF forms? These forms are intended to be printed out.解决方案Reportlab is g…

模拟宽度自适应的输入框

看代码&#xff1a; !DOCTYPE HTML><html><head><meta http-equiv"Content-Type" content"text/html; charsetutf-8"><style type"text/css"> h2 { margin:0; padding:10px 0; font-size:14px; } .mod-retweet { bac…

洛谷 - P1426 - 小鱼会有危险吗 - 模拟

https://www.luogu.org/problemnew/show/P1426 题目说的是小鱼进入探测器一秒后就会有危险&#xff0c;所以不应该让小鱼先游&#xff0c;而是先检测探测器。 #include<bits/stdc.h> using namespace std; #define ll long longint s,x;int main(){scanf("%d%d"…

Linux系统性能分析:内存 优化

整体的内存基本原理和内存性能指标、性能瓶颈分析以及优化思路可参考如下导图 原始xmind文件路径Mind-Mapping

zoj 1010 (线段相交判断+多边形求面积)

链接&#xff1a;http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemId10 AreaTime Limit: 2 Seconds Memory Limit: 65536 KB Special JudgeJerry, a middle school student, addicts himself to mathematical research. Maybe the problems he has though…

军用软件概算计价规范_工程造价五算:估算、概算、预算、结算、决算

估算、概算、预算、结算、决算估算即投资估算。是在决策阶段就建设项目建设总投资进行的科学估计。决策阶段又分为机会研究、项目建议书、初步可行性研究、详细可行性研究四个阶段&#xff0c;随着项目逐步的细化具体化&#xff0c;按照投资估算规程&#xff0c;可以得到不同精…

openssh配置终极一帖

一、什么是opensshOpenSSH 是 SSH &#xff08;Secure SHell&#xff09; 协议的免费开源实现。SSH协议族 可以用来进行远程控制&#xff0c; 或在计算机之间传送文件。而实现此功能的传统方式&#xff0c;如telnet(终端仿真协议)、 rcp ftp、 rlogin、rsh都是极为不安全的&a…

读书:历史 -- 海上丝绸之路

罗德里希普塔克 — 德国汉学家 海上丝路连结了古代世界贸易往来&#xff0c;见证了中华文明在人类历史中的枢纽位置。 王权集中的朝代中每一个流传后世的国家层级的决策无不彰显国家机器得强壮&#xff0c;但同样也很脆弱&#xff0c;决策者不可能时刻都能做出最为正确得选择。…

一.Linq to JSON是用来干什么的?

Linq to JSON是用来操作JSON对象的.可以用于快速查询,修改和创建JSON对象.当JSON对象内容比较复杂,而我们仅仅需要其中的一小部分数据时,可以考虑使用Linq to JSON来读取和修改部分的数据而非反序列化全部. 二.创建JSON数组和对象在进行Linq to JSON之前,首先要了解一下用于操作…

add python3.7 to path是什么意思_一起读源码:为什么 loguru 的时间 rotation 不能只精确到天...

摄影&#xff1a;产品经理猪耳朵与鹌鹑蛋做的皮蛋今天的问题来自未闻 Code 粉丝交流群&#xff1a;“loguru 每天自动生成的日志名字&#xff0c;可以只精确到日吗&#xff1f;”如下图所示&#xff1a;这里的每天自动生成日志的名字是什么意思呢&#xff1f;实际上指的就是rot…

hdu 4263(有限制的生成树)

题目链接&#xff1a;http://acm.hdu.edu.cn/showproblem.php?pid4263 思路&#xff1a;将红边和蓝边单独求一次生成树&#xff0c;求的红边最多可以加入的边数cntr&#xff0c;蓝边最多可以加入的边数cntb&#xff0c;只要k满足条件k>(n-1-cntr)&&k<cntb&#…

Synchronized的两个用法

Synchronized的作用&#xff1a; 能够保证在同一时刻最多只有一个线程执行该段代码&#xff0c;以达到保证并发安全的效果 Synchronized的两个用法&#xff1a; 1&#xff09;对象锁 包括方法锁&#xff08;默认锁对象为this当前实例对象&#xff09;和同步代码块锁&#xff08…

h5引入不同的js文件怎样让第二个js使用第一个js文件中的函数_px2rem-loader使用及注意事项...

1.安装lib-flexible.js&#xff1b; //基于vue-cli配置手淘的lib-flexible rem&#xff0c;实现移动端自适应2.安装px2rem-loader&#xff1b;//使用 webpack 的 px2rem-loader,自动将px转换为rem3.在项目入口文件main.js中引入lib-flexible&#xff1b;//&#xff08;import …

C++中的explicitkeyword

在C程序中非常少有人去使用explicitkeyword&#xff0c;不可否认&#xff0c;在平时的实践中确实非常少能用的上。再说C的功能强大&#xff0c;往往一个问题能够利用好几种C特性去解决。但略微留心一下就会发现现有的MFC库或者C标准库中的相关类声明中explicit出现的频率是非常…

Entity Framework Code First在Oracle下的伪实现

为什么要说是伪实现&#xff0c;因为还做不到类似MsSql中那样完全的功能。Oralce中的数据库还是要我们自己手动去创建的。这里&#xff0c;我们舍掉了Model First中的EDMX文件&#xff0c;自己在代码里面写模型与映射关系&#xff0c;这又有点像是Code First模型了&#xff0c;…

leetcode-206 反转链表

描述如下&#xff1a; 反转一个单链表。 示例: 输入: 1->2->3->4->5->NULL 输出: 5->4->3->2->1->NULL 方法一&#xff1a;原地反转 数据结构如下 struct ListNode {int val;ListNode *next;ListNode(int x) : val(x), next(NULL) {}};ListN…

ios采用什么技术_在不锈钢技术成熟的今天,为什么汽车不采用呢?不仅仅是价格问题...

文/憨憨评车想必对于那些经常开车的人都会知道&#xff0c;我们的车子在行驶了几年之后&#xff0c;在性能方面必定是会有所下降的。然而还有一点也是非常让人头疼的&#xff0c;那就是车子的生锈问题。一旦车子的车身出现生锈情况的话&#xff0c;就会给人一种破破烂烂的感觉。…

Effective STL 为包含指针的关联容器指定比较类型

// 为包含指针的关联容器指定比较类型.cpp : 定义控制台应用程序的入口点。 //#include "stdafx.h" #include <set> #include <string> #include <iostream>using namespace std;struct StringPtrLess:public binary_function<const string*…

Android中处理崩溃异常

2019独角兽企业重金招聘Python工程师标准>>> 大家都知道&#xff0c;现在安装Android系统的手机版本和设备千差万别&#xff0c;在模拟器上运行良好的程序安装到某款手机上说不定就出现崩溃的现象&#xff0c;开发者个人不可能购买所有设备逐个调试&#xff0c;所以…

python面试基本题(你需要的)

1、冒泡排序 lis [56,12,1,8,354,10,100,34,56,7,23,456,234,-58]def sortport():for i in range(len(lis)-1):for j in range(len(lis)-1-i):if lis[j] > lis[j1]:lis[j],lis[j1] lis[j1],lis[j]return lis 2、计算x的n次方的方法 def power(x, n):s 1while n > 0:n …