[美文]你懂得这些,才可能比别人更优秀!

你懂得这些,才可能比别人更优秀!

自2020年以来由于疫情的影响,大批量的公司破产倒闭,即使能坚持下来的,也是推出了很多财务削减和人员裁减计划(美其名曰: 人员优化),这导致了大量各行各业人员的失业,当然也包括搞开发的程序猿。

疫情期间,为了能快速找到工作,很多人又开始四处寻找面试材料复习开始备战面试,但就在面试复习的过程中有些人可能会发现,原来自己工作了这么多年,水平可能都不及一个拥有三年开发经验的新人。

那么问题来了,为什么有些人会比别人优秀?如何才能让自己变得优秀?下面我将从三个方面阐述我的思考。

1.做事的艺术

在工作中,我们可能会碰到各种各样的问题,如何优雅地处理这些事情,非常考验一个人的能力。

严谨一丝不苟的态度

有人经常这样向人抱怨:面试造火箭大炮,工作拧螺丝。我想即便你是拧螺丝的工作,也务必要保持一丝不苟的态度把这拧螺丝的工作做好,否则你的这步没能拧好,很有可能导致造出来的整个火箭还没飞上天就爆炸了。

就例如开发这行,我觉得干这一行,严谨和一丝不苟的态度是必须具备的基本职业素养。因为可能就是你的一点小疏忽或者情况考虑不周,可能给别人带来多大的麻烦和后果。

可能一次两次地这样坑别人,别人还能原谅你,帮你填坑。但如果由于你的不严谨和不认真的态度,导致三番五次地坑别人,时间长了即便你人再好,别人也不会再相信你,这样你在团队中就举步维艰了。

遇到问题要把握本质

在开发工作的时候,我们经常会遇到各种各样奇怪的Bug。面对这些Bug,不同的人处理的方式也是不尽相同。有的人是恨得咬牙切齿,恨不得和提Bug的人干一架;有的人则是非常淡定,一边询问Bug的详细情况,一边静静地坐着打断点、查日志来分析问题产生的原因。两者处理的方式不同,带来的结果当然也不尽相同。

那么当我们在开发过程中遇到问题时,我们该如何解决呢?我想核心的解决方法就是把握问题的本质

如何把握问题的本质,以下是我常用的方法论供大家参考:

  • 1.了解问题的详细情况,收集问题出现的条件和现象:只有了解问题才能解决问题。
  • 2.模拟问题出现的场景,对问题进行场景复现。
  • 3.将偶现问题转化为必现问题,从中寻找规律。
  • 4.善用排除法,筛除干扰项,从而确定相关问题。
  • 5.断点+日志相结合对问题跟踪,深入源码探寻问题的本质。

一旦把握了问题的本质之后,一切便会迎刃而解。后面你需要做的就是找到方法并解决它。你可以自己想办法,搜索网上有没有人和你遇到同样的问题;请教对这方面熟悉的人;问问智能的ChatGPT让它给你些思路…

事前永远比事后重要

事前埋下的坑,也许需要事后付出数倍的努力才能把坑填完。很多时候我们经常会忽视事前计划、设计的重要性,往往是走一步看一步,等功能实现到一半的时候才突然发现这条路越走越崎岖或者根本行不通,这个时候你是非常难受的:继续走下去,可能前面的坑会越来越多;不继续走,重新想方案,时间要延期,进度赶不上,要被问责。

因此在做任何事前之前,一定要自己将要做的事情想清楚再去做,避免南辕北辙、做无用功的尴尬。

以下是我给出的几点建议:

  • 1.在做一些较为复杂的功能前,尽量做好设计。这里的设计主要包括:
    • 流程图:把所有可能出现的情况都考虑进去,越详细越好。
    • 设计图:包括UML图和时序图等。好的设计往往事半功倍。
    • 性能设计和可拓展设计。为后续的功能拓展做充分准备。
  • 2.养成良好的编码规范,在关键的、难懂的地方多加些注释,这样可以避免长时间后的遗忘,导致代码晦涩难懂,大大增加维护难度和Bug产生的几率。
  • 3.提高代码的质量,在实现功能的同时,注重代码的性能,对于一些常见性的问题要烂熟于心。
  • 4.在问题出现任何端倪之前就立马进行解决,即使不能完全解决也要预先想出替代方案。否则时间长了或者功能上线之后,你可能需要付出数倍的精力才能解决,并有可能带来非常不好的影响。

低调做人与高调做事

Talk is cheap. Show me the code.这句话可谓是IT圈里最朗朗上口的一句话。

干开发这一行不同于其它的职业,并不需要极力向外推销自己来获取更高的业绩。因为绝大多数的研发人员都是务实派,靠的是一行一行写出来的代码去实现自己的价值,少说话多敲几行代码会让你变的更加有价值。

