C++ switch case 匹配字符串(全网最简单)

C++ switch case 匹配字符串(全网最简单)

我们会遇到这样一个问题:
如果有很多字符串,我们要把它们区分开来,我们可以用

if
    ......
else if
    ......
else if
    ......
else if
    ......
else if
    ......
else if
    ......
(有点凑字数的嫌疑)

可见,写起来比较麻烦,阅读代码不直观,而且写到最后容易崩溃,看起来实在是太乱了。
如果我们用 switch case 来解决就会舒服很多,比如:
C++ switch case 匹配字符串(全网最简单)_第1张图片
额,好像和计划有出入,一大堆错误,编译器大哥貌似对此表示强烈不满和坚决反对。
没办法,学习C++的同学都知道,C++ 中 switch case 语句不识别字符串。看来只能老老实实的用 if … else if … 了。

等等,似乎可以另辟蹊径

switch case 只识别整数和枚举类型,计算机的汉字是从Unicode编码成UTF-8的,Unicode是十六进制数表示,嗯好像可以实现。

需要用到 C++ 11 中 constexpr (常量表达式)
因为 case 之后要求的必须是常量,C++ 11正好提供的有 constexpr 编译期计算出的值作为常量使用。

代码:

#include 

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;
}

结果:

C++ switch case 匹配字符串(全网最简单)_第2张图片

总结:

虽然是最简单便捷的方法,但是准确度不高,比如下面这种情况:
C++ switch case 匹配字符串(全网最简单)_第3张图片
软件工程,程工件软,顺序不一致,但是依然被判断为相同项,因为它们值是相同的,我们可以按位相加就不会出现上面这种情况,这里就不提供解决代码了,上面提供的代码只够应胜任 switch case 处理字符串的需求。

你可能感兴趣的:(C++,C++)