QHash > key

QHashから指定した値を持つキーを取得

解説

key()はQHashから指定した値に一致するキーを1つ取得します.
keys()はQHashから指定した値に一致するキーを全て取得します.
uniqueKeys()はQHashから指定した値に一致するキーを全て取得します.ただし,キーが重複している場合は返値のQListから取り除かれます.

定義は以下の通りです.
const Key QHash::key ( const T & value ) const
const Key QHash::key ( const T & value, const Key & defaultKey ) const
QList<Key> QHash::keys () const
QList<Key> QHash::keys ( const T & value ) const
QList<Key> QHash::uniqueKeys () const
key(),keys()の引数valueには検索対象のキーを指定します.
key()の引数defaultKeyには,引数keyに一致する要素が見つからなかった場合に返される値を指定します.指定しない場合は型Keyのディフォルトコンストラクタの値が返されます.
keys()で引数を指定しない場合は全てのキーが返されます.
uniqueKeys()はQHashの全てのキーを返します.ただし,キー場重複している場合は,返値のQListから取り除かれます.

使用例

  1. #include <QTextCodec>
  2. #include <QTextStream>
  3. #include <QHash>
  4. #include <QList>
  5.  
  6. int main(int argc, char *argv[]) {
  7. QTextCodec::setCodecForTr(QTextCodec::codecForLocale());
  8. QTextStream out(stdout);
  9.  
  10. QHash<QString, int> hash;
  11. hash.insert("a", 0); // hash = {<a, 0>}
  12. hash.insert("b", 0); // hash = {<a, 0>, <b, 0>}
  13. hash.insertMulti ("b", 1); // hash = {<a, 0>, <b, 0>, <b, 1>}
  14. hash.insertMulti ("b", 2); // hash = {<a, 0>, <b, 0>, <b, 1>, <b, 2>}
  15. out << hash.key(0) << "\n";
  16. out << hash.key(3) << "\n"; // ディフォルトコンストラクタの呼び出し,QStringのディフォルトコンストラクタは"".
  17. out << hash.key(3, "default") << "\n"; // キーが見つからない場合"default"を返す.
  18. out << "===\n";
  19.  
  20. QList<QString> lst1 = hash.keys(0); // lst1 = (a, b)
  21. foreach (QString str, lst1) {
  22. out << str << ",";
  23. }
  24. out << "\n";
  25.  
  26. QList<QString> lst2 = hash.keys(); // lst2 = (a, b, b, b)
  27. foreach (QString str, lst2) {
  28. out << str << ",";
  29. }
  30. out << "\n";
  31.  
  32. QList<QString> lst3 = hash.uniqueKeys();// lst3 = (a, b)
  33. foreach (QString str, lst3) {
  34. out << str << ",";
  35. }
  36. out << "\n";
  37.  
  38. return 0;
  39. }

出力
a

default
===
a,b,
a,b,b,b,
a,b,
最終更新:2011年09月23日 19:55
ツールボックス

下から選んでください:

新しいページを作成する
ヘルプ / FAQ もご覧ください。