美文网首页美文共赏
如何看待软件开发 ?

如何看待软件开发 ?

作者: 时光啊混蛋_97boy | 来源:发表于2021-12-11 15:38 被阅读0次

创作不易,请珍惜,之后会持续更新,不断完善
个人比较喜欢做笔记和写总结,毕竟好记性不如烂笔头哈哈,这些文章记录了我的IOS成长历程,希望能与大家一起进步
温馨提示:由于简书不支持目录跳转,大家可通过command + F 输入目录标题后迅速寻找到你所需要的内容

目录

  • 一、软件开发
  • 二、职业生涯规划和技术人的追求
  • 三、架构师的日常
  • 四、关于旅行
  • 参考文献

一、软件开发

软件开发是一个创造或者维护,应用,框架或者应用组件的过程中涉及到的需求分析,设计,编码实现,测试,bug 修复的过程。软件开发是编写代码和维护代码的过程。更广义的来说,软件开发是一种人类思维活动的体现。

软件开发与其说是搬砖,不如说是处理问题的能力,智商的体现。开发什么并不重要,重要的是思考问题的角度和快速解决问题的能力。使用过的前后端和客户端的编程语言之后,笔者感受到会使用语言并没有什么,能用什么语言解决多大的问题才是关键。前端后端都有相应的职级,相同的职级,不同的开发岗薪资差距不大。职级的高低更多的展现的是一个人思维活动能力强弱的体现。而且各个领域和方向,干到高级开发都不容易,每个领域都有各自的 roadmap,在一个领域深耕都需要静下心来 2-3 年。谁能一直领先并且一直维持在金字塔顶端,都是非常不容易的事情。

广义的来说,开发用什么语言仅仅是一个进入这个行业的首秀,之后往下走,会接触到很多其他语言,如何修炼思维能力才是一个软件开发技术人需要关注的东西。菜鸟和大神的差距在于有效时间的积累,经常有这种情况,菜鸟和大神同时遇到一个同一个问题,哪怕是陌生的问题,大神也可以很快的找到问题的本质。大神解决问题以后,说靠的是自己的“直觉”找到的突破口。但就是这种直觉就是宝贵的经验,这就是菜鸟们需要用时间积累的东西。这种“直觉”并不是玄学,是一种能力,经验丰富以后带来的快速解决问题的能力。

在笔者经历过三端的开发迭代以后,综合看客户端,前端,后端,三端开发流程和工作内容都有相同的地方。开发流程三端都一致的。评审,排期,kickoff,站会,开发,确定终版,提测,灰度,上线发布。

各端都有 APM,都有监控性能的需求。不过架构实现方式不同。三端关注的点是不同的,客户端和前端更加关注客户为主,用户体验,页面打开速度等等。服务端关注点以服务为主,服务性能,可用性,高并发,低延迟,io 读写速度,多活,跨机房等等。这里可能会有读者说鄙视链的问题,笔者认为没有必要对其他端的鄙视。做纯服务端的开发人员对图形图形和像素就不太敏感,让他们来做一些前端动画,可能比较难。做纯前端的开发人员对后端的架构可能不太熟悉,让他们设计一些大型的高并发系统,可能比较难。(考虑到读者里面有全栈开发,对三端都非常了解,所以这里特意加了“纯”字)让做纯服务端开发的写前端,不一定写的来;让纯客户端开发写服务端,也不一定写的来。所以各端有各端的难处,可以相互学习,但是没必要鄙视。

综上,软件开发狭义的看,是实现需求到最终上线发布的过程,广义的看,是将人类的思维活动固化凝结成软件产品的过程。软件开发的过程中不断的训练人的思维和发现问题解决问题的能力。


二、职业生涯规划和技术人的追求

找到自己真正感兴趣的方向以后,就可以开始努力是做到 TOP 。在自己精通的领域做到顶尖是重中之重。在大公司里面,晋升是考察的你的专业性,技术面再宽,深度没有到达下一级的要求,是无法晋升的。以笔者为例,移动端技能分数可能就是及格分多一点,前端和后端略懂,各打 30 分吧。这种情况大公司可能都不会要吧,不要指望大公司招你进去一个人干三个人的活,因为大公司完全有能力招 3 个在各自领域都拿 90 分的人进来工作,这样全栈就没有多少优势了。大公司里面晋升更多还是靠专业性。

