前言
看了一段时间的UNP对Linux下网络编程有了一定程度的理解,经学长推荐,开始学习陈硕老师的《Linux多线程服务端编程》。看之前特地上了知乎,阅读者需要具备一定的C++和网络编程基础,新手也可以借看这本书进一步加深对其的理解。那就开始吧~
boost库noncopyable简介
几个月以前,当我把STL看得差不多的时候,曾考虑要不要进一步学习boost库,知乎大神回答说boost库没有必要特意去学,用到的时候当手册查一下就好,而现在就到了用到的时候。
介绍boost::noncopyable的时候,首先要先了解一蛤单例模式,参考:C++单例模式 ,考虑我们在单例模式的C++类中,通常将拷贝构造函数等放到private中(只需要声明),可以单例类可以直接通过继承noncopyable来实现。
class noncopyable的基本思想是把构造函数和析构函数设置protected权限,这样子类可以调用,但是外面的类不能调用,那么当子类需要定义构造函数的时候不至于通不过编译。但是最关键的是noncopyable把复制构造函数和复制赋值函数做成了private,这就意味着除非子类定义自己的copy构造和赋值函数,否则在子类没有定义的情况下,外面的调用者是不能够通过赋值和copy构造等手段来产生一个新的子类对象的。
#ifndef BOOST_NONCOPYABLE_HPP_INCLUDED
#define BOOST_NONCOPYABLE_HPP_INCLUDED
namespace boost {
namespace noncopyable_
{
class noncopyable
{
protected:
noncopyable() {}
~noncopyable() {}
private:
noncopyable( const noncopyable& );
const noncopyable& operator=( const noncopyable& );
};
}
typedef noncopyable_::noncopyable noncopyable;
}
#endif
示例
#ifndef __NONCOPYABLEATEST_H__
#define __NONCOPYABLEATEST_H__
#include <iostream>
#include <boost/noncopyable.hpp>
class Test:boost::noncopyable
{
public:
Test();
Test(int i);
void print();
private:
int __value;
};
#endif
#include "noncopyabletest.h"
Test::Test()
{
std::cout<<"Default Construct Called"<<std::endl;
}
Test::Test(int i)
{
std::cout<<"Construct Called"<<std::endl;
__value=i;
}
void Test::print()
{
std::cout<<this<<std::endl;
}
#include "noncopyabletest.h"
int main()
{
std::cout <<"noncopyabletest"<<std::endl;
Test test1(1);
Test test3;
test3.print();
Test testCopy(test3);
Test test4;
test4=test3;
return 0;
}
#Makefile
PROGS = main
CLEANFILES = core core.* *.core *.o temp.* *.out typescript* \
*.lc *.lh *.bsdi *.sparc *.uw
all: ${PROGS}
CFLAGS+=-g#gdb调试
main: main.o noncopyabletest.o
${CXX} ${CFLAGS} -o $@ main.o noncopyabletest.o
@rm *.o
clean:
rm -f ${PROGS} ${CLEANFILES}
参考
http://blog.csdn.net/huang_xw/article/details/8248960
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)