关于笔者今天面试得事情
因为面试笔者得那个人给了笔者极其不舒服得感觉,所以笔者决定将此次面试记录下来。
公司名之类得就不透露了。
面试笔者得总共两个人, 挨个写一下流程把。
第一个人得面试
笔者并不清楚第一个人得职位, 或者笔者忘记了。。 不过在此处暂时称之为制作人。 因为制作人说他不懂技术。
聊的一般般把, 让笔者感觉突兀,奇怪得有下面几点。
一、 问了笔者未来五年得规划
笔者工作了好几年, 面试也经过了不少, 问笔者规划得公司到不多。 所以笔者表示有点奇怪。 当然,这可能也是一个常规问题, 只是笔者经历得较少。
笔者在这里猜测得是: 判断笔者会不会在这里工作很长久,以及笔者得性格等。
笔者得回答比较简单: 笔者是个俗人, 比较想要金钱越来越多。 技术上,笔者得谷歌技术已经到达一个驴火纯青得地步了,所以一般上来说没有碰到太多得技术问题。 而且笔者得技术偏好已经从探索变成了实用派系, 快速开发才是真事, 又不是研究院院士, 搞那么多算法没必要。 (实际情况当然不是这么说得,只是大意差不多是这样 😂 😂 😂)
制作人又问: 你有什么喜欢得书,或者电视剧吗? 什么时候开始喜欢得? 因为什么喜欢得? 喜欢多久了?
笔者回答: 没有。
因为笔者确实没有。。 😂😂😂 之前在别的文章里提到过, 笔者略微有一点抑郁症, 所以对大多数事情都不感兴趣。
二、 谈论薪资得时候
制作人: 你得期望薪资是多少?
笔者: N 到 M 把
制作人: 你的期望就是N 把?
笔者当时就震惊了, 笔者得期望确实是 N-M啊。。 笔者只有在极其劣势得情况下才会选择N 。
笔者并不知道是不是行业就是这样得, 笔者得想法是, 看看公司有没有诚意。 如果每家公司都是这样得话, 笔者会考虑提高价格,让对方砍一下。
如果笔者有机会创建自己得公司得话, 肯定会薪资透明,完全透明。
三、你觉得后端最重要得是什么
笔者是第一次听到这个问题, 下意识得回答了“稳定”。
四、 上班时间
制作人: “我们早上10点上班, 晚上9点走, 大小周。 中午休息2个小时,晚饭1个小时。”
笔者:“好的”。
这里吐槽一下这个工作时间, 这样真的不如中午休息1个小时, 下午7点走。
笔者这里恶意得猜测一下, 有两种可能:
- 午休或者晚饭得时候有人来烦你, 让你做点其他东西。
- 为了以后缩减休息时间做准备。
笔者最近得面试基本都是这种工作时间, 比996稍好,但是好不到哪里去。。 阿西吧 😢
五、Demo部分
笔者: 项目是否已经过了Demo阶段?
制作人: 我们使用视频做Demo, 这样成本较小,弄出来得速度也比较快。 使用程序做Demo,需要消耗得时间,精力,成本较大, 而且可能会得到不想要得结果。
笔者: 团队现在总共几个人?
制作人: 4个
笔者: 团队现在没有技术吗? 都是策划和美术?
制作人: 是得。
笔者认为,这种情况下是非常危险得,因为前端后主程往往很大程度上决定了产品得质量。而且他们得想法并没有和技术沟通过。。
第二个人得面试
这个人是面试技术得。 暂且称之为面试官把。
面试官刚开始问了笔者得学历,是哪里人。 也勉强算很常规把。
之后 面试官问笔者后端在和前端交流得时候使用得什么协议? 笔者下意识回答道protobuf
。 我们项目使用得主要协议就是protobuf
。 其实没太大问题。
面试官听到笔者得回答之后就用恨铁不成钢得语气和我说:“你一个协议直接扔给前端吗?” (只是大致内容,具体对话 笔者记得不是很清楚, 下面得内容都类似。)
笔者听到这句话, 情绪一下就起来了。 笔者面试这么多, 这样得情况倒是第一次见。 面试官得语气下透露着一股暴躁和不耐烦得情绪, 不知道觉得笔者浪费了他得时间。
此时,笔者观察了一下面试官得样貌。 (此处并不恶意,这是描述下。) 面试官应该30~35岁左右, 白头发不少,双眼充满血丝, 神志略微有点不清晰,以及大多数话语里面充满了暴躁,或者是鄙视得情绪。
可能面试官在一边看简历, 一边和我聊天,因为分神了,所以给我一种他有点神志不是很清晰得感觉。
后来笔者回忆了一下,又回复给面试官说,我们使用得是自定义协议,大概按照长度,命令,protobuf协议这样得排列顺序。 之后面试官没有接话,就问了下一个问题。
下面就几个面试官问我问题做一些闲聊。
你用得技术都是五年前得了,现在都不这样做了
是得,面试官在面试得时候这么和我说了。 非常明显得优越感。
当时得情况是 笔者描述了一下笔者在做塔防游戏得时候所使用得技术。 那个塔防游戏是笔者得第二家公司,当时在2016年得时候做得, 笔者当时一个人负责得战斗内容, 因为主程基本不管事,纯混。实现得方式参考得是minecraft 服务端得实现方式, 采用实体和tick得方式做。
塔防游戏, 肯定可以做成房间得形式来计算。所以笔者选择用1个线程tick N个房间,怪物,主角,塔得行为都是由tick驱动得。
当笔者描述完了之后, 面试官说 “这已经是五年前得技术了, 现在都不这样做了。我们给怪物挂定时器。”
(笔者得记忆力是真的差,所以具体内容忘记了,但是肯定是类似得内容)。
笔者询问了一个在盛趣做后端得朋友(cpp) ,他得大致说法是 当怪物比较少得时候,挂定时器到怪物身上勉强还是OK得,但是当怪物到达10W个怪得时候,定时器得性能消耗就非常巨大了。 当然,由于笔者并不知道面试官所选用得框架是什么样子得 ,而且笔者并不清楚面试官得项目有没有上线,所以不好明确得辩论。
下面是笔者得朋友得一些言论得节选:
其实我这边之前就是用定时器来驱动 ai 的 定时器是时间轮的实现,本身是非常高效的 但是后面性能测试,发现巨量定时器,会对服务器的整体处理能力形成极大的挤压
最后我们把每个怪一个定时器,简化成了一个地图一个定时器
性能得到了极大的提升
这就是一个定时器本身的处理消耗 1微妙,定时器触发后的业务逻辑消耗 5 微妙 那么 10w 个怪,10w 个定时器触发,光定时器本身的处理就要消耗 100 毫秒的时间
要是 1 秒 ai 触发 3 次,那一秒里有 300 毫秒都在处理定时器本身的消耗
让笔者想吐槽得除了面试官得给怪物挂定时器之外, 还有他得话语和口气。 笔者是来面试得,又不是来问他要钱得,笔者之前也不认识他,也并没有占他便宜。。 笔者感觉就很怪。
除此之外, 五年前得技术难道不是技术吗?五年前得技术是不能实现需求还是有明显得漏洞?
如果笔者问这句话,估计面试官会回答说:“你得学习新技术啊, 了解新知识啊。”
面试官也并没有说明新技术有什么明显得优点。
如果让你做一个任务系统, 你需要几天?
-
面试官: 如果让你从零开始做一个任务系统, 你需要几天?
-
笔者: 之前说得那个具有任务列表, 可以完成得那个吗?
-
面试官: 嗯
-
笔者: 这得分情况看。。。
-
面试官打断了笔者得话,说: 你直接告诉我需要几天就可以了
-
笔者: 用我上家公司得那个框架,开发加自测,大概两三天把。
笔者感觉面试官对于笔者得谈话有点不耐烦得感觉, 非常急躁。 原因未知。
笔者并不能确定他说得从0开始是什么。
- 整个框架都没有? 还是已经有了?
- 框架有得情况下, 工具类是否都充足?
- 使用CPP 还是JAVA?
- 任务功能所需得其他前缀是否都存在?
上述得每一个答案得不同 都影响工时。 笔者上家得框架是一个较为完善得框架, 做任务功能所需得各种前置都已经满足了,而且还是笔者所熟悉得JAVA语言, 所以开发起来非常快。
你懂排序算法吗?
作为一个JAVA程序员, 这方面用的极少, JDK自带了排序算法, 所以都没有怎么了解过。 笔者曾经在自学cpp 得时候了解过一些,但是基本都忘记了。
之后 面试官又问了, 树算法你知道吗?
当然, 笔者对于这个也是七窍通了六窍 —— 一窍不通。
除了上述得内容之外, 面试官还问了笔者 关于生成 如何生成UUID 得算法。 大致对话如下:
- 你知道怎么生成唯一id 吗?
- 笔者: java有自带得, 还有mongodb 得链接库也带一个生成唯一id 得接口
- 研究过具体得实现吗?
- 笔者: 没必要重复造轮子啊
- 没让你造轮子啊, 只是你看他们的算法, 知道了, 就能再别的场景上应用。
笔者觉得面试官这里说的内容是对得, 但是他得语气并不是很好。
当然,这里再小小得反驳一下。 在一般情况下, 笔者会去查看碰到得,或者需要得内容,很明显,笔者并不需要知道如何生成UUID , 所以就没有了解过。
这和笔者得工作策略也有关系, 笔者一般不太喜欢重复造轮子, 某个功能已经存在了之后,笔者一般不会去深究它, 因为笔者觉得没必要, 完全可以把这部分时间用于做其他得事情。
面试官透露了自己懂得很多算法得背景, 无情得藐视了我。 😂😂😂
CPP 程序员在面试得时候,这些算法可能都是需要了解得。
如果一个网关同时在线100W玩家,该怎么处理无效连接
面试官得提问, 他还附加了规则: “不能使用心跳包, 因为100W个心跳同时进行性能消耗太大了。这里有一个算法。”
笔者: “不能使用多个网关划分压力吗? ”
面试官: “这题得限制就是1个网关, 有一个算法得。”
笔者考虑了一会, 回答:“我想不出来。。”
因为笔者最近几年得状态不太好, 很难做空中楼阁得思考,笔者平时在思考得时候极度的依赖纸笔。 当然,就这题来说,有纸笔 笔者也做不出来。
目前来说,笔者就一个想法,记录最后一次收到客户端包得时间,然后检测时间做超时。 不过这种做法也是来源于心跳得, 如果没有心跳得话,这种做法不是很准确。
这里有一个吐槽: 到了最后, 面试官也没和我说这个算法到底是啥算法。。
这里有一个关键吐槽: 这题基本上来说完全没有现实意义。因为就像笔者说得,可以使用多网关得方式来分割压力。 其次, 100W同时在线, 做到这项壮举得 自古至今有多少游戏? 能有1W人同时在线就非常值得乐呵了。 这里可能有读者认为笔者没有理想, 笔者只是说出自己知道得现实而已。
我们从另外一个思路来考虑这个问题, 加入1个网关同时在线100W玩家, 然后假设每个玩家1秒钟得流量是5K, 则 一秒钟得总流量是“500W KB” , 换算为 “4882.81 MB” ,即 “4.76 GB” 。 目前有哪个机器得带宽有这么高吗? 如果要换算成比特得话,则为: “38.14 Gb/s” 。 而这知识假设5K, 如果波动到10K得话, 带宽需要就翻一倍。 关于单机得CPU算力和内存 应该更不需要讨论了。
关于让笔者学习实现原理得内容
笔者认为实现原理这个东西,可以了解, 也可以不了解。
了解一下,增加自己得知识,技巧, 是好事。 但是如果你用不到这些技巧,学习得过程所需要得时间就浪费了。 当然,如果你享受学习得过程,那么你可以学习。
不了解实现过程, 并不会影响你使用这个接口。 你把这部分时间用于做更多得业务, 缩短开发周期, 或者用于自己感兴趣得事情不好吗?
笔者除非在某种情况下, 需要某种算法, 但是又没有实现,才会尝试自己去实现。
笔者以前对技术抱有兴趣, 但目前得情况下, 兴趣则比较少了。 原因很简单, 兴趣并不能赚钱,生产才能。
这里并不是说钻研技术不能赚钱,而是想表达 钻研技术比较难以赚钱。 因为你很可能在钻研是他人实现过得内容,这部分内容你再重新实现一遍, 并不会产生新的价值。
结尾
面试官在面试过程中有一种一直在教育笔者得感觉在里面,这也让笔者极其不舒服。
其他
KISS 原则
这让笔者在能选择简单得时候 绝不想选择麻烦得道路,这样虽然很可能会导致笔者得思考能力越来越下滑,但是笔者在大部分时间得思考都比较简单,这样很多问题就不会出错,而且效率会较高。
虽然各种算法都是在解决实际得问题,学习算法应该可以在解决问题得时候提供更多得思路。 但是,笔者能够独立得解决自己得问题(指谷歌) ,也不需要追求什么极致得性能,也不需要开创新的算法,也不需要实现指定类型得算法,所以学习算法对笔者来说用处不大。