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

    文章

    2849

    浏览量

    53432
  • 函数
    +关注

    关注

    3

    文章

    4421

    浏览量

    67822
  • 代码
    +关注

    关注

    30

    文章

    4976

    浏览量

    74370

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

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

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

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    07. 如何在Allegro中设置可以线但不能铺的铜区域?| 芯巧Allegro PCB 设计小诀窍

    背景介绍:我们在进行PCB设计时,经常需要绘制一些禁止铺铜但是允许线的区域,如果我们直接使用Route Keepout绘制的话,虽然可以实现在此区域内禁止铺铜的效果,但是线在此区域
    发表于 04-09 17:23

    无刷电机驱动板怎么选?看完这篇 90% 弯路

    ,抓住核心逻辑,新手也能次选对,今天钿驰科技小编就把最实用的选型技巧、避坑要点说透,帮你90%的冤枉路。 先纠正个最常见的误区:很多
    的头像 发表于 04-03 17:26 654次阅读
    无刷电机驱动板怎么选?看完这篇<b class='flag-5'>少</b><b class='flag-5'>走</b> 90% <b class='flag-5'>弯路</b>

    是否有显示控制器真正可以处理的 DRM 像素格式列表?

    是否有显示控制器真正可以处理的 DRM 像素格式列表? 目前内核公开以下格式: RGB: RGB565, XRGB8888, ARGB8888, ABGR8888 Packed YCbCr
    发表于 03-31 07:43

    别急着动手写代码:先想清楚这几点,后面改八百回

    实践的几条路径,设计模式不是银弹,但理解背后的原则,能帮我们一些弯路、什么算“高质量”的软件 很多人把“能运行”等同于“好”。其实
    的头像 发表于 03-24 11:43 383次阅读
    别急着动手写<b class='flag-5'>代码</b>:先想清楚<b class='flag-5'>这几点</b>,后面<b class='flag-5'>少</b>改八百回

    LT117A/LT317A、LM117/LM317正可调稳压器:设计与应用全解析

    、LM117/LM317这几正可调稳压器,看看它们有哪些特性、如何应用以及在设计中需要注意的要点。 文件下载: LM117.pdf 、特性亮点 高精度输出
    的头像 发表于 03-20 16:00 372次阅读

    【「龙芯之光 自主可控处理器设计解析」阅读体验】+可测试性设计章节阅读与自己的一些感想

    作为嵌入式底层开发,对第四章可测试性的内容比较感兴趣,因为嵌入式底层开发如何测试是个很重要的内容,一些芯片的可测试性设计做得很好,就更方便调试与查找问题有开发。 所以就来阅读下本章,分享下书中内容
    发表于 01-15 23:30

    使用RTOS时需要注意几点内容分享

    RTOS产品代码和速度快,现在RTOS还提升了致性。RTOS除能很快完成任务外,还能保证很好地完成任务。 在许多应用中,个迟到的结果可以
    发表于 12-23 06:34

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

    ,所有的知识点感觉串了起来,豁然开朗。第:是因为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 1248次阅读

    Debian和Ubuntu哪个好一些

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

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

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