入职阿里不到一个月(新零售方向)对于社招java达到什么样的水平才能社招面进阿里?
Posted jinggege795
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了入职阿里不到一个月(新零售方向)对于社招java达到什么样的水平才能社招面进阿里?相关的知识,希望对你有一定的参考价值。
刚刚入职阿里不到一个月(新零售方向),所以还是比较清楚之前都准备了啥,部门也在招聘,所以问了下那些招聘的同事主要看什么点。对于社招,我之前做的准备有以下几个方面:
1.基本功:阿里主要是java方向的,那对jdk要比较熟练的理解和使用,重点内容有:集合,多线程,io,异常,反射,注解,序列化,反序列化等知识。其次就是网络和数据结构,网络至少要知道三次握手,四次分手,https,get,post等。数据结构有时候会问下红黑树,平衡二叉树吧。如果了解redis的,还可以聊下跳跃表,前缀树吧。操作系统问的不多,一般就是问下实际中有没有出现过cpu过高或者内存过高的情况,然后怎么定位解决。
2.中间件框架:现在这边也是基本spring那套,所以spring的常问题目要了解。比如启动过程,bean的初始化流程,bean的生命周期,如何解决循环依赖问题,ioc,aop等。 缓存,不论是redis或者是memcache或者其他的,至少要有一个比较熟练的,能了解底层数据结构及实现原理,常规的使用方法。数据库,这个就mysql或者Oracle要熟悉一种,数据库一般要知道分库分表的实现,数据库备份,数据库的事务,数据库和缓存的数据一致性,数据库的索引,锁机制等等。rpc 也是阿里这边比较使用多的一种,所以常用的rpc框架可以了解下,优缺点,rpc的原理要懂,如果有时间自己可以基于netty写一个实战一下。MQ也是一个重点知识,一般会问下消息的幂等性,事务性实现,如何保证不丢消息等,要熟练至少一种消息队列,了解原理。zk有时问有时不问,这个有时间也可以看下,毕竟这是分布式协调器,很多时候在分布式系统中都会使用zk来保证强一致性的问题。
3.设计题:这种一般会给定某个特定场景,让你去做,如果是架构设计,一般就是高并发。如果是数据库的设计,一般看你对数据怎么设计能够方便查询。
4.理论题:一般这种就是看你对现在一些常用的分布式理论的理解了。一致性协议,分布式cap,base理论,服务降级,熔断,restful接口等等。
5.项目:这是个重点,和我同事聊天发现,他如果觉得连自己做的项目都讲不清楚的话,基本就没希望过了,所以一定要想下自己做的项目,有什么难点,解决了什么问题,架构有什么调整,为什么这么做,最后的结果是什么。如果做的比较久,一般还是分几个阶段来描述,每个阶段的目标是什么,为什么这么做。这样会显得思路清楚一点。
6.手写代码:代码考核是进入每个大公司都需要准备的,所以这个就是要刷刷题,leetcod,有时间逛逛,你值得拥有。
其实每个公司面试都差不多,当然了,如果要面试更高的档次的话,一般还有你对行业的了解,对行业的看法。
下面是我给大家整理的Java重点面试题,有需要的小伙伴可以文末来获取资料~
一、Java面试问题
1. ArrayList 和 LinkedList 有什么区别?
第一:底层数组结构不同,ArrayList 是数组,LinkedList是双向链表。
第二:插入速度不一定谁快,因为ArrayList要扩容,LinkedList要创建节点,节点多了暂用内存,导致处理速度下降。
第三:角标查询ArrayList快。
2. volatile的理解?
特性1:内存可见性,缓存一致性协议(底层会锁内存行)来保证每个线程中的缓存信息是一致的。
特性2:有序性(指令重新排序,JVM在保证单线程下不会出现问题的情况下,会优化指令的执行顺序。比如创建一个对象(1.开辟内存空间,2.初始化,3.指向内存地址),可以先指向内存地址再初始化)。
3. as-if-serial和happens-before的语义理解?
4. for(;;) 和 while(true)的区别?
推荐使用for(;;), 因为通过汇编指令可以很明显的看出区别for(;;)是一条指令,while(true)是4条指令。
5. 如何实现一个独占锁?
第一步通过CAS判断是否存在锁,不存在返回ture,存在将新的线程加入队列中并且设置park 等待。
第二步当占用资源的锁使用完成,需要通过队列里面的线程进行unpark操作去执行。
6. main函数所在类是通过什么类加载器加载的?
7. 不同的类加载器加载相同的类,相等吗,为什么?
答:不相等,因为不同加载器加载类后存放的地方是隔离的,虽然都在方法区。举例就像存在在两个list 集合一样的道理。
8. Jvm 中存在哪些常量池?
答:
1. class中的常量池:class文件中的,类名,方法名,字段等一些信息。
2. 动态常量池:Java对象中的常量池信息,载入常量池,存储在元空间(方法区)。
3. 字符串常量池:存放字符串的,在堆区。
9. this指针是何时被赋值的?
答:执行引擎在执行带有操作数的字节码指令时,会有一个构造运行环境的过程。this指针就是在构造运行环境过程中实现的。不完全对象会被复制一份,这一份就是用于被this指向。
10. JDK8,什么样的对象会进入老年代?
答:
15次GC:最多就是15次,因为存储字段只有4bit。
大对象:对象超过Eden区的一半。
空间担保:GC后的Eden区对象大小超过Form区加To区,直接进入老年代。
动态年龄判断:Eden区+From区GC后,To区放不下,直接进入老年代。
11. 创建的对象是否只会存在堆区,为什么?
答:不是,存在栈上分配的情况。 Jvm在逃逸分析开启的情况,存在连续创建对象的时候,会有对象不创建在堆区,会创建到虚拟栈上。
12.Java堆内存最大允许多少,为什么?
答:开启指针压缩的情况下:32G。
原因:对象头中的类型指针指向的就是对象引用变量在方法区的地址,通过这个地址可以找到整个对象的全部内容在内存中位置。
类型指针在开启指针压缩的情况下,占用4个字节即32位,2的32次方就是4G,类型指针最大可以存在4G内存的位置。 又因为每个对象在开启指针压缩的情况下,最后3位000会被去掉。 所以实际4个字节可以表示 2的35次方-2的3次方的最大内存地址,即32G内存的最大位置。
因为现在都是64位机器了,那么如果电脑或者服务器的内存超过32G内存,在开启指针压缩的情况下就是出现找不到内存地址情况。
如果在开启指针压缩下优化这个问题,可以将Java对象的8字节对齐改成16字节对其,甚至32字节对其。这个能表示的内存最大值就是64G,128G了。
二、Java Spring框架面試問題
1. Spring Bean的生命周期?
2. Spring 容器的生命周期?
3. @Autowired 的作用??
三、Java分布式面试问题
1. Zookeeper和redis分布式锁有什么区别
答:
单机下:首选redis分布式锁,因为redis是基于内存的所以比Zookeeper快很多(redis键与键之间没有必然联系,zookeeper需要保证执行顺序)。
集群下:
redis因为不保证强一致性,所以还是加锁快,但是在脑裂的情况下会出现多个节点获取同一把锁。
Zookeeper保证了强一致性,所以加锁满,但是因为保证数据一致性,所以不会出现脑裂的情况下会出现多个节点获取同一把锁的情况。
2. Redis是单线程还是多线程
答:Redis是多线程的。 redis4.0在多核CUP下实现了多线程。
redis为什么不需要多线程,原因是redis是基于内存实现的缓存功能,他的性能瓶颈在内存和网络,Redis6.0实现了网络这块的多线程。
四、Java工程师面试问题目录大全
因为篇幅过长,今天就给大家先分享这么多吧,其实还有很多进大厂必刷的面试题。
有需要的朋友帮小编点赞转发文章,关注小编后下方扫码获取~
让更多需要学习的小伙伴看到,关注小编可以省去很多整理资料的时间,带你轻松进大厂~
以上是关于入职阿里不到一个月(新零售方向)对于社招java达到什么样的水平才能社招面进阿里?的主要内容,如果未能解决你的问题,请参考以下文章
学历不是问题!社招大专老哥参加了阿里/腾讯/京东面试上岸入职京东