有没有办法让这个tolower(..)代码更快
Is there a way to make this tolower( ... ) code faster?
在浏览了web之后,我想出了以下代码来将char16_t*字符串转换为小写。
速度在我的应用程序中相当重要,所以我想知道是否有办法让这个功能更快?
std::u16string ToLower(const char16_t* str)
{
std::u16string data(str ? str : u"");
std::u16string ldata;
for (std::u16string::const_iterator it = data.begin(); it != data.end(); ++it)
{
ldata.push_back( std::use_facet<std::ctype<char16_t>>(std::locale()).tolower(*it) );
}
return ldata;
}
我有一部分认为"push_back(…)"部分本身并不是最有效的。
也许我甚至根本不能使用std::u16string,而是返回char16_t*并让调用函数删除该指针。
// pseudo code - untested
// edited with suggestion from @Dietmar Kühl
char16_t* ToLower(const char16_t* str)
{
if( NULL == str )
{
return NULL;
}
int l = strlen16( str );
char16_t* ldata = new char16_t[ l + 1];
auto const& ct = std::use_facet<std::ctype<char16_t>>(std::locale());
for (int i = 0; i < l; ++i )
{
ldata[i] = ct.tolower(str[i]);
}
ldata[l] = u' ';
return ldata;
}
但是,"std::use_facet(…)"还能更快吗?
编辑1
我进行了一些测试,给出了下面的评论
- 1000个字符的字符串
- 进行了1000次测试
- 时间一般
结果为
- 11ms-我的原始代码,(std::use_facet in the loop)
- 10ms-std::use_facet在循环外
- 10ms-std::use_facet在循环外并使用ldata.rereserve(…)
- 4ms-仅使用char16_t*,(调用者必须删除)
- 5ms-仅使用char16_t*,但返回std::u16string(函数管理删除)
- 4ms-同时包含多个字符
因此,char16_t*ToLower(const char16_t*str){…}函数看起来像是一个胜利。还有其他建议吗?
对于初学者来说,您应该获得循环之外的方面。这可能会产生巨大的差异,尤其是对于语言环境库的实现不太好的情况:
auto const& ct = std::use_facet<std::ctype<char16_t>>(std::locale());
for (std::u16string::const_iterator it = data.begin(); it != data.end(); ++it)
{
ldata.push_back( ct.tolower(*it) );
}
还有一个成员tolower()
的重载,它转换一个对象数组并只调用底层virtual
函数一次。也就是说,你可能想把它用作
std::u16string ToLower(const char16_t* str)
{
if (!str) {
return std::u16string();
}
std::u16string data(str);
std::use_facet<std::ctype<char16_t>>(std::locale()).tolower(&data[0], &data[0] + data.size());
return data;
}
相关文章:
- C++我的数学有什么问题,为什么我的代码不能正确循环
- 代码在main()中运行,但在函数中出现错误
- 在VS代码中交叉编译Windows与Linux上的MinGW的SDL程序
- 编译包含字符串的代码时遇到问题
- 我在c++代码中生成了一个运行时#3异常
- 如何在linux终端中同时编译和运行c++代码
- 为cl.exe(Visual Studio代码)指定命令行C++版本
- 在Linux for Windows上编译C++代码时出错
- 我的字符计数代码计算错误.为什么
- 孤立代码块在结构中引发异常
- 在编译C++代码(具有dlib和opencv)到WASM时面临问题
- 为什么我的C#代码在调用回C++COM直到Task时会暂停.等待/线程.加入
- 处理小于cpu数据总线的数据类型.(c++转换为机器代码)
- 此代码是否违反一个定义规则
- 为什么我的代码在输出中增加了93天
- 我的简单if-else语句是如何无法访问的代码
- 使用动态分配的数组会导致代码分析发出虚假的C6386缓冲区溢出警告
- 为什么在这个代码结束循环中没有得到结束
- 在c代码之间共享数据的最佳方式
- 有没有办法让这个tolower(..)代码更快