很抱歉,如果这个问题引起任何混淆,我希望实现这一点,并且不知道正确的方法来解决这个问题。
对于我的一个项目,我想实现方法链接。我想要包含以下功能:
.toVector()
.toArray()
.toBool()
...
我考虑将这些放在命名空间中,例如:
namespace Misc {
template<typename T, typename Inverse>
vector<T> toVector(Inverse begin, Inverser end) {
// ...
// ..
}
// ...
// ...
}
这是因为可能有多个类,这些类可以使用这些函数,因此,它必须是OO而不是在不同的类中反复实现每个函数。
假设我有以下类Wav
,它读取wav文件中包含的数据:
class Wav {
public:
Wav();
Wav(string theFileName);
void getWaveData();
protected:
vector<double> data;
};
data
被明确存储为类中的向量。
在我的主要内容中,我希望能够做到以下几点:
int main()
{
Wav wave("file.wav");
int* data = wave.getWaveData().toArray(); // Method chaining to store as an array
}
我不知道这是否可行,如果是这样的话,如果不在每个类中反复实现所有Misc
函数,我将如何处理这个问题。有没有办法在命名空间和类之间进行通信,而不必反复包含所有函数?
我希望有人有一个建议,我会尽力回答任何问题。
编辑:
我写了以下函数:
template<typename T, typename Inverse>
T* toArray(Inverse begin, Inverse end)
{
size_t size = distance(begin, end);
auto pos = 0;
T* tmp = new T[size];
for(auto i = begin; i != end; i++)
{
tmp[pos] = *i;
pos++;
}
return tmp;
}
如果我有其他功能:
void process()
{
}
因此,为了接受以下内容,我需要将params
置于process
内:
int* data = process(toArray<int>(
std::begin(vals),
std::end(vals)
);
这是让我最困惑的事情吗?
答案 0 :(得分:2)
关于你的新功能:
为了能够调用下面的处理方法
int* data = process(toArray<int>( vals.begin(), vals.end()) );
process方法的参数应该与toArray方法的返回类型匹配。也许您可以将过程方法模板化,如下所示。
template<typename T>
T* process(T* t)
{
//more code here
return t;
}
在添加上面的进程方法之后,对进程的调用将进行编译,但是你必须使进程方法的实现足够通用,以处理来自其他方法(如toArray)的不同返回类型。