热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

孙玄达叔:年薪75万的真实技术面试实践攻略(篇章二)

文章目录1、解决问题能力2、沟通与协作能力3、成长潜力4、文化匹配度5、彩蛋孙玄:毕业于浙江大学,现任转转公司首席架构师,技术委员会主席&


文章目录

  • 1、解决问题能力
  • 2、沟通与协作能力
  • 3、成长潜力
  • 4、文化匹配度
  • 5、彩蛋


孙玄:毕业于浙江大学,现任转转公司首席架构师,技术委员会主席,大中后台技术负责人(交易平台、基础服务、智能客服、基础架构、智能运维、数据库、安全、IT 等方向);前58集团技术委员会主席,高级系统架构师;前百度资深研发工程师;


【架构之美】微信公众号作者;擅长系统架构设计,大数据,运维、机器学习等技术领域;代表公司多次在业界顶级技术大会 CIO 峰会、Artificial、Intelligence、Conference、A2M、QCon、ArchSummit、SACC、SDCC、CCTC、DTCC、Top100、Strata+、Hadoop World、WOT、GITC、GIAC、TID等发表演讲,并为《程序员》杂志撰稿 2 篇。



1、解决问题能力

在篇章一中,我们聊了专业能力,今天我们来说说解决问题能力。我认为整体分为:设计能力、编码能力、问题排查能力,这三方面。

如果说专业能力主要是考察你的知识储备的话,那么解决问题能力,则是考察你灵活运用专业知识的能力。

假设面试官问到,如何设计一个 XX 功能 / 服务 / 系统,这时候,篇章一文章介绍的 BeafQPS 方法论就派上用场了。不仅要实现功能和业务,还要准确的识别出功能 / 服务 / 系统的难点,可能是需要高性能,或者需要高可用,或者需要高扩展,也可能是三者都要兼顾等等。过程中就体现了你的设计能力,既要有敏锐的洞察力,也要有结构化的全方位思考,以及可实操的落地方案。

以上,便是可以体现你设计能力的几个关键点。

下面,我们来说说编码能力,有不少工作经验较长的朋友,出去面试前,都不刷题,认为企业不会让自己写代码,这个侥幸心理不能有呀。现在越来越多的企业看重候选人的编码能力,有的团队,架构师甚至 TeamLeader,工作中也时常需要写代码。这里推荐大家面试前要至少把经典题目刷一下,比如二分查找、快速排序、反转链表、层序遍历二叉树、给定两数之和求下标、最近公共子节点、爬楼梯的算法等。

另外,比较务实的公司会考些工程类的题目,比如懒加载的单例模式、实现生产和消费的 demo、多线程交替打印有序数组、负载均衡算法等。还有的公司会考 SQL,需要把 join、group by having count、sum、avg 等用法复习一下,现在 leetcode 上也有 SQL 的题,可以刷两道找找感觉。也有的公司会考 Linux,需要把 awk、sed、sort、uniq 等关键命令熟悉下,典型题目是统计文本中出现次数最多的 ip。

最后,来说下问题排查能力,回答相关问题时,要先定位再修复。

先从监控和异常日志入手

如果是业务问题,那么可能是代码 bug 或者网络抖动造成的业务流程中断,也可能是某种原因造成的数据不一致,现象就是业务不正确或者业务不完整。

如果是系统问题,比如负载过高、内存不足、磁盘 io 过高、接口耗时变长、吞吐量降低等问题,需要借助 top、jstack、free、jmap、gcutil 等命令,以及 apm 监控和链路追踪系统,完成定位。定位之后,要给出短期和中长期的解决方案,比如负载过高,短期可以通过扩容机器来缓解,中长期可以去调整线程池参数,减少线程上下文切换次数、优化慢查询,防止请求堆积,消耗 cpu 和内存等。

再比如,发现是数据不一致导致的问题,短期的话,可以完善监控,并通过修复接口手动修数据;中长期的话,如果是主从延迟问题,可以核心链路强制读主库;如果是分布式事务问题,可以采取最大努力通知、事务消息、TCC、Seata 等解决方案。

