C++ switch case 匹配字符串(全网最简单)
我们会遇到这样一个问题:
如果有很多字符串,我们要把它们区分开来,我们可以用
if
......
else if
......
else if
......
else if
......
else if
......
else if
......
(有点凑字数的嫌疑)
可见,写起来比较麻烦,阅读代码不直观,而且写到最后容易崩溃,看起来实在是太乱了。
如果我们用 switch case 来解决就会舒服很多,比如:
额,好像和计划有出入,一大堆错误,编译器大哥貌似对此表示强烈不满和坚决反对。
没办法,学习C++的同学都知道,C++ 中 switch case 语句不识别字符串。看来只能老老实实的用 if … else if … 了。
等等,似乎可以另辟蹊径
switch case 只识别整数和枚举类型,计算机的汉字是从Unicode编码成UTF-8的,Unicode是十六进制数表示,嗯好像可以实现。
需要用到 C++ 11 中 constexpr (常量表达式)
因为 case 之后要求的必须是常量,C++ 11正好提供的有 constexpr 编译期计算出的值作为常量使用。
代码:
#include <iostream>
int toUnicode(const char* str)
{
return str[0] + (str[1] ? toUnicode(str + 1) : 0);
}
constexpr inline int U(const char* str)
{
return str[0] + (str[1] ? U(str + 1) : 0);
}
int main()
{
using namespace std;
const char* str = "微信公众号: 软件工程 Code";
switch (toUnicode(str))
{
case U("软件工程"):
cout << "软件工程";
break;
case U("软件工程 Code"):
cout << "软件工程 Code";
break;
case U("微信公众号: 软件工程 Code"):
cout << "微信公众号: 软件工程 Code";
break;
default:
cout << "默认";
break;
}
return 0;
}
结果:
总结:
虽然是最简单便捷的方法,但是准确度不高,比如下面这种情况:
软件工程,程工件软,顺序不一致,但是依然被判断为相同项,因为它们值是相同的,我们可以按位相加就不会出现上面这种情况,这里就不提供解决代码了,上面提供的代码只够应胜任 switch case 处理字符串的需求。