effective C++ 读后感(六)若不想使用编译器自动生成的函数,就该明确拒绝

本文详细介绍了如何在C++中通过将析构函数、复制构造函数、复制赋值运算符声明为private来自定义类的行为,以避免编译器自动生成这些函数。并通过定义基类的方式进一步限制类的功能。

六、若不想使用编译器自动生成的函数,就该明确拒绝

前一节讲过,如果代码中没有声明,编译器会自动生成一个析构函数,copy构造函数,copy assignment操作符和一个无参数的构造函数,而有些时候,我们并不希望某个类具有全部(或部分)这些功能。如对于一些独一无二的对象(如房子),我们不希望它能被赋值或拷贝,该怎么办呢?这似乎出现了矛盾,一方面,如果不想让编译器生成这些函数,需 要在代码中将这些函数显示声明出来,而我们恰恰不希望类有这样的功能!其实并不是这样,在前一节里,我们也可以看出来,问题关键在于编译器自动生成的这些函数都是public的,如果我们在代码中将其声明为private的,问题基本上就解决了。


为什么说是“基本上”解决呢?不要忘了还有友元函数和成员函数还是可以调用它们的。所以,真正的解决方法有两个:

一、将这些方法声明为private,而且不实现它。那么当成员函数或友元函数调用这些方法时,虽然在编译时期查不出错误,但在链接时期会出错。

二、如果希望都在编译时期就能查出错误(毕竟越早发现错误越好),则可以定义一个基类,将这此方法声明为private的,让那些不想编译器生成这些方法的类都继承自这个类。如,我们希望一个类A不能被复制(即不希望编译器自动生成copy构造函数和 copy assignment操作符,可以定义一个Uncopyable类如下:

#include <iostream>
using namespace std;

class Uncopyable {
public:
	Uncopyable(){}
	~Uncopyable(){}
private:
	Uncopyable(const Uncopyable &);
	Uncopyable& operator=(const Uncopyable &);
};

class A: public Uncopyable {

};

这样,就算是A的成员函数和友元函数都不能复制A的对象了。


在Boost中的noncopyable就是这样实现的:

#ifndef BOOST_NONCOPYABLE_HPP_INCLUDED
#define BOOST_NONCOPYABLE_HPP_INCLUDED

namespace boost {

//  Private copy constructor and copy assignment ensure classes derived from
//  class noncopyable cannot be copied.

//  Contributed by Dave Abrahams

namespace noncopyable_  // protection from unintended ADL
{
  class noncopyable
  {
   protected:
      noncopyable() {}
      ~noncopyable() {}
   private:  // emphasize the following members are private
      noncopyable( const noncopyable& );
      const noncopyable& operator=( const noncopyable& );
  };
}

typedef noncopyable_::noncopyable noncopyable;

} // namespace boost

#endif  // BOOST_NONCOPYABLE_HPP_INCLUDED


内容概要:本文档是一份关于交换路由配置的学习笔记,系统地介绍了网络设备的远程管理、交换机与路由器的核心配置技术。内容涵盖Telnet、SSH、Console三种远程控制方式的配置方法;详细讲解了VLAN划分原理及Access、Trunk、Hybrid端口的工作机制,以及端口镜像、端口汇聚、端口隔离等交换技术;深入解析了STP、MSTP、RSTP生成树协议的作用与配置步骤;在路由部分,涵盖了IP地址配置、DHCP服务部署(接口池与全局池)、NAT转换(静态与动态)、静态路由、RIP与OSPF动态路由协议的配置,并介绍了策略路由和ACL访问控制列表的应用;最后简要说明了华为防火墙的安全区域划分与基本安全策略配置。; 适合人群:具备一定网络基础知识,从事网络工程、运维或相关技术岗位1-3年的技术人员,以及准备参加HCIA/CCNA等认证考试的学习者。; 使用场景及目标:①掌握企业网络中常见的交换与路由配置技能,提升实际操作能力;②理解VLAN、STP、OSPF、NAT、ACL等核心技术原理并能独立完成中小型网络搭建与调试;③通过命令示例熟悉华为设备CLI配置逻辑,为项目实施和故障排查提供参考。; 阅读建议:此笔记以实用配置为主,建议结合模拟器(如eNSP或Packet Tracer)动手实践每一条命令,对照拓扑理解数据流向,重点关注VLAN间通信、路由选择机制、安全策略控制等关键环节,并注意不同设备型号间的命令差异。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值