• More Effective C++ (限制类的对象数量)


    如何禁止产生类对象呢?只要将类的构造函数用private修饰即可。

    那么,如何限制类只能产生一个类对象呢?只要借助于友元函数的static对象即可。

    示例代码如下:

     1 class Printer  
     2 {  
     3 private:  
     4     Printer()  
     5     {  
     6         cout<<"thePrinter constructed"<<endl;  
     7     }  
     8 public:  
     9     void what()  
    10     {  
    11         cout<<"It's a printer"<<endl;  
    12     }  
    13     friend Printer & thePrinter();  
    14 };  
    15 
    16 Printer & thePrinter()  
    17 {  
    18     static Printer p;  
    19     return p;  
    20 } 

    这样一来,Printer类的对象就只有唯一的p,而且只有在首次调用thePrinter函数时才生成,不调用就不生成。

    而将类的构造函数用private修饰还有另外一个作用:禁止类被继承。任何想要继承Printer的新类都不能顺利构造出对象来。

    接下来就应该讨论限制类所能产生的对象数量为N(N>1)的情况了。不过在正式提出解决方案之前,首先来了解一下伪构造函数。

    所谓伪构造函数就是类的一种static函数,它能够产生对象,作用就像构造函数。

    之所以需要构造函数,是因为类真正的构造函数现已被private修饰,不能被外界调用。

    仍然以Printer为例,删除友元函数thePrinter,为类添加static Printer* makePrinter()成员函数。

    示例代码为:

     1 class Printer  
     2 {  
     3 private:  
     4     Printer()  
     5     {  
     6         cout<<"thePrinter constructed"<<endl;  
     7     }  
     8 public:  
     9     void what()  
    10     {  
    11         cout<<"It's a printer"<<endl;  
    12     }  
    13     static Printer* makePrinter()  
    14     {  
    15         return new Printer();  
    16     }  
    17 }; 

    如此定义的Printer类就没有生成对象数量上的限制了,但是它不允许被继承。makePrinter函数就是Printer类的伪构造函数。

    认识了伪构造函数之后再回到之前的问题:如何限制类所能产生的对象数量为N(N>1)?

    书中提出的方案是以上述伪构造函数为基础的,只要为Printer类添加一个计数就好了。

    示例代码如下:

     1 class Printer  
     2 {  
     3 private:  
     4     Printer()  
     5     {  
     6         cout<<"thePrinter constructed"<<endl;  
     7     }  
     8     static int counter;  
     9 
    10 public:  
    11     class TooManyObject  
    12     {  
    13         public:  
    14             void what()  
    15             {  
    16                 cout<<"Too many Object"<<endl;  
    17             }  
    18     };  
    19     void what()  
    20     {  
    21         cout<<"It's a printer"<<endl;  
    22     }  
    23     static Printer* makePrinter()  
    24     {  
    25         if(++counter>10)  
    26         {  
    27             cout<<"Stop "<<endl;
    28             exit(1);
    29         }  
    30         return new Printer();  
    31     }  
    32 };  
    33 int Printer::counter=0; 

    上面代码实现出的Printer类被限制只能最多产生10个对象。

    Good Good Study, Day Day Up.

    顺序  选择  循环  坚持

    作者:kaizen
    声明:本文版权归作者和博客园共有,欢迎转载。但未经作者同意必须保留此声明,且在文章明显位置给出本文链接,否则保留追究法律责任的权利。
    签名:顺序 选择 循环
  • 相关阅读:
    C++中static_cast, dynamic_cast使用方法
    JavaScript中的Boolean 方法与Number方法
    參数预计:最大似然预计、贝叶斯预计与最大后验预计
    漫谈程序控制流
    怎样使用 RMAN 增量备份恢复 data guard log gap(日志断档)
    Unity3d修炼之路:GUIbutton简单使用,完毕对一个简单对象Cube的移动,旋转
    Python写自己主动化之邮件发送(匿名)
    LintCode
    缓存之 ACache
    Android Studio:Multiple dex files define Landroid/support/annotation/AnimRes
  • 原文地址:https://www.cnblogs.com/Braveliu/p/2847726.html
Copyright © 2020-2023  润新知