[hash] Reliability of hash_value() for std::string
data:image/s3,"s3://crabby-images/5f6a3/5f6a3c473aedd1776ca58b0464d0f55f4e074f71" alt=""
Hi, I am coding a simple serialization/factory lib and want to use class hash code based on std::string representing class name as a factory identifier. My question is: how portable / reliable is hash value produced by std::string hash_value() overload? Will it be the same across platforms? Across boost versions? Or maybe actual algorithm is dictated by standard? Or should I just go with explicit algo like crc32? btw. I was just very hardly bitten by the fact that hash_value() for const char* != hash_value() for std::string, (it is just being treated as regular pointer). In other words hash_value("Class") != hash_value(std::string("Class")) which gave me few more gray hair. Is that desirable? Cheers, Szymon Gatner
data:image/s3,"s3://crabby-images/d0f66/d0f663d06f40ccd2e146b552333ea4337d244bbb" alt=""
On 21 February 2012 12:32, Szymon Gatner
I am coding a simple serialization/factory lib and want to use class hash code based on std::string representing class name as a factory identifier.
It really isn't suitable for that purpose. it's an implementation of std::hash, which is a hash function suitable for use in STL containers.
My question is: how portable / reliable is hash value produced by std::string hash_value() overload? Will it be the same across platforms? Across boost versions?
So far, it should be the same for any platform with the same representation of 'std::size_t'. But that isn't guaranteed for the future. So the answer is no.
Or maybe actual algorithm is dictated by standard?
No, it was proposed that an algorithm be added to the standard, but that was rejected. Probably correctly.
Or should I just go with explicit algo like crc32?
Yes. I assume you've seen this: http://www.boost.org/libs/crc/ Although you might consider a stronger hash function.
btw. I was just very hardly bitten by the fact that hash_value() for const char* != hash_value() for std::string, (it is just being treated as regular pointer). In other words hash_value("Class") != hash_value(std::string("Class")) which gave me few more gray hair. Is that desirable?
It has to do that because 'hash_value' corresponds to 'operator==' -
i.e. since operator== compares the pointer value, hash_value hashes
the pointer value. In the context of an STL hash container, it does
the right thing (considering that std::set
data:image/s3,"s3://crabby-images/5f6a3/5f6a3c473aedd1776ca58b0464d0f55f4e074f71" alt=""
Hey,
W dniu 21 lutego 2012 14:27 użytkownik Daniel James
On 21 February 2012 12:32, Szymon Gatner
wrote: Yes. I assume you've seen this:
http://www.boost.org/libs/crc/
Although you might consider a stronger hash function.
Thanks a lot for detailed answer. Another question then: is computed CRC32 value good hash_value() for unorderd containers? I mean: say I have a ClassInfo class that keeps the name (string) and a hash (computed by crc algo) will that work fine (distribution-wise)? size_t hash_value(const ClassInfo& info) { return info.crcHash_; } Cheers, Simon
data:image/s3,"s3://crabby-images/0425d/0425d767771932af098628cd72e2ccd4040cb8a0" alt=""
On Tue, Feb 21, 2012 at 7:32 AM, Szymon Gatner
I am coding a simple serialization/factory lib and want to use class hash code based on std::string representing class name as a factory identifier.
There's another potential "gotcha" lurking here: where are you getting the class-name string? Is that manually coded, or are you deriving it from typeid(myclass).name()? The latter construct is explicitly (and empirically) NOT portable.
data:image/s3,"s3://crabby-images/5f6a3/5f6a3c473aedd1776ca58b0464d0f55f4e074f71" alt=""
Hi,
W dniu 21 lutego 2012 14:56 użytkownik Nat Linden
On Tue, Feb 21, 2012 at 7:32 AM, Szymon Gatner
wrote: I am coding a simple serialization/factory lib and want to use class hash code based on std::string representing class name as a factory identifier.
There's another potential "gotcha" lurking here: where are you getting the class-name string? Is that manually coded, or are you deriving it from typeid(myclass).name()? The latter construct is explicitly (and empirically) NOT portable.
Yup, I am aware of that, all names are manually typed strings. Tho, it would be very usefull imho if we could also have like typeid(MyClass).pretty_name() that would have standard format. Cheers, Simon
participants (3)
-
Daniel James
-
Nat Linden
-
Szymon Gatner