Я пытаюсь написать программу интенсивного расчета. И мне нужно, чтобы char* был полями сравнения для component_key_compare multi_index_container. Однако, похоже, это не работает. Код, как показано ниже:
struct MyStruct
{
char* firstName;
char* secondName;
int age;
};
struct equal_char
{ // functor for operator<=
inline bool operator()(const char* left, const char* right) const
{ // apply operator<= to operands
bool result=(strcmp(left,right)==0);
return result;
}
};
typedef composite_key
<MyStruct*,
BOOST_MULTI_INDEX_MEMBER(MyStruct, char*, firstName),
BOOST_MULTI_INDEX_MEMBER(MyStruct, char*, secondName)
> comp_key;
typedef multi_index_container
<
MyStruct*,
indexed_by
<
ordered_unique
<
comp_key,
composite_key_compare
<equal_char, equal_char>
>
>
> MyContainer;
boost::ptr_vector<MyStruct> vec;
MyStruct* struct1=new MyStruct();
struct1->firstName="Michael";
struct1->secondName="Mike";
struct1->age=20;
vec.push_back(struct1);
MyContainer myContainer;
myContainer.insert(struct1);
char* first="Michael";
char* second="Mike";
auto it=myContainer.find(boost::make_tuple(first, second));
if(it!=myContainer.end())
cout << (*it)->age << endl;
Я проследил до equal_char и обнаружил, что он возвращает true при первом сравнении "Michael" с "Michael", но я также обнаружил, что equal_char не вызывается для второго сравнения "Mike" с "Mike". Любой, кто может помочь мне с этим? Как мне написать композитный_ключ_компаре?