所以,那些成天夸夸其谈,开口就是讲上一堆技术架构,闭口写起代码又是一团乱麻的人,是比较不受欢迎的。

我们做技术的不要成天拿着技术出来显摆。要知道人外有人天外有天,比你技术牛逼的大有人在,没必要整天要在技术上比个高低贵贱,也不需要刻意让别人知道自己有多么厉害,因为你写的代码就能证明你的技术水平,时间长了,你的能力大家自然都心知肚明。

学习帮助别人的艺术

在帮助别人的同时,还能让自己加深印象让此技术掌握得更加透彻,何乐而不为呢?

帮助别人而不是施舍,这一点尤为重要。我们要乐于助人,但是也要注重方法。帮助他人是建立在相互尊重的基础上的,否则你的好心帮助会被别人理解为同情施舍或者多管闲事。

因此我们在帮助别人的时候要注意以下几点:

  • 不要有随意帮助人的企图,只有在别人特别需要帮助时才去伸出援助之手。
  • 不帮因懒惰造成的困难,真实遇到困难选择性帮且要给予被帮助人最起码的尊重。
  • 不要借着帮助他人的名义去干预他人成长,最好的帮助就是点到即止,剩下的顺其自然。

2.学习的艺术

从事开发,无论你是在产品线上写业务代码,还是在技术平台进行技术研究,我们都不能放弃学习,放弃对新技术的尝试。放弃学习就好比战士上战场弄丢了自己的枪,很快你将会被一波又一波的技术浪潮所淘汰。

学习和汲取他人长处

对于大多数的人来说,只善于发现别人缺点而不善于发现他人优点,这也是很多人不能快速成长的原因所在。

优秀的人总是善于发现别人的优点并加以学习。去学习模仿并最终将超越他们定为目标。他们并不在乎你身上有多少缺点,他们只在乎能从你身上学到多少东西。

他们不仅会向身边的人学习,还会通过以下几个方面来学习:

  • 优秀的源码。这里包括系统源码和优秀的开源项目源码。
  • 优秀的技术书籍、文章。书本里总是最全面和最详细的。
  • 优秀的理念和思想。更多活跃的理念和思想可事半功倍。

把握学习广度和深度

漫无目的地学习必然导致效率的极其低下,我们在学习之前一定要给自己设定一个目标:到底是想学习不同领域的技能,成为一名全才;还是想就某一领域深入研究,成为一名专才,这就涉及到学习的广度和深度的选择问题了。

因为你不同的选择可能导致不同的人生轨迹,就目前而言,大厂更偏向于某一领域的专才,而小厂更偏向于拥有更多技能的全才,当然这也不是那么绝对。就选择而言,大厂固然很好,但是又有多少人能进入大厂呢;小厂虽说待遇各方面都不如大厂,但在小厂机遇也会多啊,说不定哪天公司发展得不错,你就能爬上领导的位置呢。

所以无论你是选择学习的广度还是学习的深度,其实都是没有错的,唯一错的就是你压根就没有思考过这事。

当然这里的选择也不是绝对的,每个人在不同的阶段可能选择的方向并不相同。当你初入社会刚开始工作你可能追求的是学习的广度,但慢慢的当你对某一领域感兴趣或表现出异于常人天赋时,你可能又会转而追求学习的深度。

每个人的技术都可能在某一刻达到瓶颈。如果现在的你翻开一年前你提交的代码,却发现和你现在提交的代码并无差别时,你就要小心了,很可能你已达到你技术瓶颈了,这时候考虑换一个学习的纬度可能是不错的选择。

持续不断的坚持学习

技术在日新月异地不断变化和发展着,前几年还比较流行的技术,可能没过几年就被人们所抛弃。当革命性的突破技术取代旧的技术时,这是历史巨轮不断向前发展、不可阻挡的趋势。

不要以为你现在掌握的技术就能够养活你一辈子,我们需要对技术的发展保持着极大的敏锐警觉。一旦你所掌握的技术逐渐被新技术所替代时,你也要小心了,可能留给你学习的时间已经不多了。

善于利用好学习工具

工欲善其事,必先利其器。善于利用好学习工具,能够极大地提高我们的学习效率。

这里我主要介绍关于自学一门技术可以利用的工具:

  • 专业性的入门书籍。对于新手和小白而言,我还是建议大家先找几本专业性和权威性强的书籍作为自己的入门指南。因为书本讲解得更详细也更成体系,对于入门而言还是相当不错的。
  • 专业领域较强的技术论坛和博客。这里我们可以学到很多书本上所没有的一些前沿技术资讯和技术交流心得。
  • 开源代码托管平台。在上面拥有海量开源的项目,其中也不乏许多优秀的开源项目可以供我们学习和参考。学习和借鉴别人优秀的代码和设计思想,能让我们快速提高自我的coding能力。

