Как получить хэш-код строки в С++

Следующий код java возвращает хеш-код строки.

String uri = "Some URI"
public int hashCode() {
    return uri.hashCode();
}

Я хочу перевести этот код на С++. Есть ли какая-либо функция, доступная на С++ или простой способ ее перевести.

Ответ 1

Boost предоставляет хеш-функцию:

boost hash

#include <boost/functional/hash.hpp>

int hashCode()
{
    boost::hash<std::string> string_hash;

    return string_hash("Hash me");
}

Ответ 2

В С++ 03, boost::hash. В С++ 11, std::hash.

std::hash<std::string>()("foo");

Ответ 3

Ниже приведено исходное значение по умолчанию для String.hashCode() в Java, это упражнение триала для реализации на С++.

public int hashCode()  
{
       int h = hash;
       if (h == 0 && count > 0) 
       {
           int off = offset;
           char val[] = value;
           int len = count;

           for (int i = 0; i < len; i++) 
           {
               h = 31*h + val[off++];
           }
           hash = h;
       }
       return h;
   }

Ответ 4

Лично мне нравится использовать функции хэша boost

http://www.boost.org/doc/libs/1_47_0/doc/html/hash.html

создание строкового хэша довольно просто,

boost::hash<std::string> string_hash;

std::size_t h = string_hash("Hash me");

более новые версии С++ имеют эквивалент std:: hash

Ответ 5

//Для С++ Qt вы можете использовать этот код, результатом будут те же имена, что и для hashcode()

int  hashCode(QString text){
    int hash = 0, strlen = text.length(), i;
    QChar character;
    if (strlen == 0)
        return hash;
    for (i = 0; i < strlen; i++) {
        character = text.at(i);
        hash = (31 * hash) + (character.toAscii());
    }
    return hash; 
}

Ответ 6

Я задал тот же вопрос, что и у вас, надеюсь, этот код поможет вам:

int HashCode (const std::string &str) {
    int h = 0;
    for (size_t i = 0; i < str.size(); ++i)
        h = h * 31 + static_cast<int>(str[i]);
    return h;
}