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

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

3天内不再提示

编程代码的书写规则

Q4MP_gh_c472c21 ? 来源:嵌入式ARM ? 作者:嵌入式ARM ? 2020-11-12 18:03 ? 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

为大家搜集到编程代码的书写规则,小伙伴们千万要记住这些规则。

如果对现在的工作不满意,掌握这些技巧也是可以顺利离职的小窍门哦~

01 以一种代码已经被混淆的方式命名变量 如果我们键入的东西越少,那么就有越多的时间去思考代码逻辑等问题。Good

let a = 42;Bad

let age = 42; 02 变量/函数混合命名风格 为不同庆祝一下。Good

let wWidth = 640;let w_height = 480;Bad

let windowWidth = 640;let windowHeight = 480; 03 不要写注释 反正没人会读你的代码,看开点:Good

const cdr = 700;Bad 更多时候,评论应该包含一些“为什么”,而不是一些“是什么”。如果“什么”在代码中不清楚,那么代码可能太混乱了。

// 700ms的数量是根据UX A/B测试结果进行经验计算的。// @查看: <详细解释700的一个链接>const callbackDebounceRate = 700;(向右滑动查看完整代码) 04 使用母语写注释 如果您违反了“无注释”原则,那么至少尝试用一种不同于您用来编写代码的语言来编写注释。如果你的母语是英语,你可能会违反这个原则。Good

// Закрива?мо модальне в?конечко при виникненн? помилки.toggleModal(false);(向右滑动查看完整代码)Bad

// 隐藏错误弹窗toggleModal(false); 05 尽可能混合不同的格式 为不同庆祝一下。Good

let i = ['tomato', 'onion', 'mushrooms'];let d = [ "ketchup", "mayonnaise" ];Bad

let ingredients = ['tomato', 'onion', 'mushrooms'];let dressings = ['ketchup', 'mayonnaise'];

(向右滑动查看完整代码)

06 尽可能把代码写成一行

删繁就简三秋树。

Good

document.location.search.replace(/(^?)/,'').split('&').reduce(function(o,n){n=n.split('=');o[n[0]]=n[1];return o},{})(向右滑动查看完整代码)Bad

document.location.search .replace(/(^?)/, '') .split('&') .reduce((searchParams, keyValuePair) => { keyValuePair = keyValuePair.split('='); searchParams[keyValuePair[0]] = keyValuePair[1]; return searchParams; }, {})(向右滑动查看完整代码) 07 不要处理错误 无论何时发现错误,都没有必要让任何人知道它。没有日志,没有错误弹框。Good