解决问题能力,只靠积累专业知识是不够的,需要多实践,多总结。我平时在给来自各个公司技术核心人员授课时,都会很认真提到这一点,保持终身学习的态度,总是要持续保持优秀才好。

以上给大家介绍了五大考察点其中的专业能力和解决问题能力,接下来文章我们聊下剩余的三个考察点。


2、沟通与协作能力

如果说专业能力和解决问题能力是硬实力的话,那么接下来我们要讨论的就是软实力

首先,说下沟通与协作能力。

无论作为 leader 还是团队成员,我们都需要与很多同事一起工作,如果沟通与协作能力有问题的话,可能会降低团队的整体工作效率、影响团队的士气和氛围。因此,面试官也会观察候选人这方面的能力。

如何在平时提高沟通与协作能力,并在面试过程中,更好的体现出来呢?

很多内向的朋友可能会觉得这是一种天赋,与性格有关,自己不是那块料没法提高呀,我想说,因为大多数人的努力程度是非常低的,所以还远远没有到拼天赋的地步。建议这些朋友,抓住团建、聚会、吃饭、散步、打电话的时间,多与身边人交流聊天,久而久之,沟通能力一定会提高。这里也有个短期的特训技巧,去 app 商城搜一下“语音聊天”,试着下载两三个,每天与上面的陌生人聊 30 ~ 60 分钟,坚持一周,沟通能力就会有明显效果。

下面再说下协作能力,首先要有同理心,人无完人,我们不能用对家人和朋友的期望,来要求每一个同事、每一个面试官。比如面试官迟到了、或者说错话了、作为候选人,可以理解包容、恶劣情况下也要审时度势,权衡利弊,当然,必要时我们也要坚守自己的底线和原则。

另外,要补充的一点就是,很多较为高级的职位,工作职责都会包含日常指导初中级工程师、跨团队沟通、统筹协调、项目管理、团队管理等,因此越是工作经验丰富的朋友,越要注意提高自己的沟通协作能力。

面试过程中,不卑不亢、语速正常、注意抑扬顿挫,不要想机关枪一样,一个声调突突突,那样面试官会听的很累,抓不住重点。保持微笑,与面试官真诚的交流互动。沟通协作能力这块就会有个不错的分数。


3、成长潜力

好的,我们聊下一个考察点,成长潜力

企业招一个人的成本是很高的,尤其是高端岗位,企业一定不希望候选人入职待一年就走的,这样不利于团队的稳定性和梯队建设,也不利于企业的发展,因为新人入职的第一年,基本都在熟悉业务、系统、流程、团队等,真正做出重大贡献,往往要第二年才能开始。

因此,企业对候选人的成长性是有期望的,面试官会看,候选人过往的经历有没有在较短时间内,完成新业务或系统的熟悉,快速做出业绩的事例;也会看候选人,对自己做过的事情,有没有较为深刻的理解,是否善于发现问题,并提出解决方案以及执行落地。

典型的场景是,我们在描述完自己很拿手的项目之后,面试官问,这个项目有没有可以优化的地方?如果候选人能够脱口而出,把当前的问题,短期、中期、长期的规划,清楚的说出,就可以体现出很好的主动性,这也意味着成长潜力。

最近面试了一个同学,简历里写的项目,用到了限流的高可用手段,上面还写了具体用的是令牌桶算法,于是我就问,还了解其他的限流算法吗?他表示不清楚,由此可以初步判断,这位同学的主动性和成长潜力可能是一般的,这个例子,给我们的启示就是,工作中使用的技术,不要仅仅停留在使用层面上,也要去了解原理,深入细节,了解选型的原因,这体现了主动性,也体现了成长潜力。现在,我课堂上都会针对技术做架构逻辑、底层原理做很深入的讲解,大家都很喜欢


4、文化匹配度

下面我们再聊下文化匹配这个考察点。