但是业余的时候可以看看其他语言,吸收各自的优点。在笔者没有接触 Go 语言之前,对协程完全没有多少感觉,只是听说过,协程如何调度用户态这方面几乎一无所知。Go 语言为什么要这么设计协程,为了解决什么问题?Go 是第一个实现协程的么?谁是第一个实现协程的?Swift 能实现协程么?如果不能,为什么呢?OC 可以实现么?如何实现?这些问题都是值得平时学习思考的。视野广度可以加深你对开发的理解,提升对行业的认知。

再谈谈技术人的追求,我作为一个技术人的追求应该是一生修炼一个响彻江湖的"绝学",作为你的代表作,让它成为你行走江湖的名号。行走江湖,会耍的武器多,百般武艺,会使用的编程语言多,并不是什么传奇,关键的是能否用你最擅长的武器一招致命。十年磨一剑,匠心独运,就为了给自己这技术一生一个交代。我也在以这个追求作为我未来几年的目标,努力去实现。

不到万不得已,别换方向。新的方向上你是新人,一切都要重头开始,换了方向以后,晋升和跳槽都比较麻烦,笔者已经深刻的认识到了这个问题了!如果为了换方向而跳槽,那么换工作不要降薪降职,薪水一样的情况下职级越低越好。这一条已经得到了我周围跳槽换方向同事的验证了。如果换了方向以后,职级还能提高了,请做好心理准备,牢记:欲戴皇冠,必承其重 !迎接挑战吧。

如果想成为被大公司抢着“挖”的香饽饽,据我观察主要有这么 2 类人。一类是把一个领域做到极致,做到 95,甚至 99,100 分,一提到他就代表了这个领域或者方向,他是这个领域的领袖和领军第一人,成为这样的人很不容易。这种人对应的 title 就是 XXX 高级技术专家。另一类人是把某个产品做到极致。比如 APM,质量监控,容器调度,SOA,CI/CD,云基础设施等等。或者是公司某块业务了然于胸,微信和钉钉的 IM 核心开发,淘宝天猫京东的交易系统核心开发等等。这些人也会被争相被挖。乍一看后面一种人也许技术研究方面只有 85 分或者 90 分,但是业务熟练度上面分数更高。

过去一年我除了看技术书以外,还看的比较多的是极客时间的专栏。在上面买了几个专栏。买的第一个专栏是陈皓老师的专栏(@左耳朵耗子)。这个专栏里面的内容确实写的非常丰富,并且不少内容是我自认为没有到达相应的层次没法产生共鸣的。陈皓老师建立了这个专栏的读者群,并提出了入群要求,能坚持一年 ARTS 的人就能入群。周围朋友看了我的 github 上的 contribution 都会问,“怎么这么多 commit 啊?” 其实我就是想坚持一年 ARTS,人不逼自己永远不知道自己的潜力有多大。

不过结果是我没有坚持下来。给大家当了反面教材。ARTS 是 Algorithm、Review、Technique、Share 的简称,即每周至少做一个 leetcode 的算法题,阅读并点评至少一篇英文技术文章,学习至少一个技术技巧,至少分享一篇有观点和思考的技术文章。这样至少坚持一年。在 2018 年下半年我基本做到了每周阅读几篇英文文章,学习并记录技术技巧,分享多篇技术文章。但是 leetcode 算法题这块没有跟上。除去自己效率低下导致周末有加班,重要的原因可能还是自己“眼高手低”吧。leetcode 上的题按照难度划分,easy 的题刷 1-2 道很快就 AC 了,一点成就感也没有,medium 和 hard 等级的题目,提交了一下午全部都是 WA,挫败感巨大,在自我否定中就逐渐放弃,不再坚持了。2019 年准备继续捡起来,希望到 2019 年年终总结的时候不会打脸。github 上的 repo 也建立好了,强行逼自己一下。希望读者不是我这样“眼高手低”。

