0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

到底怎样才能成长为一名软件教练呢

华为开发者社区 来源:华为开发者社区 作者:华为云小月老师 2020-11-18 10:45 次阅读

软件正在改变世界,也在改变着华为。近几年华为招聘了众多业界软件精英,以软件教练身份加入,着力提升自身软件能力。那么,到底怎样才能成长为一名软件教练呢?本文作者以自身经验之谈,为各位开发者们提供一条新思路……

师傅领进门,修行在个人。我在本文中只指出道路,相当于一次将全套功法给你。但修行的路还请自己努力。不明白的地方,Google是个金手指。我会看大家对具体哪里更感兴趣,后续将其展开讲一下,作为一个系列。大家可以留言给我。

第一阶段对应炼气期。你要掌握:

1, Java:俗称JAVASE。不仅仅指Java语法,还包括JDK的使用。这块知识非常沉重也非常重要。沉下心花几年时间学好它。推荐学习方式:a) 《Effective Java》。让你感受下Java里面的弯弯绕绕,并不是语法表现的那样傻白甜。 b) SCJP考试。现在可能改名为OCJP了也说不定。全方位让你了解Java及里面的细节。非常重要。 c) 《并发编程实践》。必读刊物。多核CPU自带L2 cache却共享内存和线程,复杂的锁,一行Java代码被编译为多行机器指令而CPU在任意机器指令间都可切换线程。面对这么复杂的硬件环境,Java是如何设计保证程序正确的。

2, 敏捷开发:敏捷开发不是靠书学的(虽然也有书),而是靠实践来感悟的。就像卖油翁,不去倒油光靠看老翁写的心得,永远不会倒油。

3, 算法与数据结构:a) Leetcode刷题。虽然只有极少的开发会用到算法,但这是能力的体现。不要以为就是个链表反转,至少要把动态规划级别的算法搞懂。 b) 《算法导论》。读读就行了。希望你能读懂。

4, 测试:要了解测试同学如何写测试用例,如何保障code coverage,如何做自动化。

第二阶段进阶至筑基期:

当上面了解的七七八八后,你自然而然就会产生心灵上的感悟从而进阶至筑基期。你要掌握:

1, 设计模式:《设计模式》,Gang Of Four。四杆老枪的设计模式(我可没开车),教会你面对各种经典场景如何构造类群。

2, JVM原理:《深入理解Java虚拟机》。我刚工作时,大概06年,如果那时候有人说对JVM原理很懂,那就属于国内顶尖的技术人才了。现在知识的获取方式越来越方便了,比如阅读本文。你需要了解JVM如何使用内存,如何GC,如何调整启动参数,如何查看各种dump文件等等。

3, 网络编程:书籍暂时没有推荐。反正就是要搞懂HTTP/WebSocket与TCPIP与Socket的关系等知识。

4, 分布式系统中各种中间件:a) Dubbo。国内最知名开源项目。无中心化分布式架构的核心。取代了IBM的SOA产品(中心化架构造成性能瓶颈)。 b) ZooKeeper。Zookeeper小红书。分布式系统数据一致性协调工具。单机进程,代码执行被认为是完全可靠的,要么执行成功要么执行失败。而到分布式系统,网络调用偏多出来一个超时。分布式系统之所以比单进程复杂那么那么多,都是这独独一个超时闹的。理解CAP,理解分布式系统数据一致性,是分布式系统不出错的保障。你从来没看见银行转账时给你少转过一分钱吧? c) Kafka。《Kafka权威指南》。要理解其为什么那么快又那么可靠又那么存储空间大。同时也是理解幂等性最方便的系统。 d) Redis。《Redis设计与实现》。了解了前述的知识,Redis就是个菜。无非多了个流言协议,一致性哈希环,跳跃表,哨兵,持久化方式而已。 e) MySQL(假装其也是中间件好了)。

《MySQL高性能》,《MySQL技术内幕:InnoDB存储引擎》。要了解红黑树和索引的实现方式,了解innodb存储引擎的工作原理,你才能更好的理解explain sql后出来的各种回显结果,帮助你更好调优sql。MyISAM被废弃了,你可以少看一本书了,偷着乐吧,少年。 f) Nginx。之所以能有多个幂等节点存在,就全靠它了。学一下它的单线程技术。明明是单线程却能做到高性能。“我就是看不上你多线程,咋啦?”唯有真正理解计算机原理才能返璞归真。 g) Netty。《Netty权威指南》。你有没有感觉到在2002年后的某一年,就在短短一两年内,计算机网络突然提速了?02年JDK1.4,04年Netty。本来计算机网络性能被阻塞在IO上。但NIO大幅度提升了IO效率。

