• 条款25 :尽可能延后变量定义式的出现时间


    只要你定义了一个变量,而类型带有一个构造函数和一个析构函数,你就得忍受构造成本与析构成本。或许你认为你不可能定义一个不会使用的变量,但是请看下面的代码:

    std::stringencryptPassword(conststd::string&password){

        usingnamespacestd;

        stringencrypted;

        if(password.length()<MinimumPasswordLength){

               throwlogic_error("password is short");

        }

        ...

        returnencrypted;

    }

    对象encrypted并非完全没有被使用,但是当抛出异常时,这个对象确实没有被使用,但是你仍旧要忍受起encrypted对象的构造,析构成本。最好的方法是延后encrypted对象的定义式,直到确实需要它时。

    std::stringencryptPassword(conststd::string&password){

        usingnamespacestd;

        if(password.length()<MinimumPasswordLength){

               throwlogic_error("password is short");

        }

        stringencrypted; //延后encrypted对象的定义式

        ...

        returnencrypted;

    }

    假设encryptPassword函数最艰难的部分在以下这个函数中进行:

    voidencrypt(std::string&s);

           则我们的encryptPassword函数可以这样实现:

    std::stringencryptPassword(conststd::string&password){

        usingnamespacestd;

        ...// 检查length,如前

        stringencrypted;

        encrypted=password;

        encrypt(encrypted)    

        returnencrypted;

    }

           我们还可以接着去改进:我们知道上例中的encrypted是先定义,并调用了默认的构造函数,再用password进行赋值。这样,效率是比较低的,我们完全可以直接初始化。

           std::stringencryptPassword(conststd::string&password){

           usingnamespacestd;

           ...//

           stringencrypted(password);   

           encrypt(encrypted)    

           returnencrypted;

    }

     

    在这里我们再次讨论“尽可能延后”的真正意义。你不只应该延后变量的定义,直到非得使用该变量前一刻为止,而是应该尝试延后这份定义直到能够给它初值实参为止。

  • 相关阅读:
    iphoneX适配
    是时候啃一啃http跟https了
    使用阿里巴巴矢量图标库的图标
    react使用高阶组件进行界面跳转
    js性能提升之函数的防抖和节流
    vuex的一些需要知道的点
    react项目之使用猪齿鱼框架---dataSet的基础使用
    从js下手提升代码性能
    vue+ts搭建工程
    学习笔记之TypeScript语法一
  • 原文地址:https://www.cnblogs.com/loveyakamoz/p/2772415.html
Copyright © 2020-2023  润新知