3.提问的艺术

我们每个人都不是万能的,都会遇到很多我们不懂的问题,需要向别人进行求助。但是并不是每个人的问题都能够得到别人的答复,这完全取决于提问者提问的水平。

在这里先模拟一个场景:当你在Github上使用了某人开源项目时,遇到问题需要向作者提问或者提issue,你会怎样进行提问?

  • 提问者A:大佬帮帮忙,我在使用xxxx的使用遇到问题了,请问怎么解决啊?
  • 提问者B:老哥,我是xxx小白,在使用你的xxxx搞了一天了都没有运行得起来,能不能帮帮忙,我实在没办法了。
  • 提问者C:您好,大佬。我在使用xxxx时,频繁xxxx,导致xxxx,但是xxxx,又会xxxx, 但是呢…(以下省略500字)。可能我形容地不是很清楚,你可以试一下就知道了。
  • 提问者D:请问怎么解决,…(以下省略数百行的看着像乱码的日志)
  • 提问者E:你这xxx根本不能用,真垃圾,…(以下省略约一百字的抱怨的话)
  • 提问者F:您好,我在使用xxx的xxx版本的时候,遇到了xxx问题。下面是我出现问题时的现象(…)以及日志(…)。我是这样xxx,然后xxx,最后导致xxxx。我出现问题的设备型号是xxxx,在xxxx上没有出现问题,是不是xxxxx导致的?

上面6个人提问的方式是完全不同,我想可能只有提问者F才能够最终得到别人的答复并顺利解决问题,下面我将帮大家逐一分析相关原因:

  • 提问者A是很多人经常犯的错误,那就是只抛出了问题,并没有给出问题出现的现象和依据,这会让被提问者无从下手,没有丝毫回复的欲望。毕竟你是求别人帮你解决问题,而不是领导发号施令。
  • 提问者B是很多初学者(学生)常犯的毛病,没有明确的问题,没有明确的解决预期,有的就是祈求式的求助,甚至连要帮什么忙都没有表述清楚。对于这种提问,绝大多数人是不予理睬的,因为他们并不想把时间浪费在一个什么都不明白的菜鸟身上,毕竟他们不是你的老师,没有义务教你基础知识。
  • 提问者C的问题就是说得太多,没能精确描述问题是什么。这样表述不清的提问只会让被提问者满脸的问号,然后直接回复:???。
  • 提问者D也是很多人经常犯的错误。出现问题之后的第一反应不是先去进行一番思考尝试自己解决,而是无脑地将一堆无用的错误日志贴出来,请求别人给出解决方案。对于这样的问题,可能绝大多数人的第一反应就是:能百度解决问题的,请不要来烦我,谢谢!
  • 提问者E就不用多说了,这种提问明显不是冲着解决问题的目的来的。对于这种不友善,怀有敌意的提问,我想大部分人的反应不是去帮忙解决问题,而是在想:这人不会是傻*吧?

分析了上面人的提问方式后,我们可以总结出如下几个提问时的技巧:

  • 首先明确你所遇到的问题是什么。
  • 优先自我解决,再向别人求帮助。
  • 直奔主题,避免无意义的提问句。
  • 简短且清晰地描述你遇到的问题。
  • 提问问题并给出超级离谱的答案。(慎用)
  • 问题解决及时反馈并表达出谢意。

明确你的问题是什么

在提问之前,首要任务是要搞明白自己到底要问什么?诉求是什么?这是对被提问者最起码的尊重!

什么都没搞明白就稀里糊涂地跑去问别人,这会让别人觉得你很唐突无知,给人留下非常不好的印象,这也会直接导致别人不愿意回答帮助你去解决问题。

为什么这么说?因为别人要想帮你解决问题,还得先搞明白你的问题到底是什么,你的诉求是什么,然后还需要帮你分析问题出现的原因,最后才能帮你想出解决的办法,这花费的精力和代价实在是太大了。要知道这不是在学校或者医院,没人会愿意这么大废周折地免费帮你,甚至帮你解决问题后还有可能得不到你一句感谢的话!

所以,要想自己的问题能够得到别人的答复和帮助,你必须想明白你要问的问题到底是什么?学会如何去提问题!

优先自我思考去解决

搞开发的你可能也会遇到这样的情况,经常有人会在论坛上、QQ群里、博客评论区里,动不动就贴出数百行且没有代码块包裹的报错日志,然后不做一点说明,开口就问:这是什么问题,能帮我解决吗?

