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

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

3天内不再提示

如何才能让代码更简单?

Q4MP_gh_c472c21 来源:技术让梦想更伟大 作者:李肖遥 2021-03-17 09:42 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

不知道大家有没有这样的经历,当你来到一个新的公司或者是接手一个新的项目的时候,最怕的就是看前任的代码(外加没有文档),最气人的还是,连简单的注释都没有多少,每当遇到这种情况都想把前任程序员拉出来毙了。

吐槽归吐槽,谁的新欢不是谁的旧爱呢?自己写完的项目可能也要交给后来人,那我们可能是想被毙掉的那一位了。我仔细想了想,可能一切的锅都得归于我们写代码时候的炫技。

程序语言都会提供这样的或者那样的特性,这些特性在某些时候可以帮助我们省些代码或者在特定情况帮助我们减少失误带来的影响。我相信存在即合理,然而语言的有些特性并不是什么好东西,很多特性都经不起时间的考验(代码的不断迭代),最后带来的bug可能很难找到。

还有一点,我相信每个程序员都想要写好代码,或者认为短小精悍的代码才算好。我们也会经常吹牛逼说:这个功能别人要写100行,我不到一半行就搞定了。不是说不好,但是很多情况,利用语言里的一些特殊构造来缩减代码可能会让人难以理解。

也就是说:并不是语言提供什么特性,我们就一定要使用起来。实际上我们只需要其中很小的一部分功能,就能写出优秀的代码,实现特定的功能。

下面我根据一些经验,针对一些有问题的语言特性,规范一些代码,为什么这样能让代码更简单。

切记不要省略花括号

这个相信大家都有体会,也是经常会这么用的,比如:

if (condition1) action1();

而不是

if (condition1){ action1(); }

这种情况最起码可以省了一两行代码了,而且也还算是很好看。但是这样也会经常引起一些意想不到的问题,比如,在后面想要多加一句话action2()到这个if里面,有可能会把代码改成:

if (condition1) action1(); action2();

这可不是python,当我们都有缩进的时候,潜意识里肯定是以为它们是在一起的,以为它们只会在if的条件为真的时候执行,然而action2()却其实在if外面,它会被无条件的执行。

看似很简单的问题,可能都很容易发现这个错误,但实际上却容易被忽视。只要是if-else语句,把花括号全都打上,就可以不用担心漏掉了,相当于没这个特性,这样就可以保持完全的一致性,减少不必要的思考。

if (condition1){ action1(); action2(); }

避免使用自增减表达式(i++,++i,i–,–i)

我们总喜欢骚操作,在我之前写过的一篇文章中 浅析C语言中一些“令人吃惊”的结构 ,表明C语言会同意一些“令人震惊”的结构,但实际上自增减操作表达式其实是历史遗留的设计失误。

像是c = a+++++b;这种类型的表达式含义比较蹊跷,非常容易弄错,混淆缠绕在一起,把语义搞得乌七八糟。

这种表达式的结果可能取决于求值顺序,在某种编译器下能正确运行,换一个编译器就可能出现离奇的错误了,当然这个我并没有验证,但这种看起来太骚了。

如果你想写function(i++),你完全可以把它拆成

int t = i; i += 1; function(t);

这两个表达式分解成两步,如果想写function(++i),可以拆成

i += 1; function(i);

拆开之后的代码,含义完全一致,却清晰很多。到底更新是在取值之前还是之后,一目了然。

当然我们也会有更细致的争论,例如:i++或者++i的效率比拆开之后要高,当看到这种究根源的结论我其实是很感兴趣的,但实际上这些代码经过基本的编译器优化之后,生成的机器代码是完全没有区别的。

而且自增减表达式只有在for循环的update部分、写成单独的一行这两种情况下才可以安全的使用,这两种情况是完全没有歧义的。其余情况需要避免使用,比如用在复杂的表达式里面,比如function(i++),function(++i)等等。

合理使用括号