通常这方面都是由主管、VP、HR 来考察的,有的面试官很坦诚,“我们这里加班很多,早 10 晚 10,996,你能接受吗?”,也有的会通过询问离职原因了解候选人的三观,面对这种问题,offer 收割机可以如实作答,因为面试也是双向选择;对于手上没有 offer 的朋友,可以适度修饰作答。

每个企业都有自己的使命、愿景和价值观,候选人面试前可以提前做好功课,如果顺利面到后面,适当的表达自己对企业文化的认可,会有很大加分的。

最后要说的是,面试攻略系列文章其实是属于标题党,功夫在于日复一日一点一滴的积累和思考,希望通过这一系列文章,能让大家对技术人的能力模型、思考框架,有个较为系统的认知。


5、彩蛋

大家认知里比较热门的基础知识,主要有编程语言基础、多线程、IO、缓存、数据库、各种组件与工具等等。
操作系统可以说是上面这些“基础知识”的基础知识了

学好操作系统,可以帮助我们更好的理解,运行在它上面的一些程序、软件、组件、工具等等,从而可以让我们更快的学习其他的新技术,因为他们的底层都汇聚在操作系统这一层,是相通的。

先来看下操作系统在维基百科的定义:

操作系统(英语:Operating System,缩写:OS) 是管理计算机硬件与软件资源的系统软件,同时也是计算机系统的内核与基石。操作系统需要处理如管理与配置内存、决定系统资源供需的优先次序、控制输入与输出设备、操作网络与管理文件系统等基本事务。操作系统也提供一个让用户与系统交互的操作界面。
如图 1,所示来方便大家的理解操作系统(以Linux 操作系统为例)。

在这里插入图片描述
可以很清楚的帮助大家理解操作系统与计算机软件(应用程序)和硬件的职责边界和层次结构。

在这里插入图片描述
图 2,则给大家展示了操作系统需要处理的一些基本事务:进程管理、内存管理、文件管理、网络操作、设备控制,以及操作系统内核的体系结构。现在请各位老铁闭上眼睛想下,什么是操作系统呢?操作系统能做哪些事情呢?

恭喜各位已经可以准确回答上这个问题了,同时也已经打开了操作系统学习之路的大门。

人生路漫漫,帮助我们走向人生巅峰的,一定是我们真实的能力。所以一起苦练基本功吧,记得关注和分享哦,后续会给大家提供更专业、更精彩的文章,包含专业知识与原理、架构设计、职场感悟、人生趣谈等内容。

期待与大家一起成长!


关注【架构之美】,与孙玄老师探讨更多深层次架构知识

在这里插入图片描述


