C/C の switch ステートメントは、整数値に基づいた効率的な分岐を可能にする強力な制御フロー メカニズムです。 。ただし、多くの場合、文字列や列挙型などの非整数値をオンにすることが望ましいです。 switch ステートメントは整数の引数のみを受け入れるため、これには課題があります。
非整数 switch 引数を処理する従来のアプローチの 1 つは、一連の if ステートメントを使用することです。
if( str == "foo" ) ... else if( str == "bar" ) ... else ...
ただし、このアプローチは n 件の線形時間計算量 (O(n)) を必要とするため、非効率的です。より効率的な解決策は、マップまたはネストされた if を使用して、非整数値を整数として表すことです。ただし、これらのアプローチは複雑でエラーが発生しやすい可能性があります。
マクロを使用すると、コンパイル時に展開された二分検索を実装でき、高速で構文の高速化が可能になります。 -フレンドリーなアプローチ:
#define NEWMATCH #define MATCH("asd") some c++ code #define MATCH("bqr") ... the buffer for the match is in _buf #define MATCH("zzz") ... user.YOURSTUFF #define ENDMATCH(xy_match)
このマクロは、文字列を入力として受け取り、ブール値を返す関数を生成します。指定されたケースによる二分検索を実装します。
C 11 では、ラムダと初期化子リストにより、よりエレガントで簡潔なアプローチが提供されます。
template<typename KeyType, typename FunPtrType> void switchStatement(const KeyType& value, std::initializer_list<std::pair<const KeyType, FunPtrType>> sws) { std::lower_bound(sws.begin(), sws.end(), value, [&](const auto& a, const auto& b) { return a.first < b.first; }); if (r != sws.end() && !cmp(val, *r)) { r->second(); } // else: not found }
int main() { switchStatement<const char*, void(*())>("ger", { { "asdf", []{ printf("0\n"); } }, { "bde", []{ printf("1\n"); } }, { "ger", []{ printf("2\n"); } }, }); return 0; }
モダン C の場合, C 11 メタプログラミング手法を利用して、ソートされていないケース分岐を効率的に処理できる高度なデータ構造であるコンパイル時トライを作成できます:
#include <smile/cttrie/cttrie.h> using namespace smile::cttrie; // Define cases as string literals trie<true, void()> s = {"foo", "bar"}; int main() { // Switch on a string s.switch_on("foo", []() { std::cout << "foo" << std::endl; }); return 0; }
以上がC/C で非整数引数を含む switch ステートメントを効率的に実装するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。