Date: Tue, 20 May 2025 17:28:47 +0000
Are you looking for https://www.open-std.org/jtc1/sc22/wg21/docs/papers/2013/n3627.html ?
--
Zhihao Yuan, ID lichray
The best way to predict the future is to invent it.
_______________________________________________
On Tuesday, May 20th, 2025 at 4:38 AM, Zhao YunShan via Std-Proposals <std-proposals_at_[hidden]> wrote:
>
> In C++, the `switch` statement is a fundamental control-flow construct originally designed to work only with integer types (`int`, `char`, `enum`, etc.). However, in real-world development, programmers often need to handle string-based (`std::string`) branching logic. While the standard syntax does not natively support strings, well-structured design patterns can still leverage `switch`-like behavior to replace lengthy `if...else if` chains, significantly improving code readability and conciseness.
>
> #include <iostream>
> #include <string>
> int main()
> {
> std::string router;
> switch (router)
> {
> case "cpp":
> std::cout << "cpp router selected.";
> break;
> case "hpp":
> std::cout << "hpp router selected.";
> break;
> default:
> std::cout << "Unknown router type.";
> break;
> }
> return 0;
> }
>
>
>
> By leveraging compile-time static analysis, `switch` statements can be optimized into various efficient data structures:
>
>
> Jump tables for few cases,
> Balanced binary search for many branches,
> Hash tables where supported.
>
> This ensures optimal time complexity (O(1) to O(log n)) even with large branch sets.
Received on 2025-05-20 17:29:01
