gpt4 book ai didi

c++ - 在 C++ 中将基于策略的设计与 CRTP 混合

转载 作者:可可西里 更新时间:2023-11-01 16:39:05 25 4
gpt4 key购买 nike

我正在尝试编写一个基于策略的主机类(即,一个继承自其模板类的类),其中策略类也由主机类模板化,以便它可以访问其类型。这可能有用的一个示例是策略(实际上像混合一样使用)使用多态 clone() 方法扩充主机类。这是我正在尝试做的一个最小示例:

template <template <class> class P>
struct Host : public P<Host<P> > {
typedef P<Host<P> > Base;
typedef Host* HostPtr;
Host(const Base& p) : Base(p) {}
};

template <class H>
struct Policy {
typedef typename H::HostPtr Hptr;
Hptr clone() const {
return Hptr(new H((Hptr)this));
}
};

Policy<Host<Policy> > p;
Host<Policy> h(p);

int main() {
return 0;
}

不幸的是,这编译失败,在我看来是循环类型依赖:

try.cpp: In instantiation of ‘Host<Policy>’:
try.cpp:10: instantiated from ‘Policy<Host<Policy> >’
try.cpp:16: instantiated from here
try.cpp:2: error: invalid use of incomplete type ‘struct Policy<Host<Policy> >’
try.cpp:9: error: declaration of ‘struct Policy<Host<Policy> >’
try.cpp: In constructor ‘Host<P>::Host(const P<Host<P> >&) [with P = Policy]’:
try.cpp:17: instantiated from here
try.cpp:5: error: type ‘Policy<Host<Policy> >’ is not a direct base of ‘Host<Policy>’

如果有人能发现明显的错误,或者成功地将 CRTP 混合在策略中,我将不胜感激。

最佳答案

事实上,问题是由于HostPtr 声明在您从策略继承时尚未看到。有一些关于实例化模板可见这些声明的确切语义的讨论,这有相当复杂的问题,请参阅 this defect report .

但是在您的情况下,情况很清楚:在类主体之前,没有代码可以看到类成员的任何声明,因此您的代码失败了。您可以将类型作为模板参数传递

template <template <class,class> class P>
struct Host : public P<Host<P>, Host<P>* > {
typedef P<Host<P> > Base;
Host(const Base& p) : Base(p) {}
};

template <class H, class Hptr>
struct Policy {
typedef Hptr HostPtr;
HostPtr clone() const {
return Hptr(new H((Hptr)this));
}
};

如果有更多的类型,你可以决定传递一个特征

template <class Host>
struct HTraits {
typedef Host *HostPtr;
// ...
};

template <template <class,class> class P>
struct Host : public P<Host<P>, HTraits< Host<P> > > {
typedef P<Host<P> > Base;
Host(const Base& p) : Base(p) {}
};

template <class H, class Htraits>
struct Policy {
typedef typename Htraits::HostPtr HostPtr;
HostPtr clone() const {
return Hptr(new H((Hptr)this));
}
};

关于c++ - 在 C++ 中将基于策略的设计与 CRTP 混合,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2558109/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com