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

    文章

    3643

    浏览量

    94128
  • 代码
    +关注

    关注

    30

    文章

    4841

    浏览量

    69225
  • 程序员
    +关注

    关注

    4

    文章

    953

    浏览量

    29888

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

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

收藏 人收藏

    评论

    相关推荐

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

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

    gitee 支持的编程语言有哪些

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

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

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

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

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

    网关的设置规则

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

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

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

    国内低代码平台推荐--万界星空科技低代码平台

    代码平台是一种应用程序,它为编程提供图形用户界面,从而以极快的速度开发代码,减少传统编程工作。 这些工具有助于快速开发代码,最大限度
    的头像 发表于 07-18 15:39 372次阅读
    国内低<b class='flag-5'>代码</b>平台推荐--万界星空科技低<b class='flag-5'>代码</b>平台

    请问在AT指令集中,是否支持连接中文名称的ssid,如何书写呢?

    请问在AT指令集中,是否支持连接中文名称的ssid,如何书写呢? 外部有一个名称为“哈”的路由器,下面这个命令提示找不到相关ap AT+CWJAP_DEF=\"哈\",\"12345678\"
    发表于 07-16 07:09

    在STVD书写代码的时候,一写到“{}”就自动顶格了怎么解决?

    在STVD书写代码的时候,一写到“{}”就自动顶格了,好烦哪- -! 不知道哪里可以更改这个设置?
    发表于 05-17 07:34

    如何提升代码质量与效率的秘诀

    提高编程能力其实没有捷径,最佳方式就是多写代码。 不过,除了写大量代码,提升编程能力还需要大量阅读别人写的代码
    的头像 发表于 04-28 14:53 481次阅读
    如何提升<b class='flag-5'>代码</b>质量与效率的秘诀

    微软Edge浏览器新增文本编辑功能:引入Compose和数字书写功能

    除此之外,Edge 浏览器也对 Windows Ink 的手写体验进行了优化提升。现在,用户可在浏览器地址栏、文本区及“contenteditable”属性的区域内使用数字书写功能。
    的头像 发表于 04-24 15:26 762次阅读

    谷歌发布用于辅助编程代码大模型CodeGemma

    谷歌发布了用于辅助编程代码大模型 CodeGemma。CodeGemma 基于谷歌今年 2 月发布的轻量级开源大模型 Gemma,针对 Gemma 的两个不同参数规模的版本 Gemma 2B 和 Gemma 7B 发布了 CodeGemma 2B 和 CodeGemma
    的头像 发表于 04-17 16:07 796次阅读
    谷歌发布用于辅助<b class='flag-5'>编程</b>的<b class='flag-5'>代码</b>大模型CodeGemma

    阿里云内部全面推行AI写代码

    阿里云正在内部全面推行 AI 编程,使用通义灵码辅助程序员写代码、读代码、查 BUG、优化代码等。
    的头像 发表于 04-07 09:22 617次阅读

    Altium Designer电气规则设置后无报错原因解析

    可是很多时候我们明明是在规则编辑器里面设置了规则的,为什么在我们规则之外的时候它竟然不报错呢?是哪里设置不对吗?
    发表于 03-28 09:35 2244次阅读
    Altium Designer电气<b class='flag-5'>规则</b>设置后无报错原因解析

    代码检查的方式有三种

    【摘要】 代码检查中,提到的编程规范,规则集,规则规则用例(场景、误报、检出)分别代表什么意思呢? 在 SAST 静态检查领域,
    的头像 发表于 02-25 10:08 953次阅读
    <b class='flag-5'>代码</b>检查的方式有三种