linux C++ string大小写转换

#include <iostream>
#include <cctype>
#include <string>
#include <algorithm>

using namespace std;

int main()
{
    string s = "ddkfjsldjl";
    transform(s.begin(), s.end(), s.begin(), toupper);
    cout<<s<<endl;
    return 0;
}

    但在使用g++编译时会报错:
对 ‘transform(__gnu_cxx::__normal_iterator<char*, std::basic_string<char, std::char_traits<char>, std::allocator<char> > >, __gnu_cxx::__normal_iterator<char*, std::basic_string<char, std::char_traits<char>, std::allocator<char> > >, __gnu_cxx::__normal_iterator<char*, std::basic_string<char, std::char_traits<char>, std::allocator<char> > >, <unresolved overloaded function type>)’ 的调用没有匹配的函数。
    这里出现错误的原因是Linux将toupper实现为一个宏而不是函数:
/usr/lib/syslinux/com32/include/ctype.h:

/* Note: this is decimal, not hex, to avoid accidental promotion to unsigned */
#define _toupper(__c) ((__c) & ~32)
#define _tolower(__c) ((__c) | 32)

__ctype_inline int toupper(int __c)
{
return islower(__c) ? _toupper(__c) : __c;
}

__ctype_inline int tolower(int __c)
{
return isupper(__c) ? _tolower(__c) : __c;
}

    两种解决方案:

1.transform(str.begin(), str.end(), str.begin(), (int (*)(int))toupper);

    这里(int (*)(int))toupper是将toupper转换为一个返回值为int,参数只有一个int的函数指针。

2.自己实现ToUpper函数:
int ToUpper(int c)
{
    return toupper(c);
}
transform(str.begin(), str.end(), str.begin(), ToUpper);

附:大小写转换函数
#include <cctype>
#include <string>
#include <algorithm>

using namespace std;

void ToUpperString(string &str)
{
    transform(str.begin(), str.end(), str.begin(), (int (*)(int))toupper);
}

void ToLowerString(string &str)
{
    transform(str.begin(), str.end(), str.begin(), (int (*)(int))tolower);
}

### C++ 中实现不区分大小写的字符串匹配方法 #### 使用标准库函数 `_stricmp` 或 `strcasecmp` 对于 Windows 环境,可以利用标准 C 库中的 `_stricmp` 函数来实现忽略大小写的字符串比较。此函数位于 `<cstring>` 头文件中。 ```cpp #include <iostream> #include <string> bool stringCompareIgnoreCase(const std::string& lhs, const std::string& rhs) { return _stricmp(lhs.c_str(), rhs.c_str()) == 0; } ``` 而在 Linux 或其他 Unix-like 系统上,则应使用 `strcasecmp` 来代替 `_stricmp`[^1]。 #### 自定义转换为小写字母再比较的方法 另一种通用的方式是在 C++ 中手动将待比较的两个字符串全部转成小写形式后再做对比: ```cpp #include <algorithm> // For transform() #include <cctype> // For tolower() std::string toLowerCase(const std::string& str){ std::string lowerStr = str; std::transform(lowerStr.begin(), lowerStr.end(), lowerStr.begin(), [](unsigned char c){ return std::tolower(c); }); return lowerStr; } bool caseInsensitiveEqual(const std::string& s1, const std::string& s2){ return toLowerCase(s1) == toLowerCase(s2); } ``` 这种方法虽然简单直观,但在性能方面可能不如直接调用底层 API 高效,因为每次都需要创建新的副本并逐字符处理[^3]。 #### 查找子串是否存在而不考虑大小写差异 当目标是从一个较长文本中寻找特定模式时(比如判断某段话里是否含有某个单词),可以通过先将两者都变为同一种情况的形式之后再去执行查找操作;或者采用更高效的算法如 KMP、BM 等来进行模式匹配前预处理输入数据使之满足条件。 ```cpp size_t findSubstringNoCase(const std::string& haystack, const std::string& needle){ auto pos = toLowerCase(haystack).find(toLowerCase(needle)); if (pos != std::string::npos) return pos; return std::string::npos; } ``` 上述代码片段展示了如何在一个较大的字符串 (`haystack`) 内部定位另一个较小的目标字符串 (`needle`) 的位置,并且在整个过程中忽略了字母的大写/小写区别.
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值