【刷点笔试面试题试试水】找错—使用strlen()函数代替sizeof计算字符串长度
大家好,这里是国中之林!
❥前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站。有兴趣的可以点点进去看看←
问题:
解答:
#include <iostream>
using namespace std;
void UpperCase(char *str)
{
for (size_t i = 0; i < sizeof(str) / sizeof(str[0]); ++i)
{
if ('a' <= str[i] && str[i] <= 'z')
{
str[i] -= ('a' - 'A');
}
}
}
int main()
{
char str[] = "aBcDe";
cout << "The length of str is " << sizeof(str) / sizeof(str[0]) << endl;
UpperCase(str);
cout << str << endl;
return 0;
}
运行结果:
注意:
- 看似正确,其实错了两个地方,一是长度为5,
sizeof
计算多了一个字符串结束符. - 结果好像都转成了我们想要的,但是如果我换成32位的执行.
运行结果就出问题了.
这是因为sizeof()计算的时候,将将传入的数组当成指针了.
所以我们用strlen()
来替换.
运行结果:
x86也一样可以哦.
原文地址:https://blog.csdn.net/qq_74047911/article/details/142664511
免责声明:本站文章内容转载自网络资源,如本站内容侵犯了原著者的合法权益,可联系本站删除。更多内容请关注自学内容网(zxcms.com)!