try { // 意料之外的情况。} catch (error) { // tss... }Bad

try { // 意料之外的情况。} catch (error) { setErrorMessage(error.message); // and/or logError(error);} 08 广泛使用全局变量 全球化的原则。Good

let x = 5; function square() { x = x ** 2;} square(); // 现在x是25Bad

let x = 5; function square(num) { return num ** 2;} x = square(x); // 现在x是25 09 创建你不会使用的变量 以防万一。Good

function sum(a, b, c) { const timeout = 1300; const result = a + b; return a + b;}Bad

function sum(a, b) { return a + b;} 010 如果语言允许,不要指定类型和/或不执行类型检查。

Good

function sum(a, b) { return a + b;} // 在这里享受没有注释的快乐const guessWhat = sum([], {}); // -> "[object Object]"const guessWhatAgain = sum({}, []); // -> 0(向右滑动查看完整代码)Bad

function sum(a: number, b: number): ?number { // 当我们在JS中不做置换和/或流类型检查时,覆盖这种情况。 if (typeof a !== 'number' && typeof b !== 'number') { return undefined; } return a + b;} // 这个应该在转换/编译期间失败。const guessWhat = sum([], {}); // -> undefined(向右滑动查看完整代码) 011 你应该有不能到达的代码 记住:这是你的 "Plan B"。Good

function square(num) { if (typeof num === 'undefined') { return undefined; } else { return num ** 2; } return null; // 这就是我的"Plan B".}(向右滑动查看完整代码)Bad

function square(num) { if (typeof num === 'undefined') { return undefined; } return num ** 2;}(向右滑动查看完整代码) 012 三角法则 就像鸟巢,鸟巢,鸟巢。这是艺术。Good

function someFunction() { if (condition1) { if (condition2) { asyncFunction(params, (result) => { if (result) { for (;;) { if (condition3) { } } } }) } }}(向右滑动查看完整代码)Bad

async function someFunction() { if (!condition1 || !condition2) { return; } const result = await asyncFunction(params); if (!result) { return; } for (;;) { if (condition3) { } }}(向右滑动查看完整代码) 013 混合缩进 避免缩进,因为它们会使复杂的代码在编辑器中占用更多的空间。如果你不喜欢回避他们,那就和他们捣乱。Good

const fruits = ['apple', 'orange', 'grape', 'pineapple']; const toppings = ['syrup', 'cream', 'jam', 'chocolate'];const desserts = [];fruits.forEach(fruit => {toppings.forEach(topping => { desserts.push([fruit,topping]); });})(向右滑动查看完整代码)Bad

const fruits = ['apple', 'orange', 'grape', 'pineapple'];const toppings = ['syrup', 'cream', 'jam', 'chocolate'];const desserts = []; fruits.forEach(fruit => { toppings.forEach(topping => { desserts.push([fruit, topping]); });})(向右滑动查看完整代码) 014 不要锁住你的依赖项 以非受控方式更新每个新安装的依赖项。为什么坚持使用过去的版本,让我们使用最先进的库版本。Good

$ ls -la package.jsonBad

$ ls -la package.jsonpackage-lock.json 015 函数长的比短的好 不要把程序逻辑分成可读的部分。如果IDE的搜索停止,而您无法找到所需的文件或函数,该怎么办?

一个文件中10000行代码是OK的。

一个函数体1000行代码是OK的。

处理许多服务(第三方和内部,也有一些工具、数据库手写ORM和jQuery滑块)在一个' service.js ' ,这是OK的。

016 不要测试你的代码 这是重复的并且不需要的工作。 017 避免代码风格统一 编写你想要的代码,特别是在一个团队中有多个开发人员的情况下。 这是一个“自由”的原则。 018 构建新项目不需要 README 文档 一开始我们就应该保持。 019 保存不必要的代码 不要删除不用的代码,最多是注释掉。 以上就是全部总结,大家可千万不要再犯哦。(别打我,网线不够粗,手伸不过来)

责任编辑:xj

原文标题:这样写的代码,都是垃圾......

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

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

    关注

    88

    文章

    3694

    浏览量

    95566
  • 代码
    +关注

    关注

    30

    文章

    4908

    浏览量

    71271
  • 程序员
    +关注

    关注

    4

    文章

    954

    浏览量

    30522

原文标题:这样写的代码,都是垃圾......

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

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

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    贞光科技代理品牌 | 三星电容物料编码规则

    核心规则,引用官方资料及行业解读一、贴片电容(MLCC)编码规则以典型型号CL03B104KQ8NNNC为例,分11段解析:位置代码含义可选值示例1-2CL系列编码
    的头像 发表于 08-07 15:51 ?237次阅读
    贞光科技代理品牌 | 三星电容物料编码<b class='flag-5'>规则</b>

    代码开发云平台是什么?零编程零成本搭建

    代码物联网云平台是种融合了低代码开发能力与物联网(IoT)技术的云端服务平台,其核心目标是大幅降低物联网应用的开发门槛和成本,让用户无需专业编程经验,也能快速构建、部署和管理物联网系统。 低
    的头像 发表于 07-31 15:25 ?241次阅读

    HarmonyOS AI辅助编程工具(CodeGenie)代码续写

    利用AI大模型分析并理解开发者在代码编辑区的上下文信息或自然语言描述信息,智能生成符合上下文的ArkTS或C++代码片段。 一、使用约束 建议在编辑区内已有较丰富上下文,能够使模型对编程场景有一定
    发表于 07-15 16:15

    上传示例代码后,CYPD3171不再可编程是怎么回事?

    我有一个使用 CYPD3171 芯片的定制板,用于定制移动电源应用。在第一个测试 PCB 上我上传了示例代码,但后来我发现我无法再对其进行编程。我查看了引脚排列的代码和 GUI,发现代码
    发表于 07-15 08:01

    贴片电解电容的命名规则涵盖哪些重要参数?

    贴片电解电容的命名规则通过标准化编码整合容量、耐压、尺寸等关键参数,是电子工程师选型的重要依据。其命名结构通常为 尺寸代码+材质标识+容量代码+耐压代码+端头/包装标识 ,以风华
    的头像 发表于 07-09 15:55 ?240次阅读

    KiCad 中的自定义规则(KiCon 演讲)

    “ ?Seth Hillbrand 在 KiCon US 2025 上为大家介绍了 KiCad 的规则系统,并详细讲解了自定义规则的设计与实例。? ” ? 演讲主要围绕 加强 KiCad 中的自定义
    的头像 发表于 06-16 11:17 ?803次阅读
    KiCad 中的自定义<b class='flag-5'>规则</b>(KiCon 演讲)

    MISRA C:2025新标准解析:新增规则、优化点与静态代码分析工具支持(Perforce QAC、Klocwork)

    MISRA C:2025?发布!新增5条规则,并对部分现有规则进行了扩展、重组,以进一步简化安全关键型系统的开发流程。如何实现最新MISRA合规性?
    的头像 发表于 05-08 17:58 ?1162次阅读
    MISRA C:2025新标准解析:新增<b class='flag-5'>规则</b>、优化点与静态<b class='flag-5'>代码</b>分析工具支持(Perforce QAC、Klocwork)

    使用 QWQ:32B 模型搭配 VSCode 的 Cline 插件实现自动化代码编程

    作者:算力魔方创始人/英特尔创新大使刘力 一,概述 随着人工智能技术的快速发展,自动化编程工具逐渐成为开发者的得力助手。QWQ:32B 模型是一种先进的自然语言处理模型,能够理解并生成高质量的代码
    的头像 发表于 03-21 18:12 ?696次阅读
    使用 QWQ:32B 模型搭配 VSCode 的 Cline 插件实现自动化<b class='flag-5'>代码</b><b class='flag-5'>编程</b>!

    基于BLE技术 智能手写笔解决方案:改变你的书写体验PTR5415

    方案说明: 我们的智能手写笔方案基于BLE技术,利用蓝牙低功耗连接手写笔与移动设备(如智能手机、平板电脑)之间的无线通信。可以实时将书写数据上传到手机APP及云端,及时有效的对书写数据进行存档及管理
    发表于 03-11 17:50

    代码与传统开发的区别 低代码与无代码开发的区别

    的工具和图形界面来缩短开发时间和降低技术门槛。以下是对低代码开发与传统开发的详细对比: 适用人群 传统开发 :主要适用于有经验、有基础的程序员,他们可以利用各种编码语言进行应用程序的创建。传统开发需要深厚的编程功底
    的头像 发表于 01-31 10:48 ?741次阅读

    gitee 支持的编程语言有哪些

    Gitee(码云)是一个基于 Git 的代码托管和研发协作平台,类似于 GitHub 和 GitLab。它支持多种编程语言,允许开发者托管和管理代码,进行版本控制,以及协作开发。以下是一些
    的头像 发表于 01-06 09:50 ?795次阅读

    Triton编译器与GPU编程的结合应用

    Triton编译器简介 Triton编译器是一种针对并行计算优化的编译器,它能够自动将高级语言代码转换为针对特定硬件优化的低级代码。Triton编译器的核心优势在于其能够识别并行模式,自动进行代码
    的头像 发表于 12-25 09:13 ?975次阅读

    PCB布线和布局电路设计规则

    常用的PCB设计规则
    发表于 11-09 14:10 ?113次下载

    网关的设置规则

    网关的设置规则涉及多个方面,包括硬件安装、网络连接、基本配置、高级配置以及安全设置等。以下是一篇关于网关设置规则的详细指南,旨在帮助用户正确配置和管理网关设备。
    的头像 发表于 09-30 11:48 ?5018次阅读

    AD9元器件间距规则如何设置

    在Altium Designer 9(简称AD9)中设置元器件间距规则,主要是为了确保PCB(Printed Circuit Board,印刷电路板)上的元器件之间保持适当的距离,以避免短路、干扰或
    的头像 发表于 09-02 15:26 ?9393次阅读