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

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

3天内不再提示

阅读代码注意这几点及时纠正可以少走一些弯路

C语言编程 来源:C语言编程 作者:C语言编程 2022-11-29 14:17 次阅读

想想以前刚入行的自己,也会犯类似的错误。我觉得这些问题挺有代表性的,在这里把这些问题抛出来,大家可以看看自己有没有犯相同的错误,及时纠正可以少走一些弯路。

阅读代码

1、阅读代码之前没有先弄清整个项目的框架

这位新来的小伙伴,一上来就开始看代码,哪怕我已经把相关的系统设计文档已经发给他了。他没有仔细阅读,对各模块的功能也不是很了解。所以,刚开始看代码时一头雾水。

公司里的项目,往往都是很多人一起开发的。参与公司的项目开发,无论我们最终分配到负责哪个模块的开发,在去专研那个模块代码之前,都很有必要先了解这个项目的总体框架。这个项目实现了什么功能,由哪些模块组成?哪些硬件模块?哪些软件模块?各模块之间是怎么交互的?

只有了解了这些,我们再去做某个模块时,能更清楚的知道我们负责的模块要做什么,才能更好地开发好这个模块。

2、阅读代码时没有把握住主线

对项目整体框架有一定了解之后,我让他去看上层的业务逻辑模块,因为业务逻辑模块直接跟产品功能挂钩,看懂这个模块就可以很好地了解我们产品的功能。业务逻辑作为最上层的模块,下面一层好几个模块都对其服务,对其提供了很多接口。

这位小伙伴一开始看代码时,从第一个函数开始往下阅读,遇到嵌套好多层的代码,也一层一层点进去阅读,好像要试图看懂每个函数、每行代码,最后越看越懵。

我们在阅读某个模块的代码时,尽量沿着这个模块的主线去阅读,沿着主线尽可能快地弄清这个模块做的事情。

本模块可能会调用了其它模块的接口,而且可能还会嵌套好几层函数,我们只要大概知道这些接口实现了什么功能就可以,先不用一层一层地看、先不要去纠结其实现的细节。等我们弄懂本模块之后,日后对其它模块感兴趣再去仔细阅读其具体实现也不迟。

3、阅读代码时没有及时做一些总结笔记

这位小伙伴全面阅读某个模块的代码时,没有做一些自己的学习、理解记录,这就会导致看了后面部分,又忘了前面部分。

我们刚开始切入某个陌生的项目,并且代码量比较大的情况下,在阅读代码的过程中,很有必要做一些阅读笔记,便于自己反复阅读(有些代码不看好几遍可能理解得不透彻)的时候加深一些理解。

做笔记得方式可以是写一些注释描述、流程图、思维导图等。

学习、工作习惯

1、遇到不会的没有及时做笔记记录及学习

这位小伙伴刚开始对一些git常用命令及Linux常用命令不熟悉,我演示过几遍之后,后面再用到的时候,让他自己操作他也还不会。

我们刚开始参加工作时,需要一些很常用,但是又不能马上掌握的知识点要及时的记录写来、多用,直至掌握。特别是一些流程、步骤之类的,要记录下来、然后多操作几次,操作次数多了,就熟了。

我们做技术的,还是要有写文档、写总结的习惯,这会加深我们对某些知识的理解。写出来的技术总结,如果自己愿意,可以发到网上,或者自己本地存档。

2、总想一次性把基础补好

刚开始时,这位小伙伴整天阅读某个学习网站学习C语言知识。以前,我也有这种想法,但是我觉得你只要看懂C语言语法、知道if、else、for等,就可以直接去看项目代码了,从项目代码中去学习C语言的知识,项目代码中,遇到不会的C语言知识,针对性地去查资料进行学习,这样印象反而会更深一些。

其实看代码也可以分这么两种情况:

C语言基础比较差得情况下,阅读代码时可以先不管这些模块都实现了什么功能,就盯着这个模块用到的C语言知识,遇到不会的C语言知识就去查资料学习。

C语言基础比较好的情况,就可以看这个模块的具体实现及内部机理。