使用括号可以确保表达式的优先级,而我们总是不大喜欢在表达式中添加括号,但是盲目依赖操作符优先级往往得不偿失。

当然对于简单的加减乘除我们可以使用,比如1+4*9,而不需要写成1+(4*9),然而在一些稍微复杂一点的表达式中我们可能不喜欢括号,比如1《《2+4*9。

当然,这也考研我们的基本功,但我相信移位操作《《的优先级,大部分人第一眼可能是不大熟悉的,所以这导致了我们再一次废了多一点脑子或者Google了一下。

由于x 《《 1相当于把x乘以2,那么这个表达式可能会被误以为(1《《2)+(4*9),然而实际上《《的优先级比加法+还要低,所以这表达式其实相当于1《《(2+4*9)

解决这个问题的办法,不是要求每个人都去把操作符优先级表给硬背下来,而是合理的加入括号。虽然没有括号也表示同样的意思,但是加上括号就更加清晰了,是不是呢?

总结

再次声明,这里只是举了几个简单的例子,所谓存在即合理,特性既然存在肯定是在某种特定情况下有用武之地的,这一点我们毋庸置疑。

但实际到我们自己敲的代码,或者在工程应用中,为了避免花过多的时间与精力放在这种费眼睛、费脑子的事情上,是适得其反的。

我们需要写简单的代码,需要看简单的代码,需要没有歧义与争论的代码,这才是我们的终极目标,希望本文所阐述的思想对大家有用处。

原文标题:如何写简单的代码?

文章出处:【微信公众号:嵌入式ARM】欢迎添加关注!文章转载请注明出处。

责任编辑:haq

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

    关注

    30

    文章

    4942

    浏览量

    73191

原文标题:如何写简单的代码?

