上一篇 我在华为OD的275天 最后说,要讲讲自己为什么会坚持在年底离职,以及离开后去了哪儿。趁周末,鸽王本鸽来交下作业

1 - 为什么要在年底离职

1.1 惊觉:没有什么成长

20年11月初的一天,在同事们讨论“又有某某某被其他公司高薪挖去了,钱景无限”的消息,我忽然惊觉,自己来到华为半年多,除了熟悉内部的系统和流程,好像没有什么成长和进步?

只有大佬才会被挖,停止成长、进步缓慢的我,现在这个状态,值几个钱?

1.2 投简历,敲打自己

意识到自己应该抓紧时间学习提升,刚好也想起了之前的一个同事,在离职的聚会上分享的经验:

技术人不能闭门造车,要多交流,多看看外面的动态。

如果感觉自己太安逸了,那就把简历挂出去,去了解其他公司用的是什么技术,他们更关注哪些痛点?面几次你就有方向了。

为了鞭策自己(让面试官的狂虐来刺激自己),更好地制定学习方向,我重新下载了某聘软件,在首页推荐里投了几家公司。

1.3 面试它来了

11月10号(星期二)投的简历,当天就有2家预约了11号下午的线上面试。(对,其中就有鹅厂)

好巧不巧,10号晚上要双十一保障,一直到第二天凌晨2点半才下班。

熬夜太伤身,还好能申请调休一天,也省去了找借口请假


这段时间总共面了3家:

一家广州的公司11号当晚就完成了2轮线上面试,开得有点低,而我从深圳返回广州的成本有点高,就婉拒了;

第二家就是本文的重点——鹅厂;

第三个是做跨境电商的公司,一面就跪(恭喜它荣升为“我有限的工作经历中,面试体验最差的2家公司之一”)

1.4 提前触到目标?

一直有一个大厂梦,奈何菜鸟一枚,之前试过好几次,都跪在技术面了。

所以想了个曲线救国的方法:先在其他单位积累着,有机会了再争取大厂的机会

很幸运,也很猝不及防,这次竟然通过了鹅厂的所有面试。

虽然已到年底,但是要是错过这么难得的机会,下次就不知道什么时候才能再通关了。

所以,年底离职 vs 鹅厂 Offer,我选择了后者

2 - 我的鹅厂面试

如本文标题所说,16天的时间,我经历了五轮面试,在第17天,如愿收到了渴盼已久的 Offer。

做技术的同学,可能会对鹅厂的面试很好奇,他们都会问哪些问题呢?

本人主要编程语言是 Java,应聘的是大数据开发岗位,这里对我经历过的通用问题做个梳理,也给想来鹅厂的同学们一个参考

几乎所有问题都能在网络上找到很详细的答案,鉴于篇幅有限,这里只列举题目和一些引申的问题。

2.1 技术一面

Java 语言相关

1、对 Java 的类加载器有没有了解?如何自定义类加载器?

引申:一个类能被加载多次吗?java/javax 包下的类会被加载多次吗?

2、Java 中要怎么创建一个对象?

3、对多线程有了解吗?在什么场景下需要使用多线程?

引申:对 线程安全 的认识;对线程池的了解,以及各个线程池的适用场景。

4、对垃圾回收的了解?

5、对 JVM 分代的了解?

6、NIO 的了解?用过 RandomAccessFile 吗?

引申:对 同步、异步,阻塞、非阻塞 的理解?

多路复用 IO 的优势?

7、ArrayList 和 LinkedList 的区别?各自的适用场景?

8、实现一个 Hash 集合,需要考虑哪些因素?

引申:JDK 对 HashMap 的设计关键点,比如初识容量,扩所容,链表转红黑树,以及 JDK 7 和 JDK 8 的区别等等。

通用学科相关

1、TCP 的三次握手;

2、Linux 的常用命令,比如:

ps aux / ps -ef、top C
df -h、du -sh *、free -g
vmstat、mpstat、iostat、netstat

项目框架相关

1、Kafka 和其他 MQ 的区别?它的吞吐量为什么高?

消费者主动 pull 数据,目的是:控制消费节奏,还可以重复消费;

吞吐量高:各 partition 顺序写 IO,批量刷新到磁盘(OS 的 pageCache 负责刷盘,Kafka 不用管),比随机 IO 快;读取数据基于 sendfile 的 Zero Copy;批量数据压缩……