写代码

1、写代码之前没有思考清楚

刚开始时,这位小伙伴拿到工作任务时,还未想清楚就去写代码了,导致在开发的过程中,反复地进行修改。

在接到一个开发任务时,我们首先要弄清楚需求并大致想清楚整体的实时流程,至少要保证大的方向没错,否则一上来就去编码,这可能会做很多无用功。

2、写代码不注重编码规范

可能是在学校时养成了不是很好的编程习惯,导致他没有及时地改过来。我们业务自己开发一些小项目时,可以有自己遵循的一套编码规范。

但是,与他人协同开发一个项目,还是要尽量跟着项目遵循的规范来进行编码,特别的,在某个模块里添加代码时,最好参照该模块的编码风格进行编码,这样至少可以保证整个模块的风格是统一的。

3、写完代码没有检查

以前在学校,考试的时候,老师常常强调答卷做完了要仔细检查检查。同样的,我们软件开发中,平时写完代码,也有必要检查一下自己写的代码,看看有没有比较明显的编码错误,否则等到调试阶段,出问题可能要找半天。

比如这位小伙伴某次写case时忘记写break了,出问题了,他很懵,还觉得问题很奇怪。

分析问题

1、遇到问题没有仔细阅读问题说明

我们遇到问题时,要尽可能地去查找原因。特别的,有些问题是有一些比较明显的问题反馈的,比如编译错误、git冲突等。这也是这位小伙伴目前比较欠缺的,遇到问题常常忽略掉问题的提示。

2、遇到问题不会加一些必要的日志定位问题

平时,开发调试,遇到问题是很正常的事情,有时候加几条打印就可以定位到问题的所在,却一直盯着代码查半天。特别的,刚接手某个模块,对这个模块不是很熟的情况,可以多加一些日志打印,可以很好地帮助我们去理解该模块。

3、容易被问题的表象迷惑

好几次,遇到问题,他跟我描述问题都是:xxx可以正常运行,xxx不行,然后怀疑xxx出了问题。

我们平时遇到问题,还是要有理有据地去定位、分析问题,不能瞎猜。更不能害怕问题,我们要清楚,遇到越多地问题,解决越多的问题,我们成长得越快!

审核编辑 :李倩

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

    关注

    7

    文章

    2695

    浏览量

    47433
  • 函数
    +关注

    关注

    3

    文章

    4327

    浏览量

    62573
  • 代码
    +关注

    关注

    30

    文章

    4780

    浏览量

    68527

原文标题:初学者注意这几点,可以少走一些弯路!

