Hello, Below is a minimisation of a larger program (that may explain why the objective of the progarm is not too clear). The essence is I am trying to do a map find with a structure as key and the significant aspect of the structure is - it has a void *. I expect the below progarm to print nothing as s2 is not there on the map at all! There are 2 findings however: 1. "Address found" is getting printed 2. Segmentation fault occurs. For convenience, I am attaching the code as well. ------------------------------------------------------------------------ #include <iostream> #include <map> using namespace std; struct Value { int id; void *buf; Value (long l) { id = 4; buf = operator new(128); long *c = reinterpret_cast<long *>(buf); *c = l; } ~Value() { operator delete(buf); } }; bool operator< (const Value &v1, const Value &v2) { bool result = (*(reinterpret_cast<long *>(v1.buf))) < (*(reinterpret_cast<long *>(v2.buf))); return result; } bool operator== (const Value &v1, const Value &v2) { bool result = (*(reinterpret_cast<long *>(v1.buf))) == (*(reinterpret_cast<long *>(v2.buf))); return result; } typedef map<Value, string> Map; typedef Map::iterator ITR; int main() { Map m; ITR itr; Value s((long)10); m.insert(Map::value_type(s, "1")); Value s2((long)20); itr = m.find(s2); if(itr != m.end()) { cout << "Address found!" << endl; } } ***** What is further interesting is it does not work with any of pointers (e.g char *buf) but does well with non aggregate types (e.g long buf). This explains I am probably missing something grossly. Any advice helps. BTW, it would be interesting to see the cause of segmentation fault too which happen to be common in all the cases. Thanks in advance, -- Regards, Anitha B @S A N K H Y A
#include <iostream> #include <map> using namespace std; struct Value { int id; void *buf; Value (long l) { id = 4; buf = operator new(128); long *c = reinterpret_cast<long *>(buf); *c = l; } ~Value() { operator delete(buf); } }; bool operator< (const Value &v1, const Value &v2) { bool result = (*(reinterpret_cast<long *>(v1.buf))) < (*(reinterpret_cast<long *>(v2.buf))); return result; } bool operator== (const Value &v1, const Value &v2) { bool result = (*(reinterpret_cast<long *>(v1.buf))) == (*(reinterpret_cast<long *>(v2.buf))); return result; } typedef map<Value, string> Map; typedef Map::iterator ITR; int main() { Map m; ITR itr; Value s((long)10); m.insert(Map::value_type(s, "1")); Value s2((long)20); itr = m.find(s2); if(itr != m.end()) { cout << "Address found!" << endl; } }