智能指针(pointer like class)和仿函数(function like class)

本文探讨了智能指针的实现原理,包括成员模板、重载操作符*和->,以及如何通过析构函数进行资源管理。同时介绍了仿函数的概念,展示了如何通过重载()运算符来创建仿函数,并提供了具体的示例。

看侯捷老师讲智能指针的课程的时候,有那么一些感悟,其实这节课里讲的智能指针还不是很完全,通过之后的学习,我发现智能指针其实里面会有成员模板,来模拟我们平时会对变量进行的一个向上转型,最后达到可以使用虚函数的目的。

对于一个class去模拟point,我们必须对其*和->操作符进行重载。shared_ptr

template<typename T>
class shared_prt{
public:
	T& operator*() const{
		return *px;
	}
	T* operator->() const{
		return px;
	}
private:
	T* px;
	long* pn;
};
在调用的时候比如制造一个FOO的智能指针去使用它
struct FOO{
...
    void method(){}
};

shared_prt<FOO> sp(new FOO);
FOO f(*sp);
sp->method();
智能指针里面一定会有一个指针去模拟这个指针,被封装在智能指针里,在智能指针里比较有用的是能够把封装在里面的指针使用析构函数进行资源管理。

另一个比较复杂的像指针的class就是迭代器了

这里也重载了很多操作符,最关键的还是*以及-> ,星号取出了这个node指针的data数据,->则是利用了*操作符重新取回原地址来实现的。


接下来看看仿函数,仿函数其实就是在class重载了运算符()

比如对于pair来说,我要取其第一个值。设计一个这样的class

template<class Pair>
struct select1st{
	const typename Pair::first_type&
		operator()(const Pair& x) const{ return x.first;}
};
形如这样的类,就可以成为类的仿函数,这时候我可以产生一个select1st<pair> a;

pair<int,int> x = (1,2);

a(x);
仿函数都会继承2种类型,unary_function(1个操作数),binary_function(2个操作数)。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值