文章出处:【微信号:C语言编程,微信公众号:C语言编程】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    如何选择合适的数字孪生开发平台?这几点注意

    选择合适的数字孪生开发平台对于企业和组织来说至关重要,因为它直接影响到数字孪生项目的成功实施和未来发展。在考虑数字孪生开发平台时,需要综合考虑多个因素,以确保选择最适合自身需求的平台。以下是一些需要
    的头像 发表于 12-03 14:54 103次阅读

    电子电器气密性检测仪使用方法:操作中的常见错误与纠正

    电子电器气密性检测仪是确保产品质量的关键设备,但在使用过程中,操作人员常犯一些错误,导致测试结果不准确或仪器损坏。以下是一些常见的操作错误及其纠正方法,旨在帮助操作人员正确使用气密性检测仪。常见错误
    的头像 发表于 11-29 11:20 135次阅读
    电子电器气密性检测仪使用方法:操作中的常见错误与<b class='flag-5'>纠正</b>

    分享一些常见的电路

    理解模电和数电的电路原理对于初学者来说可能比较困难,但通过一些生动的教学方法和资源,可以有效地提高学习兴趣和理解能力。 下面整理了一些常见的电路,以动态图形的方式展示。 整流电路 单相桥式整流
    的头像 发表于 11-13 09:28 285次阅读
    分享<b class='flag-5'>一些</b>常见的电路

    LED驱动器应用的一些指南和技巧

    电子发烧友网站提供《LED驱动器应用的一些指南和技巧.pdf》资料免费下载
    发表于 09-25 11:35 0次下载
    LED驱动器应用的<b class='flag-5'>一些</b>指南和技巧

    选择运算放大器应该注意一些什么呢?

    运算放大器的选择应该注意一些什么呢?
    发表于 09-13 06:55

    java反编译的代码可以修改么

    的影响。 1. Java反编译工具 在Java反编译领域,有一些知名的工具可以帮助开发者将字节码转换回源代码。这些工具包括: JD-GUI :个图形界面的反编译工具,
    的头像 发表于 09-02 11:00 651次阅读

    FPGA电路设计的一些技巧

    FPGA设计有别于DSP和ARM系统,相比之下较为灵活和自由。主要是设计构思好专用管脚的电路,通用I/O的连接可以自身定义。因而,FPGA电路设计中会有一些独特的方法能够参照。 FPGA管脚兼容性
    发表于 07-21 20:20

    【《软件开发珠玑》阅读体验】+ 初识

    着为自己摘下“只会写代码”的标签了。相信在未来的职业生涯中,这本书给我带来的知识能让我在各个地方发光发热,在某种意义上可以帮我突破一些瓶颈。 同样,我期望这本书也能在正在阅读此书的你未
    发表于 06-21 16:33

    STM32F103程序移植到F105上,中断不能及时响应的原因?怎么解决?

    为什么F103可以及时响应中断,F405在外设运行时无法及时响应外部中断呢? 奇怪的是,如果把(Optimize for time)选上、把优化级别由0改为2,延迟会明显一些,但
    发表于 04-23 08:07

    注意这几点,安规电容用到老

    安规电容是电子电路的关键元件,确保电路稳定运行。选择适合的安规电容、正确安装和安放、合理使用和维护,可延长其使用寿命和提高电路稳定性。定期检查和维护安规电容,及时处理潜在问题,是确保电路长期稳定运行的关键。
    的头像 发表于 04-22 09:26 421次阅读
    <b class='flag-5'>注意</b><b class='flag-5'>这几点</b>,安规电容用到老

    注意这几点,安规电容用到老

    安规电容是电子电路的关键元件,确保电路稳定运行。选择适合的安规电容、正确安装和安放、合理使用和维护,可延长其使用寿命和提高电路稳定性。定期检查和维护安规电容,及时处理潜在问题,是确保电路长期稳定运行的关键。
    的头像 发表于 04-22 09:25 325次阅读
    <b class='flag-5'>注意</b><b class='flag-5'>这几点</b>,安规电容用到老

    深圳恒兴隆|心机主轴:全方位让您的心机主轴更心.

    、航空航天:机主轴用于航空航天行业的零部件加工,如飞机发动机的加工;4、通用机械:机主轴也用于一些通用机械行业,如轴承加工。四、心机主轴的维护与保养1、定期进行润滑油更换,保证润滑系统的正常工作;2、清洁
    发表于 04-15 10:36

    刚工作,代码太多没头绪?怎么办?

    不想错过,右上角设为星标最近有位问:刚参加工作,看不懂代码?这篇文章我们就来简单分享一些代码的经验。1、了解项目整体架构在阅读嵌入式代码
    的头像 发表于 03-25 08:09 651次阅读
    刚工作,<b class='flag-5'>代码</b>太多没头绪?怎么办?

    PSOC Creator 4.4中是否有一些设置可以阻止strtok操作?

    我需要一些帮助才能开始使用这个功能。 我做了个简单的代码,意图用逗号作为分隔符来标记字符串。 我尝试在 PC 上模拟以下代码并将其改编为 PSoc5LP: [i]int 主要 ()
    发表于 01-24 08:31

    如何纠正三相电源相序

    如何纠正三相电源相序    纠正三相电源相序错误是电气工程中个非常重要的任务。相序错误可能会导致电气设备损坏、功率因数下降、电路故障等严重后果。因此,我们需要在实际工作中及时发现和
    的头像 发表于 01-04 14:30 6121次阅读