zoukankan      html  css  js  c++  java
  • 怎么才能写一个好代码

    给自己布置这个标体在这里的时候, 我就知道不是一个好的题目. 并且这个也是一个持续的体会和总结.

    当然, 对于一个好的代码的评判, 网上搜索可能一大推. 在多年coding后, 总结出来也会差不多.

    基本上大方向的:

    1. 可读性
    2. 可维护性
    3. 可扩展性

    从实际角度考虑的:

    1. 逻辑清晰
    2. 运行效率高
    3. 问题(bug)少

    进一步的:

    1. 算法上有调优处理 -- 可能归结为效率问题
    2. 有模式上的实现 -- 认为 模式是对逻辑清晰的一种命名, 将这个事情进行固化
    3. 模块之间的解耦 -- 多人开发,沟通协作上有利, 也利于编码的可读性

    所以, 理解一下, 代码好坏与否, 在于两大块:

    1. 代码的沟通上
      代码作为程序的实现, 更作为程序员之间的语言, 是大家的一个工作"沟通"之地, 高效沟通是基础
    2. 代码的实际运行上
      show me the code, 代码的高效产出结果才是目的

    所以, 到这里我还没有达到我表体要说的事情, 具体这些还是原则上的东西. 所以, 有没有一些具体的东西呢?

    我自己简单想了一下, 也争取做一个持续的总结整理, 这里只说一些具体的代码书写习惯以及风格上的东西

    多条件判断场景

    上代码, 经常遇到很多个条件下的判断的问题, 存在多个符合条件下的判断

    function whatYouWillSay(role) {
    
        const conditionA = ...;
        const conditionB = ...;
        const conditionC = ...;
    
        if (conditionA && conditionB && conditionC) {
            ...
        }
    
    }
    

    我的一个感觉就是非常不清晰, 别人读取这些条件判断的时候很不容易理解
    我的一个感觉比好的体验是: 如果过分复杂,(将判断条件单独提出这个再说)

    需要提取一些短路判断, 比如上边的判断

    function ...(){
        if (!conditionA){
            return ...
        }
    
        if (!condtionB) {
            return ...
        }
    
        if (!condtionC) {
            return ...
        }
    
        //到这里的条件肯定都是满足的了, 上边的判断尽量简单明了, 让大家知道是什么意思
        //并且方法命名上也能自解释
        return ...
    
    }
    

    要有默认值的返回

    对于一个方法, 首先要有一个判定, 我的输入和输出是什么, 然后再进行具体实现. 对于输出最好有一个默认值
    所以 typescript 这里做得就比较好, 如果有声明输出, 没有显示输出的话, 经常会提示错误

    function returnStr() : string {
    
        ...
    
    
        // 我是一个 str
        return 'defaultStr'
    }
    

    写法上尽量少的创建一些中间变量

    但是如果中间变量可以让代码更清晰的话, 那就创建吧. 这里想到一个例子, 比如对数组需要做一个统计返回的处理
    reducer 都可以进行实现.

    例如最普通的求和

    const arr = [];
    const sum = arr.reduce((sum, cur)=>sum+cur, 0);
    

    例如要去遍历一个数组, 但是需要根据数组输出一个东西 (其实类似上边的求和, 复杂了一些)

    const arr = [4,5,6];
    
    const effectYourSomething = arr.reduce((effect, item, index)=>{
        effect[item] = index
        return effect;;
    }, {})
    
    //输出
    {4: 0, 5: 1, 6: 2}
    
    

    总结

    一种习惯或者素养, 并且是一个不断持续的过程.

  • 相关阅读:
    些许注意事项(初学)
    第一个方法(初学)
    重载(初学)
    数组(初学)
    文件下载(初学)
    javaweb中上传视频,并且播放,用上传视频信息为例
    javaweb中上传图片并显示图片,用我要上传课程信息(里面包括照片)这个例子说明
    从后台servlet中,获取jsp页面输入的值,来删除用户一行信息
    第二式 观察者模式
    第一式 策略模式
  • 原文地址:https://www.cnblogs.com/asdfq/p/13377547.html
Copyright © 2011-2022 走看看