2、Hive 和 SparkSQL 的区别?

3、Ranger 的权限模型、权限对象,鉴权过程,策略如何刷新……

问题定位方法

1、ssh 连接失败,如何定位?

是否能 ping 通(DNS是否正确)、对端端口是否开了防火墙、对端服务是否正常……

2、运行 Java 程序的服务器,CPU 使用率达到 100%,如何定位?

ps aux | grep xxxjps 命令找到 Java 的进程号 pid

然后用 top -Hp pid 命令查看其阻塞的线程序号,将其转换为16进制

再通过 jstack pid 命令跟踪此 Java 进程的堆栈,搜索上述转换来的16进制线程号,即可找到对应的线程名及其堆栈信息……

3、Java 程序发生了内存溢出,如何定位?

jmap 工具查看堆栈信息,看 Eden、Old 区的变化……

2.2 技术二面

二面主要是过往项目相关的问题,有少量的基础问题和一面有重复,这里略去不表。

1、Solr 和 Elasticsearch 的区别 / 优劣?

2、对 Elasticsearch 的优化,它的索引过程,选主过程等问题……

3、项目中遇到的难题,如何解决的?

blabla 还有一些大数据相关的内容,记不太清了

2.3 技术三面

这一面是总监面,更多是个人关于职业发展的一些想法,以及在之前公司的成长和收获、对下一份工作的期望等问题。

但也问了几个技术问题。印象比较深的是这道题:

1TB 的大文件,每行都只是1个数字,无重复,8GB 内存,要怎么对这个文件进行排序?

首先想到的是 MapReduce 的思路,拆分小文件,分批排序,最后合并。

此时连环追问来了:

Q:如何尽可能多的利用内存呢?

A:用位图法的思路,对数字按顺序映射。(对映射方法要有基本的了解)

Q:如果在排好序之后,还需要快速查找呢?

A:可以做索引,类似 Redis 的跳表,通过多级索引提高查找速度。

Q:索引查找的还是文件。要如何才能更多地利用内存呢?

A:那就要添加缓存了,把读取过的数字缓存到内存中。

Q:缓存应该满足什么特点呢?

A:应该使用 LRU 型的缓存。

呼。。总算是追问完了这道题


还有 GM 面和 HR 面,问题都和个人经历相关,这里就略去不表。

3 - 文末的絮叨

入职鹅厂已经1月有余。不同的岗位,不同的工作内容,也是不同的挑战。

感受比较深的是,作为程序员,还是要自我驱动,努力提升个人技术能力,横向纵向都要扩充,这样才能走得长远。

对了,最后广告下,有想要加入鹅厂、或者有疑问的同学,可以留言,或关注公众号加我好友,我尽力给你解答