文章出处:【微信号:gh_c472c2199c88,微信公众号:嵌入式微处理器】欢迎添加关注!文章转载请注明出处。

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

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    TQKIT开发板工具让系统功能调用简单

    TQKIT开发板工具,将复杂的系统控制能力以接口形式开放给开发者,让系统功能调用简单
    的头像 发表于 12-08 09:27 160次阅读
    TQKIT开发板工具让系统功能调用<b class='flag-5'>更</b><b class='flag-5'>简单</b>

    编写简单高效单片机汇编程序

    ,避免重复编写。 宏指令:编写重复代码块时,把它封装为宏指令,并用传参简化,比如显示数字(数码管号, 数值)。这样能让代码简洁。 子程序调用:像时钟显示刷新这种逻辑,可以写成子程序
    发表于 11-24 07:00

    怎么能让riscv32-unknown-elf-gcc支持e203?

    https://github.com/ilg-archived/riscv-none-gcc 自己在这个地方下载的riscv32-unknown-elf-编译器代码 ./configure
    发表于 11-10 07:06

    力芯微LCD驱动IC:高集成度“芯”优势让显示简单

    在当今数字化时代,显示屏无处不在。然而,随着设备小型化、高性能化的需求不断增加,如何在有限的空间内实现更强大的显示功能,成为了一个亟待解决的问题。力芯微LCD驱动IC:高集成度“芯”优势让显示简单
    的头像 发表于 10-15 16:08 335次阅读
    力芯微LCD驱动IC:高集成度“芯”优势让显示<b class='flag-5'>更</b><b class='flag-5'>简单</b>

    代码格式化工具Clang-Format提升你的CW32工程质量

    它能自动统一团队代码风格,让不同开发者写出的代码如出一辙。就像 CW32 官方库函数遵循统一规范一样,Clang-Format 能让团队所有成员的代码瞬间保持一致,彻底消除 "tabs
    的头像 发表于 10-09 17:43 922次阅读
    <b class='flag-5'>代码</b>格式化工具Clang-Format提升你的CW32工程质量

    告别代码迷宫!exgnss扩展库让GNSS定位开发秒变简单

    还在为GNSS定位的复杂代码头疼?exgnss扩展库为你扫清障碍!它提供简洁的接口和高效的工具链,从信号捕获到坐标解析一气呵成,开发效率直线飙升。 一、exgnss库的三种应用模式 exgnss库
    的头像 发表于 09-10 17:23 654次阅读
    告别<b class='flag-5'>代码</b>迷宫!exgnss扩展库让GNSS定位开发秒变<b class='flag-5'>简单</b>

    嵌入式系统中,FLASH 中的程序代码必须搬到 RAM 中运行吗?

    Flash,通常都是让代码直接在 Flash 里运行。这类芯片的设计侧重成本,面对的任务也多是简单的控制逻辑,比如玩具里的动作控制、传感器的数据采集等,Flash 虽
    的头像 发表于 08-06 10:19 1160次阅读
    嵌入式系统中,FLASH 中的程序<b class='flag-5'>代码</b>必须搬到 RAM 中运行吗?

    使用stm32u575rg通过spi读取外置adc的数据,如何设置才能让spi不需要中断重启持续读取数据?

    DBL_1=3,DINC=1, BNDT=64. 测试时候发现SPI只能读取2组数据,共8个字节,EOT=1. 需要开启EOT中断然后再中断函数中重新关闭再开启SPI才能继续读数据。如何设置才能让spi不需要中断重启持续读取数据
    发表于 07-10 08:22

    大语言模型火爆的今天,我们为什么还要拥抱世界模型?

    多点发力,协同并进,才能让AI的成长有更多道路可走
    的头像 发表于 04-11 14:57 1714次阅读
    大语言模型火爆的今天,我们为什么还要拥抱世界模型?

    光伏电站智能运维系统让阳光财富简单

           光伏电站智能运维系统让阳光财富简单        在双碳目标的推动下,光伏发电仪成为绿色能源的主力军。然而,随着光伏电站越建越多、规模越来越大,传统的人工管理方式却显得力不从心—设备
    的头像 发表于 03-17 15:33 698次阅读
    光伏电站智能运维系统让阳光财富<b class='flag-5'>更</b><b class='flag-5'>简单</b>

    光伏电站智能分析管理系统让电站管理简单

    光伏电站智能分析管理系统让电站管理简单 光伏电站建好后,管理才是真正的考研。过去靠人工巡检,设备坏了要等好几天才能发现,发电损失让人心疼。现在,光伏电站智能分析管理系统就能让电站自己
    的头像 发表于 03-14 15:20 807次阅读
    光伏电站智能分析管理系统让电站管理<b class='flag-5'>更</b><b class='flag-5'>简单</b>

    DevEco Studio 联合小艺接入 DeepSeek,步骤简单开发鸿蒙专业

    所有的代码,并且希望快点看到效果 按照提供的代码,将整个工程进行代码和资源的填充和简单修改,马上一个富有设计元素,拥有点击动效的个人IP首页就可以马上运行了,整个过程不到半个小时,是不
    发表于 03-13 15:11

    STM32WB09KEV6TR生成的代码需要改哪些地方才能实现开启BLE?

    想问一下我利用STM32WB09KEV6TR生成的代码还需要改哪些地方才能实现开启BLE,并且发现GATT服务,麻烦大佬指点一下,我需要看哪些文档~
    发表于 03-13 06:58

    爱立信如何让网络运维简单

    在爱立信“可编程网络”这一创新概念里,差异化连接、AI赋能和意图驱动、网络能力开放作为三大基石,各司其职,让网络智能、更灵活、开放。本期《信观察》,爱立信专家将从AI赋能和意图驱动的概念和功能入手,与您分享爱立信如何“让网络运维
    的头像 发表于 03-03 09:27 1w次阅读

    如何给ADS1247发送指令,才能让它开始转换温度?

    最新在使用ADS1247测量PT100,MCU51模拟SPI访问ADS1247,可以读写所有的寄存器。但是无法测量温度,DOUT交永远是低电平,而且差分电压也总是0.000V。想请问,应当如何给ADS1247发送指令,才能让它开始转换温度。
    发表于 01-22 06:25