Go语言为什么曾那么火?它的MPG模型还是找的IO阻塞的茬,使得多线程并发会更快。学一下Linux IO模型,零拷贝技术。理解计算机原理才能做到真正性能优化。 我猜测,在JDK支持了NIO之后,Tomcat等web容器很快就进行了IO模块的更新,之后各大网站的Tomcat跟着升级,于是在全世界硬件资源没变的情况下,网络站点服务器的并发响应能力大幅提升。 顺便说一句为什么Java语言会长盛不衰。因为任何新语言的特性,比如Go的MPG模型,Reactive模式等,很快就会被Java抄过来。Java已有AKKA并成功用于Flink等知名项目了。而Go想抄Java的好处,短时间很难达成。 h) Flume。一个日志收集传输系统。 i) ProtoBuf。序列化也是性能中需要重要关注的地方。 j) Tomcat。太有名了。学学其classloader的设计。

5, JAVAEE依然有用的知识:比如servlet,JMX等。哎,一个时代的落幕。

6, 编译原理与操作系统:我假设你上大学时候就学过了。没有的话,至少操作系统要读一下。就读清华大学的本科教材吧。

7, 分布式数据库体系架构:第4条讲的是内存网络的分布式架构。这条要讲持久化存储的分布式架构。分库分表,异构索引,数据库主备等。《数据密集型系统设计》,这本书很赞,堪称存储设计的通史。

8, Spirng and Mybatis:怎么说呢,你能读懂源代码当然更好。

9, 前端与CDN:至少要了解一下。

10,UML建模:教会你如何认识世界并转到计算机系统里来。《UML用户指南》。

上个境界,是最难晋升的了。多少开发们被阻在这步一辈子不得前进了。因为既要承担繁重的开发任务,又要学习那么多的知识,还要处理个人的生活,太难了。这些知识对你的提升又只是相加,不是相乘的关系。熬过去后海阔天空。

第三阶段金丹期:

好了你现在是金丹期了,你的很多要继续学的知识,都是靠前面给你打基础的,你会发现你的提升曲线斜率越来越抖了。你要掌握:

1, 架构设计方法论:做事要有章法。《软件架构设计》。

2, 领域驱动设计:软件是真实世界在计算机中的虚拟映射。如何让软件更贴近真实世界,读一下Eric Evans的《领域驱动设计》。很晦涩,不太容易懂。

3, 中台:中台这个词现在这么火,怎能不提一下。平台是啥也许你还不清楚,那就先了解一下中台。

4, 高性能调优:还是那句话,真正了解计算机及runtime的本质,才能做到性能调优或Hacker。《性能之巅》。

5, 稳定性建设:凑合看《逆流而上》。但是稳定性和上述的性能调优,是真正体现水平的地方。还有Google的《Google SRE》。

6, 两地三中心容灾系统建设:这个目前我还不清楚有什么书。如果确实没有的话,可以趁机出一本抢占市场。

7, 全链路压测:又是测试。但又不仅仅是测试。对系统的性能瓶颈节点的探查,对系统QPS的掌控。单单一个起压机就不容易设计。

8, 大数据:首先,你需要跨多个领域开始了解更多的知识。其次,你会发现我对技术的介绍粒度开始越来越粗了。因为你之前打的基础 - 粗粒度之下用来支撑的细粒度知识,已经生效了。再然后就是我会减少推荐书籍。到了这里你应该形成自己的知识体系了,也就会找书了。离线海量数据存储与计算的Hadoop。将Hadoop变的更易用些的HIVE。在线海量数据存储的HBase。批计算的Spark。流计算的Flink。自成一套ELK,尤其大名鼎鼎弹性搜索。时序数据库Druid。

9, 数据仓库:大数据都学了,顺便也就把数仓学了呗。顺手的事而已。

10,IC:HCIE,这个我就不班门弄斧了。

11,网络安全:我也不懂。汗。

12,Linux OS。可不仅仅是使用命令操作系统而已。当然,即使是这样也不容易了。

第四阶段化神期:

当你还要再继续晋升,就涉及到我也不完全理解的境界了。

1, 中间件的实现细节:作为业务侧的技术架构师,通常会把存储和网络的需求下压给中间件团队。但是他们是怎么实现的呢?细节重要的点是什么?

2, 使用Master Slave模式,Spark等是如何实现分布式任务分解并确保计算正确的?

3, Docker虚拟化技术。

4, Yarn的资源分配技术。

5, 计算机网络等。

6, 再扩展一下技术领域,触角伸到AI领域。那么数学基础,各种论文与算法实现。又或者使用算法来赋能某个具体的业务领域比如AI赋能新零售。

7, 也可以往IOT方向发展。随着5G的发展,这个应该也很火。持续看好。

责任编辑:xj

原文标题:从码农到教练,软件神功咋个炼?

