QStaticLatin1StringMatcher Class
template <Qt::CaseSensitivity CS, size_t N> class QStaticLatin1StringMatcherQStaticLatin1StringMatcherクラスは、QLatin1StringMatcher のコンパイル時バージョンである。
Header: | #include <QStaticLatin1StringMatcher> |
CMake: | find_package(Qt6 REQUIRED COMPONENTS Core) target_link_libraries(mytarget PRIVATE Qt6::Core) |
qmake: | QT += core |
Since: | Qt 6.7 |
- 継承メンバを含む全メンバのリスト
- QStaticLatin1StringMatcher は、文字列データ用クラスの一部です。
パブリック関数
qsizetype | indexIn(QLatin1StringView haystack, qsizetype from = 0) const |
qsizetype | indexIn(QStringView haystack, qsizetype from = 0) const |
関連する非メンバー
(since 6.7) auto | qMakeStaticCaseInsensitiveLatin1StringMatcher(const char (&)[N] patternToMatch) |
(since 6.7) auto | qMakeStaticCaseSensitiveLatin1StringMatcher(const char (&)[N] patternToMatch) |
詳細説明
このクラスは、コンパイル時に既知の部分文字列をLatin-1文字列で効率的に検索する必要がある場合に便利です。これは、パーサーなどでよく見られます。特に、検索する文字列を繰り返し検索する場合や、検索する部分文字列の接頭辞に一致する文字列が多数含まれる可能性のある大きな Latin-1 文字列内を検索する場合は、検索する文字列の indexOf() メンバメソッドを使用するよりも matcher オブジェクトのindexIn() を使用する方が高速です。
QLatin1StringMatcher とは異なり、このクラスはコンパイル時に内部表現を計算するので、1 回限りの Latin-1 文字列マッチを行う場合でも有益です。
QStaticLatin1StringMatcher を作成するには、qMakeStaticCaseSensitiveLatin1StringMatcher() またはqMakeStaticCaseInsensitiveLatin1StringMatcher() を呼び出し、検索する Latin-1 文字列を C 文字列リテラルとして渡します。その関数の返り値をstatic constexpr auto
変数に格納するので、N
テンプレート・パラメータを明示的に渡す必要はありません。
そして、QLatin1StringMatcher と同じように、検索したいQLatin1StringView に対してindexIn() を呼び出します。
このクラスは、コンパイル時にすべての先行計算を行うように設計されているため、 setPattern() メソッドや setCaseSensitivity() メソッドは提供されません。
注意: INTEGRITY オペレーティング・システムは現在サポートされていません。
QLatin1StringMatcher 、QStaticByteArrayMatcher 、QByteArrayMatcherも参照して ください。
メンバ関数ドキュメント
[constexpr noexcept]
qsizetype QStaticLatin1StringMatcher::indexIn(QLatin1StringView haystack, qsizetype from = 0) const
[constexpr noexcept]
qsizetype QStaticLatin1StringMatcher::indexIn(QStringView haystack, qsizetype from = 0) const
QLatin1StringView haystack を、from のバイト位置(デフォルトは 0、つまり最初のバイトから)から、コンストラクタで設定されたQLatin1StringView pattern()を検索する。コンストラクタで設定した大文字小文字の区別を使用します。
haystack で pattern() がマッチした位置を返すか、マッチしなかった場合は -1 を返す。
関連する非メンバー
[constexpr noexcept, since 6.7]
template <size_t N> auto qMakeStaticCaseInsensitiveLatin1StringMatcher(const char (&)[N] patternToMatch)
渡されたpatternToMatch から自動的に決定された正しいN
を持つQStaticLatin1StringMatcher を、大文字小文字の区別なしで返します。
この関数を最大限に活用するには、結果をstatic constexpr auto
変数に代入してください:
static constexpr auto matcher = qMakeStaticCaseInsensitiveLatin1StringViewMatcher("needle");
この関数は Qt 6.7 で導入されました。
[constexpr noexcept, since 6.7]
template <size_t N> auto qMakeStaticCaseSensitiveLatin1StringMatcher(const char (&)[N] patternToMatch)
この関数はQt 6.7で導入されました。渡されたpatternToMatch から自動的に決定された、大文字と小文字を区別する正しいN
を持つQStaticLatin1StringMatcher を返します。
この関数を最大限に活用するには、結果をstatic constexpr auto
変数に代入してください:
static constexpr auto matcher = qMakeStaticCaseSensitiveLatin1StringViewMatcher("needle");
この関数は Qt 6.7 で導入されました。
この関数はQt 6.7で導入されました。©2024 The Qt Company Ltd. 本書に含まれる文書の著作権は、それぞれの所有者に帰属します。 本書で提供されるドキュメントは、Free Software Foundation が発行したGNU Free Documentation License version 1.3に基づいてライセンスされています。 Qtおよびそれぞれのロゴは、フィンランドおよびその他の国におけるThe Qt Company Ltd.の 商標です。その他すべての商標は、それぞれの所有者に帰属します。