字节跳动Android三面凉凉,面试资料分享

缘起

随着互联网企业的不断发展,产品项目中的模块越来越多,用户体验要求也越来越高,想实现小步快跑、快速迭代的目的越来越难,还有应用之间的互相调用等等问题,插件化技术应用而生。如果没有插件化技术,美团、淘宝这些集成了大量“app”的应用,可能会有几个g那么大。

所以,当今的Android移动开发,不会热修复、插件化、组件化,80%以上的面试都过不了。

阿里P8大佬每天熬夜到凌晨一两点,花了将近半个月时间将Android热修复框架、插件化框架、组件化框架、图片加载框架、网络访问框架、RxJava响应式编程框架、IOC依赖注入框架、最近架构组件Jetpack等等Android第三方开源框架整合成了一套系统知识笔记PDF,长达1042页!相信看完这份文档,你将会对这些Android第三方框架有着更深入、更系统的理解。

阿里

阿里的实习生招聘我参加了内推批次和正式批次一共两场。

阿里的内推批次和正式批次的时间是完全错开的,即在内推全部结束后才开始正式批次。需要注意的是,阿里主要部门(集团、菜鸟、蚂蚁等)的招聘几乎全部放在内推批次中,而正式批次绝大多数是非主要部门(高德、优酷土豆、虾米、钉钉等)的招聘。

阿里的内推没有统一的笔试,在内推成功后,马上就会收到素质测评和编程测验的通知。然而这两个测评其实并没有太大意义,做不做都会很快(一两天)就开始面试的。阿里内推批次的面试全都是电话面试。我在内推后的第二天就接到了一面的电话,部门是菜鸟/无线(记不清了)。

内推一面大概40分钟,主要问的计算机基础,如HTTP、TCP、并发、二叉树遍历、字符串匹配算法等,还让我简单介绍了我做的两个项目。因为我的其中一个项目做的APP中有调查问卷的发放和收集,所以问了我如何防止有人刷问卷;我回答说可以限制IP、记录设备唯一编号、监测做问卷模式等,但都存在一些漏洞。最后我问他Android开发过程中是不是会遇到很多兼容性问题,面试官回答说会遇到,还详细说了他们有专门的大规模真机测试来检查兼容性。一面总体上答的还行,几乎没有涉及到Android相关的问题;因为是电话面试,也就没问什么算法题。

内推一面两天后就接到内推二面电话了。二面大概50分钟,主要问了Java GC机制、Android APP启动过程、Android事件分发、Android View绘制流程。GC机制因为刚看过所以答的比较好,然而因为阿里面试开始太早,我还没来得及复习Android,所以Android相关的问题答的一塔糊涂,比如APP启动过程就支支吾吾乱说一气,View绘制流程干脆说不知道,跟面试官说我知道Android事件分发流程,于是事无巨细说了好长一串,最后被面试官吐槽根本不熟悉Android。最后问了面试官对国内手机厂商乱改Android Framework层有什么看法,面试官回答说他也很无奈,但阿里一般都和手机厂商有合作,直接进白名单,所以没有碰到太大问题。

内推二面后过了一周多才接到内推三面的电话,而且是在周末的晚上11点的时候。三面大概20多分钟,主要问了做过的项目、Java基础、最近看的书、到阿里想学到什么。我不太确定这轮面试是技术面还是HR面,因为是晚上11点和女票刚回到酒店完全不在状态,而且面试官也似乎很不耐烦,加上那段时间一直在准备技术方面的问题对这些HR面相关的问题完全没有准备,所以答的很啰嗦也很糟糕,好多都没有答到点子上。最后我问面试官我答的怎么样,面试官也没有说什么就急忙不耐烦挂电话了。

内推三面结束后就觉得应该是挂了,然后又等了一星期,官网上就从“面试中”变成“已回绝了”。