文章出处:【微信公众号:华为开发者社区】欢迎添加关注!文章转载请注明出处。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • JAVA
    +关注

    关注

    19

    文章

    2903

    浏览量

    102978
  • 软件
    +关注

    关注

    67

    文章

    4336

    浏览量

    85575
  • 开发者
    +关注

    关注

    1

    文章

    499

    浏览量

    16369
  • 5G
    5G
    +关注

    关注

    1340

    文章

    47793

    浏览量

    553867

原文标题:从码农到教练,软件神功咋个炼?

文章出处:【微信号:Huawei_Developer,微信公众号:华为开发者社区】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    GS12070怎样才能输出带16声道的高清SDI信号

    请教下各位,GS12070怎样才能输出带16声道的高清SDI信号
    发表于 03-13 07:48

    CY8C4025怎样才能提高SPI的速率?

    我只使用SPI的MOSI来发送数据,不需要过度采样,我怎样才能提高SPI的速率? 我看到 SPI 的最大波特率是 4MHz,我需要它是 8MHz,超采样至少是 6,如何将其配置 3? 芯片是 CY8C4025,谢谢。
    发表于 02-26 07:11

    怎样才能验证ADAS功能的抗干扰能力?

    来自位客户的咨询,麻烦帮忙解答,越详细越好,有图有真相,可以适当提供些英飞凌解决方案和产品推荐。 现如今无线通信设备这么多,怎样才能验证ADAS功能的抗干扰能力?
    发表于 02-02 07:20

    XMC4000怎样才能将波特率设置非恒定值?

    我们怎样才能将波特率设置非恒定值? 在我的应用程序中,我需要根据某些情况更改UART波特率。 因此,波特率设置不能保持恒定。 但是,如果我添加UART应用程序并设置波特率,则它是恒定的。 而且它是
    发表于 01-23 06:26

    ADUCM360怎样才能实现AD每0.2秒采集次数据?

    ADUCM360怎样才能实现AD每0.2秒采集次数据?用定时器每0.2秒中断次,在定时器中断中开始AD单次转换次,可以吗? void GP_Tmr0_Int_Handler(v
    发表于 01-12 06:34

    怎样才能在multisim里添加ad7606的元器件来仿真

    在做个采集电路,选用了ad7606,官网上只有ibis模型,貌似只有spice模型才能被添加到multisim里去,怎样才能在multisim里添加ad7606的元器件来仿真
    发表于 12-13 06:23

    请问怎样才能将SharcAudioToolbox导入SigmaStudio?具体如何操作?

    请问怎样才能将SharcAudioToolbox导入SigmaStudio?具体如何操作?
    发表于 11-30 07:47

    怎样才能在有限的容量下发挥电池的极限续航能力

    电子发烧友网站提供《怎样才能在有限的容量下发挥电池的极限续航能力.doc》资料免费下载
    发表于 11-14 14:38 0次下载
    <b class='flag-5'>怎样才能</b>在有限的容量下发挥电池的极限续航能力

    怎样才能准确的而获取高频信号的频率10Mhz以内的?

    使用51单片机,怎样才能准确的而获取高频信号的频率10Mhz以内的
    发表于 11-10 06:52

    怎样才能选到性价比高的网线

    为了满足各类用户对网线的需求,目前市面上比较常见的有超五类网线、六类网线、超六类网线、七类网线及八类网线等。科兰通讯小编:在网线选择上不要认为等级越高越好,够用或者用得上才是硬道理,那怎样才能
    的头像 发表于 07-12 10:36 435次阅读

    怎样才能找到HardFault_Handler的原因?

    嗨,我怎样才能找到 HardFault_Handler 的原因, 接下来我该怎么办。
    发表于 06-07 08:32

    如何自学并精进FPGA

    我是一名学生,目前自学fpga,进度在野火的rs232这块儿,想问之后怎样才能提升自己啊,感觉只靠视频有点纸上谈兵了,求帮助,谢谢!
    发表于 06-06 10:39

    怎样才能让Gmail与ESP8266草图起工作?

    Gmail 现在需要 2 个因素和个唯的应用程序密码。我怎样才能让它与我的 8266 草图起工作。如果我在草图中输入唯密码,它将无法
    发表于 06-01 08:44

    怎样才能从ESP下载自己的代码

    可能这是个愚蠢的问题,但我怎样才能从 ESP 下载我自己的代码? - Filemanager 不起作用 - Strg+a 和 Strg+c 不起作用(剪贴板仅适用于编辑器内的可见部分)。 - 右键
    发表于 05-10 13:05

    LPC4370怎样才能在flash启动后,又能成功读写flash?

    /misc_spifi_tst,在运行到spifi_comde_dst,在运行();就会出现总线异常进入而崩溃,如果程序在RAM中启动运行就不会出现总线异常,想请教下怎样才能在flash启动后,又能成功读写flash
    发表于 04-27 06:04