我在CPP测验中发现了一个问题。问题是
class secret
{
class hidden{};
public:
template <class K>
string accept(K k) {return (k(*this, hidden()));}
string keyToNextLvl (hidden )const {return ("success!"); }
};
struct SampleSoln
{
template <class pwd>
string operator()(const secret &sc, pwd opwd) const
{ return (sc.keyToNextLvl(opwd)); }
};
int main()
{
secret sc;
cout <<sc.accept(SampleSoln()) << endl; //Prints success
cout <<sc.keyToNextLvl (AnswerKey()) << endl; //Need to provide the implementation of AnswerKey
}
现在我必须直接使用方法“keyToNextLvl”来访问它。 (我不允许访问accept方法 - 在问题本身中提供了样本解决方案,用于使用accept方法访问keyToNextLvl。所以我需要提供AnswerKey的实现)
我做了一些搜索并找到了一些方法来访问私有成员/方法而不使用朋友 http://bloglitb.blogspot.in/2010/07/access-to-private-members-thats-easy.html
但我对上述问题的解决方案一无所知。
答案 0 :(得分:5)
知道了!
printf "%s\n" "$0 $*"
使用模板化转换运算符构造struct AnswerKey
{
template <class T>
operator T ()
{
return T();
}
};
对象
答案 1 :(得分:3)
因为它是默认的可构造的,你可以这样做:
sc.keyToNextLvl ({})
举个例子:
#include<string>
#include<iostream>
class secret
{
class hidden{};
public:
template <class K>
std::string accept(K k) {return (k(*this, hidden()));}
std::string keyToNextLvl (hidden )const {return ("success!"); }
};
int main()
{
secret sc;
std::cout <<sc.keyToNextLvl ({}) << std::endl;
}
您不需要定义AnswerKey
不可见的是该类的名称,但只要您不需要实际使用其名称,您就可以构建它。