等到阿里正式批次开始的时候又投了正式批次,正式批次有统一的笔试,笔试用的阿里自己的系统;笔试内容记不清了,但一二十个选择题记忆深刻,好多超出Android相关知识的题目,好多做不出来的智力题。

正式批次的笔试似乎只有很少数的人通过了(主要是因为正式批次的岗位很少),幸运的是我也通过了,在官网预约面试时间后就开始准备视频一面了,面试的部门是钉钉(像之前说的,正式批次的部门都比较边缘)。

正式一面是视频面试,大概不到20分钟,是我实习秋招体验并列第二差的面试。主要问了Activity中能不能执行耗时操作(就是UI线程相关)、Android中有哪些内存泄漏的情况,然后就是共享屏幕写代码:实现单链表的插入删除和查找。为什么说体验非常差呢?首先整个面试就问了两个问题,而且这两个问题几乎任何有Android开发经验的都能对答如流,并且我回答完后就没有然后了,没有继续深入问;其次那个代码在数据结构教材上讲链表的时候一定会讲,而且也没有什么技术含量。最后面试官说还行,也没让我问他问题就结束了。

一天后官网状态就变成“已回绝”了,累觉不爱。

美团点评

美团点评也是很早就网申了,其实最初是找的师兄内推的,然而当时内推的岗位是后台开发,仔细想了想之后我又改成Android开发,于是就不是内推了(直到我笔试挂了才明白这个道理)。

之后就收到了美团点评的统一笔试,美团点评用的是北森系统,奇烂无比。笔试题目记不清了,最后有一个编程题,好像是求最长递增子序列,经典题目了。当时感觉笔试做的挺好的,然而笔试完就再也没有消息了,简直是黑人问号。

后来想了想可能是我当时网申的时候,选“感兴趣的事业群”选了“都感兴趣”导致没有一个事业群对我感兴趣,这个后面再说。

网易游戏

严格来说我投的是网易互娱(区别于雷火&盘古,后面再说更多区别),走的内推。网易游戏以其笔试难度大著名,这次也不例外;所有的内推都要求参加统一笔试,我记得笔试有几场,我是在第一场。内推的岗位是网易游戏最核心的“游戏研发工程师”,地点是杭州。

笔试用的牛客网平台,大大的赞。笔试一共四道编程题,一共150分钟,难度都很大,前三题用不到啥高深的算法,但需要想到解题的思路,最后一题是一个多重背包问题。笔试我一共过了三题半,因为最后一题不知道为啥内存超限了,用的primary int和动态规划,理论上是不会内存超限的。做完笔试题几乎就有把握能进面试了,当时预感能做出两题就能进面试,后来发现好多人只做出了一题就进面试了。

网易游戏实习生招聘很神奇的是整个就一轮面试,HR面是不存在的。面试是视频面试,用的牛客网平台,大概面了一个小时多一点。面试主要就是把计算机四大专业课轮番问了一遍,问了Java语言基础,最后还问了一个算法题。

四大专业课问的也就是那些基础问题,不过有些地方问的很深,基础的像问到了各种排序算法的最好、平均、最坏时间复杂度、线程和进程的区别、cache工作原理、计算机网络七层模型;问的深的像问到了进程中有多少个栈、线程中有多少个栈、阻塞是指进程阻塞还是线程阻塞、一台服务器上TCP和UDP监听端口号能不能相同、服务器80端口和客户端建立连接后会不会切换端口等。

Java语言基础这里有个小插曲,面试官没想到我不会C/C++(因为岗位介绍里面有写要会C/C++,但五个要求里只要求满足任意两个就可以投递)只会Java和Python,于是他就只好问了一些Java语言基础的问题,比如Integer和int的区别、GC的工作过程等;还问了Python的装饰器的原理,我就说了说面向切面编程相关的;最后面试官觉得不问C/C++不行,然后问我知不知道C/C++里的虚函数,被我一口回绝了。最后问了一个字符串循环移动的算法题,算是一个经典题目了,直接口头说三次翻转就好了。

