c++primer(第5版)中的一个练习题 P339 T10.5
如果两个容器中保存的是c风格字符串
list
,运用equal 比较两个容器会出现什么样的结果?
#include <list>
#include <iostream>
#include <algorithm>
#include <numeric>
using std::list;
using std::cout;
using std::endl;
using std::equal;
int main()
{
list<const char*> lc(12, "bca");
list<const char*> lc2(12, "bc");
cout << equal(lc.cbegin(), lc.cend(), lc2.cbegin());//#1 输出0
list<const char*> lc3(12, "bca");
list<const char*> lc4(12, "bca");
cout << equal(lc3.cbegin(), lc3.cend(), lc4.cbegin());//#2 输出1
cout<< typeid(*lc3.begin()).name();//#3 char const *
cout<< (*lc3.begin()==*lc4.begin());//# 4编译通过 输出1
return 0;
}
请问:
1.按道理来说两个C风格字符串是未定义“==”运算符的,运用“==”比较应该比较的是其指针指向的元素,但第一第二个cout表明并不是这样?
2.是否是equal算法重载了“==”运算符?
3.迭代器指向元素的比较也是用的元素类型的比较运算符,为什么第四个cout结果为1
前三个问题其实看一下equal实现的源码就很清楚了,注意查看官方文档
这里面写的很清楚:The elements are compared using operator== (or pred, in version (2)).
也就是这里的==是做过重载了的
最后一个问题其实挺有意思,但是要记着,字符串之间的==一般(注意是一般,这个有时候特殊)都是比较字符串地址,
你list生成的时候用的是一个"字符串常量",你虽然创建了两个list,然而初始化用的是同一个”字符串常量“(存储在静态数据区,是全局的)
说白了就是地址是一样的,字符串常量的问题有时候一眼看不出来,但是确实是一个比较有意思的点,下面是我运行时候断点的截图:
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。