像这样不经大脑思考就草率的发问只能得到草率的回答,或者根本得不到任何答案便会石沉大海。其实我特别不建议大家在QQ群或者微信群里向别人问问题,因为懂的人可能不屑于回答(觉得这样的问题太low了,即使回答对了也体现不出自己的价值),不懂的人即便回复你了也没有任何价值,反而有可能会把你带偏了。现在是21世纪,大家的时间都很宝贵,没有哪个真正厉害的技术大牛是在QQ群和微信群里活跃的,大牛的时间都很宝贵。那些成天在QQ群或者微信群里活跃的人,八成是闲的没事干的人。

因此要想得到别人高质量的答复,必须拥有与之相匹配的高质量问题才行,这样别人才会愿意帮你解决。所以并不是什么问题都是值得向别人提问的。

我们在提问之前,一定要有自己的思考,优先尝试自己解决问题。下面是我提供的几个自我解决问题的途径:

  • 开发上断点+日志相结合进行问题跟踪,深入源码探寻问题的本质并予以解决。
  • 仔细通读作者编写的使用手册,不要忽略每一个细节(切忌想当然),试着自己找答案。
  • 善于在常见问题中找答案。若有开源地址,建议优先在Issue中查找历史问题,并借鉴其解决方法。
  • 优先利用搜索引擎搜索相关问题(条件允许时优先使用Google,百度搜到的大多千篇一律)。
  • 向你身边精于此道的朋友咨询或若有条件问问智能的ChatGPT,让它给你些答案或建议。

如果经过以上5种方法你都没能解决问题,这个时候你再向别人进行提问,我相信你一定能够把问题解决。因为带着思考向别人提问题,才更能够得到别人高质量的答复。如果可以的话,你可以直接把自己想的几个解决方法阐述出来,这样别人可能会更愿意帮你解决,毕竟大家都喜欢做选择题,而不是论述题。

避免无意义的提问句

直奔主题,避免用无意义的话进行提问,例如:在吗?在干嘛?有人能帮我吗?这有答案吗?

首先:如果你对问题的描述不是很好,这样问更是画蛇添足。

其次:由于这样问是画蛇添足,被提问者会觉得厌烦。 你通常会得不到回复或他用逻辑上正确,但毫无意义的回答来表示他们的蔑视! 例如:没错,有人能帮你或者不,没答案

一般来说,避免用 是或否对或错有或没有类型的问句,除非你想得到类型的回答!

清晰描述遇到的问题

有这样一部分人,每次遇到问题需要向别人求助的时候,经常表现的是举足无措,慌张地描述了一大堆看上去和问题有关又或者无关的话,滔滔不绝口若悬河,问的被提问者是一脸懵逼也不知所措。

面对这样的问题难免会让别人头大。讲了一大堆却分不出主次和主要矛盾,别人就连你要问的问题是什么都没有搞得很明白,别人也更加无法帮你去更好的解决?

因此我们在阐述问题的时候,需要注意以下几点:

  • 问题描述要言简意赅,尽量控制在50字以内。
  • 问题描述要条理清晰,把握主要矛盾。与问题无关或者相关性较低的话就不要说了。
  • 建议问题中包括如下几部分的内容:
    • 问题描述
    • 使用版本
    • 如何重现
    • 期望效果
    • 出错现象(截图或视频)
    • 设备信息(环境和版本)
    • 附加信息(出问题链接)

提问题并说离谱答案

这种方法还是要谨慎使用的。因为提出问题给出离谱答案的做法可能是基于“反向思考”的原理。通过给出一个看似荒谬的答案,可以激发其他人对这个问题的思考或懂行的人对荒谬答案的反驳,使他们开始考虑问题的不同方面或角度,从而别人在反驳时为了证明自己是对的而说出更好的解决方案(可以说是利用了人性的弱点吧)。

此外,提出一个荒谬的答案这种做法也可能是在尝试打破思维的定势和刻板印象,引导人们以更开放、更富创造性的方式去思考问题,从而产生新的想法和解决方案。

解决后请反馈并感谢

现实生活中常常有这样一部分人,在得到别人的帮助之后,连一句问题是否被解决的答复或感谢也没有便消失得无影无踪,这会极大地打击提供帮助者人的积极性。因为问题久拖未解决会让人灰心,他们渴望听到问题被解决,并从中得到帮助别人带来的满足感,这点是非常重要的。否则下次再有人向他提问题时,可能就不太愿意帮忙了。

所以,在问题解决后,需告诉所有帮助过你的人并让他们知道问题是怎样解决的,并再次向他们表示感谢!

参考文章:
同样是开发,为什么你不如别人?:https://blog.csdn.net/xuexiangjys/article/details/106184931
提问的智慧-老师永远不会教:https://www.fzxx.xyz/how-to-ask-questions-the-smart-way

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值