如果有些读者觉得提高到了瓶颈的时候,可以看看自己的计算机基础是否足够扎实,足够你继续往上再建高楼。计算机基础决定了上层建筑的高度也进步的速度。

举个例子,比如区块链技术,如果计算机基础非常扎实的人,掌握基本的区块链技术会非常快,因为里面的协议,加密技术都不是新的。设计理念是新的,看一遍很快也能学会。再比如换方向,一个 iOS 方向的开发者换到大前端方向,或者人工智能,或者后端方向,切换的成本有多大?如果基础扎实,至少计算机基础这块的知识是无缝衔接的,都是通用的,零成本切换。再比如菜鸟和大神同时看一本技术书,大神用一上午就看完了,菜鸟看了一周。为什么会有这么大的差距呢?因为大神看书,书中写的大部分知识点早已是自己内化的知识,看一眼就明白在讲什么,也不需要思考,直接看过去,遇到不会的再思考思考,一本书看下来可能就只有 2-3 处需要思考的地方,菜鸟看书就不同了,每一页可能都有需要思考的地方,甚至每段话都需要思考,比如看算法导论这本书,书中会经常推算一些数学公式,然后写“很显然可以得出”,这个结论对于菜鸟来说真的不显然,菜鸟看到这一行的时候就会思考一上午,还不一定想的明白。大神之前推算过或者这个结论早就已经理解了,2 秒就过了这一行了。从看书快慢的例子里很容易看出自己在知识点上欠缺的点,每个人欠缺的知识点也不同。笔者建议学习应该更注重的回归本源,计算机基础真的很重要。


三、架构师的日常

这一年平时工作的时候有意观察过架构师的工作内容。架构师的工作内容是对公司里面每个系统提出最适合最好的架构方案以及对系统各方面指标把控。架构师必须要对业务了如指掌,不然对系统设计不出量身打造的架构方案。这里的架构方案一定是量身打造的,一个小公司的业务体量没有大公司的体量大,如果用大公司上亿的架构方案,明显是浪费资源,所以架构方案会随着业务体量发生巨大变化的时候产生变化。另外架构师对系统指标的掌握也必须了解,公司内每个业务对系统组件的使用,对资源的使用,都是他们的工作范畴。笔者申请机器资源都需要经过架构师的审批,他们都会审核是什么业务,业务场景是什么,是否合理。

架构师还具有技术前瞻性,一个好的架构是不断随着业务增长而不断进化的。一个好的架构应该对当前业务有业务余量的,对业务增长也有预判的,而不是当业务突然增长了,架构适应不了,引起血崩式的崩溃。这方面的前瞻和预判也是一种能力!笔者今年就遇到几次没有前瞻性的技术改造,自己没有做好预判,突然到来的险情只能靠加班去紧急解决问题,如果做好了预判,能减少不少加班时间,系统运行的也更加稳定,演化的更加平稳。

笔者认为架构师的工作要求比较高,视野也要求广。如果没有见过各个场景下比较好比较合理的架构设计,只靠自己没有实践的空想还是不行的。毕竟在架构评审会上面需要他们对好的架构提出宝贵的建议。笔者尝试对之前同事的系统架构设计“指手画脚”,发现很多地方的设计是对业务场景的取舍,并非是不好的设计。到最后也给出不了什么好的建议。架构师确实不好当,对各种业务没做到透彻的理解,对好的架构设计没有实践的经验,基本就没戏!

另外架构师关注点也比较高,并非局限在某一个技术点上,关注的更多的是收益。架构师的薪资为什么高,是因为他熟悉浏览器内核的每一句代码么?(这是举个例子,当然很多架构师确实精通浏览器内核的每一行代码)。其实并不是,他们的价值在于帮公司解决了多大的问题。他们给公司创造的高价值对应了他们的高薪。他们更关注的收益,好的架构方案目的一定是能解决问题。而使用某个技术只是手段。使用这种技术能解决什么问题,好在哪里,收益是什么,能否解决问题。笔者刚刚毕业那会更多的关注技术点上,视野比较窄。从只关注单一技术点到关注技术收益的转变,算是程序员思维认知的一个分水岭吧。

