我写了一个模板,只有当一个struct
,class
重载了bool operator==
否则编译器错误会拿出一个有效的使用,模板如何呈现数据类型?
namespace atn {
template <typename T>
bool find(std::vector<T>& cont, T find) {
for(std::vector<T>::iterator it = cont.begin(); it != cont.end(); ++it) {
if((*it) == find)
return true;
}
return false;
}
};
所以罚款是好的,例如:
struct sPlayer {
u_int idPlayer;
sPlayer() : idPlayer(0) {};
bool operator==(const sPlayer& ref) const {
return ref.idPlayer == this->idPlayer;
};
};
int _tmain(int argc, _TCHAR* argv[]) {
std::vector<sPlayer>a;
sPlayer player;
player.idPlayer = 5;
a.push_back(player);
if(atn::find(a, player)){
std::cout << "Found" << std::endl;
}
return 0;
}
事情是,如果我这样使用它:
vector<int>hold;
if(atn::find(hold, 4))
我迷失在这个部分,模板tes假设通过传递的第二个参数的值在vector<T>
处分配的T的类型?或者它会从传递的向量引用的类型中假设?