最后问了面试官说岗位介绍里要求会C/C++,但我看招聘网站介绍里有提到Python,实际中是用哪些语言呢?面试官说C/C++主要用在游戏引擎那块,开发主要还是会用Python。虽然整个下来有些题没有答上来或者答错了,但整体来看还是答的很好的,反正对我来说已经发挥到极限了。面试完就感觉这个offer基本要到手了。

等了两周多才收到了网易游戏的offer,但也算是我实习生招聘收到的第一个offer,也是很有分量的一个了,自此我的实习生招聘就有底气了。

最后

本文在开源项目腾讯文档已收录,里面包含不同方向的自学编程路线、面试题集合/面经、及系列技术文章等,资源持续更新中…

目前已经更新的部分资料,需要的自取:



-y4uUwCWI-1620894034678)]
[外链图片转存中…(img-W6AqiWrc-1620894034683)]

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 好的,我会尽力回答你的问题。 以下是一个示例MySQL存储过程,用于批量生成业务数据并关联多个表。该存储过程需要传递复杂的参数,并解释了代码的每个部分。 ``` DELIMITER $$ CREATE PROCEDURE `generate_data`(IN start_date DATE, IN end_date DATE, IN num_records INT) BEGIN DECLARE i INT DEFAULT 1; DECLARE j INT DEFAULT 1; WHILE i <= num_records DO INSERT INTO orders (customer_id, order_date) VALUES (FLOOR(RAND()*100), DATE_ADD(start_date, INTERVAL FLOOR(RAND()*(DATEDIFF(end_date, start_date)+1)) DAY))); SET @order_id = LAST_INSERT_ID(); INSERT INTO order_details (order_id, product_id, quantity) VALUES (@order_id, FLOOR(RAND()*10)+1, FLOOR(RAND()*10)+1); WHILE j <= FLOOR(RAND()*4)+1 DO INSERT INTO order_comments (order_id, comment) VALUES (@order_id, CONCAT('Comment ', j)); SET j = j + 1; END WHILE; SET i = i + 1; SET j = 1; END WHILE; END$$ DELIMITER ; ``` 这个存储过程被称为“generate_data”,它需要三个输入参数: - `start_date`:生成订单的起始日期 - `end_date`:生成订单的结束日期 - `num_records`:要生成的订单数量 存储过程使用了两个变量 `i` 和 `j`,它们都被初始化为 1。`i` 变量用于跟踪当前订单的数量,`j` 变量用于跟踪当前订单的评论数量。 存储过程使用 `WHILE` 循环来生成订单,直到达到指定的 `num_records` 数量为止。在循环体内,存储过程使用 `RAND()` 函数来生成随机的客户 ID、产品 ID、数量和日期。 首先,存储过程将订单插入到 `orders` 表中,其中包含 `customer_id` 和 `order_date` 字段。然后,存储过程使用 `LAST_INSERT_ID()` 函数来获取最近插入订单的 ID。 接下来,存储过程将订单详情插入到 `order_details` 表中,其中包含 `order_id`、`product_id` 和 `quantity` 字段。存储过程使用 `RAND()` 函数来生成随机的产品 ID 和数量。 最后,存储过程使用 `WHILE` 循环来插入订单评论,直到达到一个随机数量为止。评论被插入到 `order_comments` 表中,其中包含 `order_id` 和 `comment` 字段。 在循环结束时,存储过程将 `i` 和 `j` 变量重置为 1,以准备生成下一个订单。 ### 回答2: 下面是一个示例的MySQL存储过程,满足批量造业务数据的需求,并涉及多个表的关联操作,包含一些复杂的参数。 ``` DELIMITER $$ CREATE PROCEDURE generate_business_data( IN num_rows INT, IN start_date DATE, IN end_date DATE ) BEGIN DECLARE i INT DEFAULT 1; DECLARE rand_cust_id INT; DECLARE rand_product_id INT; DECLARE rand_order_id INT; WHILE i <= num_rows DO SET rand_cust_id = FLOOR(RAND() * 1000) + 1; SET rand_product_id = FLOOR(RAND() * 100) + 1; SET rand_order_id = FLOOR(RAND() * 10000) + 1; INSERT INTO customers (id, name, email) VALUES (rand_cust_id, CONCAT('Customer ', rand_cust_id), CONCAT('customer', rand_cust_id, '@example.com')); INSERT INTO products (id, name, price) VALUES (rand_product_id, CONCAT('Product ', rand_product_id), RAND() * 100); INSERT INTO orders (id, customer_id, product_id, order_date) VALUES (rand_order_id, rand_cust_id, rand_product_id, DATE_ADD(start_date, INTERVAL FLOOR(RAND() * DATEDIFF(end_date, start_date) + 1) DAY)); SET i = i + 1; END WHILE; END $$ DELIMITER ; ``` 这个存储过程名为`generate_business_data`,包含三个复杂的输入参数:`num_rows`表示要生成的数据行数,`start_date`和`end_date`表示订单日期的范围。 存储过程使用循环插入数据,每次循环生成一个随机的`rand_cust_id`、`rand_product_id`和`rand_order_id`。然后将这些随机值和其他数据插入到`customers`、`products`和`orders`三个表中。 循环的次数由`num_rows`指定,每次循环插入一行数据,直到满足指定的行数。 注意,这里的随机数生成使用了`RAND()`函数,并且根据具体表的范围进行了调整,保证生成的随机数在指定的范围内。 这个存储过程可以通过调用`CALL generate_business_data(100, '2022-01-01', '2022-12-31')`来生成100行具有随机值的业务数据,订单日期范围在2022年1月1日至2022年12月31日之间。 ### 回答3: MySQL存储过程是一种预先编译并存储在数据库服务器上的可重复使用代码块。下面是一个示例的MySQL存储过程,用于批量生成业务数据并关联多个表,入参复杂。 ```mysql DELIMITER // CREATE PROCEDURE generate_business_data(IN num_rows INT, IN start_id INT) BEGIN DECLARE i INT DEFAULT 0; DECLARE current_id INT; WHILE i < num_rows DO SET current_id = start_id + i; INSERT INTO table1 (id, name) VALUES (current_id, CONCAT('Name', current_id)); INSERT INTO table2 (id, address) VALUES (current_id, CONCAT('Address', current_id)); UPDATE table3 SET count = count + 1 WHERE id = current_id; SET i = i + 1; END WHILE; END // DELIMITER ; ``` 代码解释: 1. 首先,通过`DELIMITER //`和`DELIMITER ;`指示改变MySQL的分隔符,以便在存储过程中使用`//`作为结束符号。 2. 使用`CREATE PROCEDURE`语句创建一个名为`generate_business_data`的存储过程,该存储过程接受两个输入参数:`num_rows`表示要生成的数据行数,`start_id`表示起始的ID值。 3. 使用`DECLARE`语句声明两个变量:`i`用于循环计数,`current_id`用于生成当前的ID。 4. 使用`WHILE`循环,在每次迭代中生成业务数据并关联多个表。 5. 在循环内,首先根据`start_id`和循环计数计算当前的ID值。 6. 使用`INSERT INTO`语句向`table1`和`table2`表分别插入数据,`CONCAT`函数用于生成名称和地址。 7. 使用`UPDATE`语句更新`table3`表中指定ID的记录的计数值。 8. 在循环结束前,更新循环计数器`i`。 9. 使用`END WHILE`结束循环。 10. 使用`END //`结束存储过程代码块。 11. 最后,使用`DELIMITER ;`将分隔符重置为默认值。 通过调用存储过程`generate_business_data`并传递适当的参数,我们可以生成指定行数的业务数据,并且该数据会自动关联多个表。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值