架构师的看待问题和解决问题的思维方式,很值得我们去学习。


四、关于旅行

今年一共去了 5 个国家,日本、捷克、匈牙利、奥地利、斯洛伐克,十几个城市,名古屋、大阪、奈良、京都、箱根、静冈县、山梨县、东京、布拉格、卡罗维瓦利、克鲁姆洛夫、哈尔施塔特、萨尔兹堡、林茨、维也纳、布达佩斯、布尔诺、库特纳霍拉、布拉迪斯拉发,大城市,小城市都有。有人问我旅行对我的意义是什么?首先当然是放松身心,释放工作和生活上的压力,其次是长长见识,看看世界。去发达国家看看有钱人的生活是怎么样的,探寻物质富有的人为什么还有这样那样的烦恼,去贫穷的国家看看穷人的生活是怎么样的,追寻物质贫穷的人是怎么丰富精神生活的。有钱人有自己的烦恼,穷人却也有生活的很开心的。人类的世界充满了故事,充满了有趣的事情。以后有人拿酒问我是否有故事的时候,我可以和他聊聊世界上我见过有趣的见闻。最后是可以结交一些旅友,来自各行各业的朋友,不同地方的人,大家有着不同的兴趣爱好,各种肤色,怀着对世界的好奇之心,一起探索着未知的世界。一家酒店的餐厅里,坐着来自各个国家的人们,各种肤色,大家吃饭的方式都不同,有的直接用手抓,有的用刀叉,有的用筷子,有的用勺,说着各式各样的语言。不同的信仰,基督,天主,伊斯兰教,佛教。一个小小的空间里面浓缩的是世界的缩影,在这个空间里面将不同时区的人们包容在了一起。凯撒大帝一生的名言也概括了我的答案:I see,I come,I conquer。我用小小的脚步丈量着大大的世界。


参考文献

相关文章

  • 如何看待软件开发 ?

    创作不易,请珍惜,之后会持续更新,不断完善个人比较喜欢做笔记和写总结,毕竟好记性不如烂笔头哈哈,这些文章记录了我的...

  • 【星霜荏苒】 - 如何看待软件开发 ?

    GitHub Repo:Halfrost-FieldFollow: halfrost · GitHubSource...

  • 如何看待电商APP软件开发优势?

    国内电商企业数量越来越多,其中大部分还是处于PC端的商家,其中选择开发定制一款电商商城APP软件的还是偏少的,电商...

  • 如何看待电商APP软件开发优势?

    国内电商企业数量越来越多,其中大部分还是处于PC端的商家,其中选择开发定制一款电商商城APP软件的还是偏少的,电商...

  • 隐藏的关系

    在这段关系中,你如何看待自己? 在这段关系中,你如何看待对方? 在这段关系中,对方如何看待你? 对方如何看待你们的关系?

  • “高光时刻”,即使有,也是由一个个小选择铺就而成的

    选择背后的三个底层思维: 如何看待自己,如何看待他人,如何看待机会和欲望。 如何看待自己? 经常看自己有什么,而不...

  • 在关系中

    在关系中我如何看待我自己 在关系中我如何看待我的伴侣 在关系中我的伴侣如何看待我和他的关系 在关系中我的伴侣如何看待我

  • 人活着拼的就是三观

    定义,即我们的世界观、价值观和人生观,我们如何看待这个世界、如何看待是非以及如何看待自己的人生。 重要...

  • “阳”的关联思索

    如何正确看待“阳”? 如何准确界定“阳”的标准? 如何正确看待“无症状感染者”? ...

  • 我是谁(转毕淑敏)

    导语:“我是谁”,这是一个关于你“如何看待自己,如何看待别人,如何看待世界”的问题。一个健康的自我形象,会导引...

网友评论

    本文标题:如何看待软件开发 ?

    本文链接:https://www.haomeiwen.com/subject/abukfrtx.html