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

    文章

    2822

    浏览量

    52797
  • 函数
    +关注

    关注

    3

    文章

    4406

    浏览量

    66837
  • 代码
    +关注

    关注

    30

    文章

    4941

    浏览量

    73145

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

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

收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    【「高速数字设计(基础篇)」阅读体验】 + 书籍评测第

    ,所有的知识点感觉串了起来,豁然开朗。第:是因为PCB的电源线之间,是存在线阻抗的,负载设备的瞬间电源要求,通常是由其附近的去耦电容进行能量供给的;第二:去耦电容离负载越近,电容的电荷就能更
    发表于 11-09 10:31

    【高速数字设计(基础篇)】阅读体验之--书籍排版设计和目录架构及初步阅读

    图所示,书中的第21章就会讲到高速电路中常见的差分传输,里面有讲到关于差分传输线的一些很实用的PCB LAYOUT知识,并且还有对应的插图演示,在进行PCB layout时可以作为个不错
    发表于 11-06 22:49

    蜂鸟E203的浮点指令集F的一些实现细节

    降低功耗,因此如果多个IP核运算周期设计的不致,如乘法两个周期,加法个周期时,注意需要让乘法模块的clken多延时个周期。而为了节省片上面积且改善时序,我们参考了
    发表于 10-24 08:57

    Vivado浮点数IP核的一些设置注意

    Vivado浮点数IP核的一些设置注意点 我们在vivado2018.3中使用了Floating-point(7.1)IP核,可以自定义其计算种类及多模式选择。有时多种计算可以用同
    发表于 10-24 06:25

    U盘插上后串口打印CBW size error怎么解决?

    request size 18, transfer size 0 CBW size error rt_udisk_run =-8 之前调好的U_HOST的驱动,插入u盘后正可以正常挂载与读写,今天插了另个U盘后出现如上打印消息,查了
    发表于 10-13 06:53

    1688 拍立淘接口实战:从图像优化、工厂排序到供应链匹配(附可跑代码

    深耕B2B电商十余年,亲历1688拍立淘接口20+坑:从图像预处理、权限申请到工厂排序。本文详解核心参数、实战代码及多图验证、定制方案生成等高级技巧,助你实现“看图找厂”精准匹配,附可运行代码,新手也能
    的头像 发表于 10-09 10:39 290次阅读

    Debian和Ubuntu哪个好一些

    兼容性对比Debian和Ubuntu哪个好一些,并为您揭示如何通过RAKsmart服务器释放Linux系统的最大潜能。
    的头像 发表于 05-07 10:58 853次阅读

    、高压电源的使用需注意哪些问题?二、高压电源及其附件日常养护需注意几点

    、高压电源的使用需注意哪些问题? 刚关掉电源时不要接触高压输出电缆,接触前必须确保电源的输出电压已经为0。因为还有残余电压,尽管所有高压电源电源的设计都在带有各种保护电路、防漏电措施,但是为了保证
    发表于 04-23 15:40

    在i.MX RT 1176上正常运行代码时与使用IAR调试代码时存在一些奇怪的差异,为什么?

    我在 i.MX RT 1176 上正常运行代码时的行为与使用 IAR 调试代码时的行为之间存在一些奇怪的差异,并注意到这是由于堆栈指针的初始化方式造成的。 我的重置向量表将其指向 D
    发表于 03-17 07:26

    【「典型电子电路设计与测试」阅读体验】运算放大器电路阅读体验

    ,特别是在高可靠性和高精度要求的电路设计中。本书中设置直流电压为1V,电阻容差为平均分布5%,得出输出电压值。 通过对学习运算放大器电路的学习,感觉这本书非常好,例子都是典型的案例,参数的设置非常具有代表性,需要有定的基础,阅读时候,不懂的概念需要
    发表于 02-23 10:56

    20岁用上无线呼叫器——50年弯路

    ,也就是俗称的老年人呼叫器,20岁的年纪就用了老年人无线呼叫器——妥妥的50年弯路! 仓库无线呼叫器         在我国,人口的老龄化日益严重,为老人设计的智能呼叫产品却不多见,我们技术部研发了这款老人无线呼叫器
    的头像 发表于 01-07 16:34 678次阅读
    20岁用上无线呼叫器——<b class='flag-5'>少</b><b class='flag-5'>走</b>50年<b class='flag-5'>弯路</b>

    漏电开关使用误区及纠正

    漏电开关是现代电气安全中不可或缺的部分,它能够在检测到漏电时迅速切断电源,从而保护人身安全和设备不受损害。然而,在实际使用过程中,由于对漏电开关的认识不足或操作不当,常常会出现一些误区。 误区
    的头像 发表于 12-30 17:18 1219次阅读

    虹科直播 | 掌握这些,少走弯路!叶正祥老师教你NVH常见问题诊断技巧!

    ,就能更多弯路,直抵问题核心,省时省力更提升客户满意度!当然,经验是知识和实践的沉淀,非一朝一夕可得。但通过学习他人智慧成果,同样可以
    的头像 发表于 12-25 17:05 686次阅读
    虹科直播 | 掌握这些,少走<b class='flag-5'>弯路</b>!叶正祥老师教你NVH常见问题诊断技巧!

    串口设计一些关键注意点!千万别踩雷!

    本文将以Air700ECQ/EAQ/EMQ为例,带你从硬件设计的角度,起来了解串口设计中的一些关键注意点;软件开发或者AT设置方面不做深入探讨。   、串口相关管脚 Air700E
    的头像 发表于 12-25 17:01 976次阅读
    串口设计<b class='flag-5'>一些</b>关键<b class='flag-5'>注意</b>点!千万别踩雷!

    用AFE4400搭建血氧计,请问用AFE4400需要注意一些什么呢?

    准备自己用AFE4400搭建血氧计,请问用AFE4400需要注意一些什么呢? 我自己之前做了个,但是接通电源后,AFE4400不工作,晶振不起振,BG端电压为0,TX_REF端电压为电源电压。。 TX 和RX部分都使用的3
    发表于 12-17 06:55