推荐阅读
  • Android自定义控件绘图篇之Paint函数大汇总
    本文介绍了Android自定义控件绘图篇中的Paint函数大汇总,包括重置画笔、设置颜色、设置透明度、设置样式、设置宽度、设置抗锯齿等功能。通过学习这些函数,可以更好地掌握Paint的用法。 ... [详细]
  • SpringMVC接收请求参数的方式总结
    本文总结了在SpringMVC开发中处理控制器参数的各种方式,包括处理使用@RequestParam注解的参数、MultipartFile类型参数和Simple类型参数的RequestParamMethodArgumentResolver,处理@RequestBody注解的参数的RequestResponseBodyMethodProcessor,以及PathVariableMapMethodArgumentResol等子类。 ... [详细]
  • 本文介绍了P1651题目的描述和要求,以及计算能搭建的塔的最大高度的方法。通过动态规划和状压技术,将问题转化为求解差值的问题,并定义了相应的状态。最终得出了计算最大高度的解法。 ... [详细]
  • 判断数组是否全为0_连续子数组的最大和的解题思路及代码方法一_动态规划
    本文介绍了判断数组是否全为0以及求解连续子数组的最大和的解题思路及代码方法一,即动态规划。通过动态规划的方法,可以找出连续子数组的最大和,具体思路是尽量选择正数的部分,遇到负数则不选择进去,遇到正数则保留并继续考察。本文给出了状态定义和状态转移方程,并提供了具体的代码实现。 ... [详细]
  • [大整数乘法] java代码实现
    本文介绍了使用java代码实现大整数乘法的过程,同时也涉及到大整数加法和大整数减法的计算方法。通过分治算法来提高计算效率,并对算法的时间复杂度进行了研究。详细代码实现请参考文章链接。 ... [详细]
  • Go语言实现堆排序的详细教程
    本文主要介绍了Go语言实现堆排序的详细教程,包括大根堆的定义和完全二叉树的概念。通过图解和算法描述,详细介绍了堆排序的实现过程。堆排序是一种效率很高的排序算法,时间复杂度为O(nlgn)。阅读本文大约需要15分钟。 ... [详细]
  • This article discusses the efficiency of using char str[] and char *str and whether there is any reason to prefer one over the other. It explains the difference between the two and provides an example to illustrate their usage. ... [详细]
  • 模板引擎StringTemplate的使用方法和特点
    本文介绍了模板引擎StringTemplate的使用方法和特点,包括强制Model和View的分离、Lazy-Evaluation、Recursive enable等。同时,还介绍了StringTemplate语法中的属性和普通字符的使用方法,并提供了向模板填充属性的示例代码。 ... [详细]
  • 本文由编程笔记#小编整理,主要介绍了关于数论相关的知识,包括数论的算法和百度百科的链接。文章还介绍了欧几里得算法、辗转相除法、gcd、lcm和扩展欧几里得算法的使用方法。此外,文章还提到了数论在求解不定方程、模线性方程和乘法逆元方面的应用。摘要长度:184字。 ... [详细]
  • HashMap的相关问题及其底层数据结构和操作流程
    本文介绍了关于HashMap的相关问题,包括其底层数据结构、JDK1.7和JDK1.8的差异、红黑树的使用、扩容和树化的条件、退化为链表的情况、索引的计算方法、hashcode和hash()方法的作用、数组容量的选择、Put方法的流程以及并发问题下的操作。文章还提到了扩容死链和数据错乱的问题,并探讨了key的设计要求。对于对Java面试中的HashMap问题感兴趣的读者,本文将为您提供一些有用的技术和经验。 ... [详细]
  • java drools5_Java Drools5.1 规则流基础【示例】(中)
    五、规则文件及规则流EduInfoRule.drl:packagemyrules;importsample.Employ;ruleBachelorruleflow-group ... [详细]
  • 本文介绍了求解gcdexgcd斐蜀定理的迭代法和递归法,并解释了exgcd的概念和应用。exgcd是指对于不完全为0的非负整数a和b,gcd(a,b)表示a和b的最大公约数,必然存在整数对x和y,使得gcd(a,b)=ax+by。此外,本文还给出了相应的代码示例。 ... [详细]
  • 3.223.28周学习总结中的贪心作业收获及困惑
    本文是对3.223.28周学习总结中的贪心作业进行总结,作者在解题过程中参考了他人的代码,但前提是要先理解题目并有解题思路。作者分享了自己在贪心作业中的收获,同时提到了一道让他困惑的题目,即input details部分引发的疑惑。 ... [详细]
  • 摘要: 在测试数据中,生成中文姓名是一个常见的需求。本文介绍了使用C#编写的随机生成中文姓名的方法,并分享了相关代码。作者欢迎读者提出意见和建议。 ... [详细]
  • 本文讨论了Kotlin中扩展函数的一些惯用用法以及其合理性。作者认为在某些情况下,定义扩展函数没有意义,但官方的编码约定支持这种方式。文章还介绍了在类之外定义扩展函数的具体用法,并讨论了避免使用扩展函数的边缘情况。作者提出了对于扩展函数的合理性的质疑,并给出了自己的反驳。最后,文章强调了在编写Kotlin代码时可以自由地使用扩展函数的重要性。 ... [详细]
author-avatar
冰妞qb_424
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有