16天5面,我终于拿到了鹅厂Offer的更多相关文章

  1. 鹅场offer已Get,下周签约,终于能静下心来总结总结

    2015年9月20号下午,接到腾讯总部的电话,确定了offer相关信息,算是正式get了鹅场的offer,坐等下个周一周二的签约会. 心路篇 2015年2月:已经2月份了,自己在大学的时光已经来到了比 ...

  2. 记一次前端面试~终于拿到理想中的offer!

    2019年已经过去一半,终于拿到一直想去的公司offer,也算是实现了今年的一个小目标. 由于这家公司是我从去年到现在最想去的公司,本次换工作一直没有投,希望先积累下面试经验再投. 没有想到居然先在b ...

  3. 5面终于拿到了字节跳动offer! 鬼知道我经历了啥...

    坐标北京,某211本科毕业生,之前学校活动有去过字节跳动公司总部参观,所以一直以来就蛮想进入字节工作的,被字节的企业文化和工作氛围所影响.字节作为发展速度最快的互联网公司,旗下的很多产品的用户都比肩B ...

  4. 面试 16:栈的压入压出队列(剑指 Offer 第 22 题)

    我们今天继续来看看周五留下的习题: 面试题:输入两个整数序列,第一个序列表示栈的压入顺序,请判断二个序列是否为该栈的弹出顺序.假设压入栈的所有数字均不相等.例如:压入序列为{1,2,3,4,5},那{ ...

  5. 新鲜出炉!凭借着这份面试宝典,我终于拿下了字节跳动的offer!

    前言 我做Java也十来年了,现在也算是中层管理,每次招聘都需要找一些面试题,干脆自己整理了一份,这份面试宝典是从我 去年开始收集的,一方面是给公司招聘用,另一方面也是想用它,来挖掘自己在 Java ...

  6. 化学专业大二转战Android开发,终于拥有了鹅厂暑期实习offer

    我是双非学校,应用化学专业,一年前我大二,现在我大三.一年前我两手空空,现在我拥有了鹅厂暑期实习的offer. 虽然结果是好的,但我春招实习的道路远没有这么简单和辉煌,它是无比坎坷的:每个人应该量力而 ...

  7. 【Android实习】20场面试斩获大厂offer,我学会了什么

    前言 很高兴遇见你~ 先说一下笔者春招实习的情况:从三月初到四月半,经历了近20场面试,一共面试了五家企业,通过了腾讯.字节.蚂蚁.美团的面试,虎牙在一面之后拒了二面邀请. 金三银四,笔者不是在面试中 ...

  8. 2017 年的 人生 hard 模式终于结束了,2018年回归初心

    2017 年的 人生 hard 模式终于结束了,2018年回归初心 2017年对于我个人来讲, 毫不夸张的说 算是近十年来除了高考那一年,最最惊心动魄的一年了,没有之一. >>>开篇 ...

  9. 2017 年的 人生 hard 模式终于结束了,2018年回归初心(二)

    今天周末, 深圳的天气简直好的不像话.好了,我们继续之前的话题往下聊. >>>猎头 : 关于猎头这个行业,以笔者的感觉来说 一般你工作年限未超过三年的话,你是很难遇到猎头来推送你的简 ...

随机推荐

  1. js 必须为字母或下划线, 一旦创建不能修改

    <div class="form-group"> <label class="col-lg-2 control-label" for=&quo ...

  2. LeetCode150 逆波兰表达式求值

    根据逆波兰表示法,求表达式的值. 有效的运算符包括 +, -, *, / .每个运算对象可以是整数,也可以是另一个逆波兰表达式. 说明: 整数除法只保留整数部分. 给定逆波兰表达式总是有效的.换句话说 ...

  3. Openstack Ocata 公共服务端(三)

    Openstack Ocata 公共服务端 mysql 安装: yum install mariadb mariadb-server mysql 安装过程省略 rabbit-server 安装包: # ...

  4. MySQL的CURD 增删改查

    添加 insert 语法: 单条:insert into 表名('字段1', '字段2', ...) values('值1', '值2', ...) 多条:insert into 表名('字段1', ...

  5. 腾讯QQ,人人都是高手

    今天,腾讯果然给出了官方回应,具体表述如下: 可能你看不太懂,其实我也看的不太懂,不过这就是公关的能力体现,就像我"人人都是高手"的大连车务组微机室小编一样,把一个降级flash描 ...

  6. Over Permission - Pikachu

    概述: 如果使用A用户的权限去操作B用户的数据,A的权限小于B的权限,如果能够成功操作,则称之为越权操作. 越权漏洞形成的原因是后台使用了不合理的权限校验规则导致的. 一般越权漏洞容易出现在权限页面( ...

  7. 1.8V转5V电平转换芯片,1.8V转5V的电源芯片

    1.8V是一个比较低的电压,在电压供电电压中,1.8V电压的过于小了,在一些电子模块或者MCU中,无法达到供电电压,和稳压作用,PW5100就是可以在1.8V转5V的电平转换电路和芯片,最大可提供50 ...

  8. 利用JavaUDPSocket+多线程模拟实现一个简单的聊天室程序

    对Socket的一点个人理解:Socket原意是指插座.家家户户都有五花八门的家用电器,但它们共用统一制式的插座.这样做的好处就是将所有家用电器的通电方式统一化,不需要大费周章地在墙壁上凿洞并专门接电 ...

  9. Bagging和Boosting的介绍及对比

    "团结就是力量"这句老话很好地表达了机器学习领域中强大「集成方法」的基本思想.总的来说,许多机器学习竞赛(包括 Kaggle)中最优秀的解决方案所采用的集成方法都建立在一个这样的假 ...

  10. kubernetes用户权限管理工具permission-manager

    Permission Manager Permission Manager是一个为Kubernetes RBAC和用户管理提供Web UI的项目,为Kubernetes权限管理提供友好的可视化界面. ...