使用指针在字符串上缓慢迭代
Slow iterating over string using pointers
我很想知道为什么以下解决方案中的一个比另一个慢得多。让我们考虑下面的代码:
// create a very long string
int x,y;
bool b;
char c[10000];
for (x=0;x<10000;x++)
c[x]='a';
string s(c);
现在我想遍历string并比较每个字符。第一个解决方案在5秒内完成任务:
for (y=0;y<100000;y++){
for (x=0;x<10000;x++){
b = (s[x]=='a');
}}
和21秒内的第二个:
string::iterator begin = s.begin();
string::iterator end = s.end();
string::iterator i;
for (y=0;y<100000;y++){
for (i=begin;i<end;i++){
b = (*i=='a');
}}
为什么第二个慢这么多?
每次将迭代器与'a'进行比较时,都必须对指针进行解引用,而不仅仅是比较实际的char值。在大多数情况下,这是一个可以忽略不计的差异,但是当它进行1,000,000,000次迭代时,它是明显的。
相关文章:
- 使用std::multimap迭代器创建std::list
- 来自 std::list 的迭代器 .end() 按预期返回"0xcdcdcdcdcdcdcdcd"但 .begin()
- C++中带有List类的迭代器Segfault
- 迭代时从向量和内存中删除对象
- 如何在c++迭代器类型中包装std::chrono
- 带过滤器的现代迭代c++集合
- 在c++中检查长方体是否尽可能快地重叠(无迭代)
- C++矢量迭代
- 集合上的输出迭代器:assign和increment迭代器
- Boost Spirit,获取迭代器内部语义动作
- 擦除while循环中迭代的元素
- 实现一个在集合上迭代的模板函数
- 对于set上的循环-获取next元素迭代器
- 在向量内的向量上迭代
- 为什么output_editor Concept不需要output_e迭代器标记
- TSP递归解的迭代形式
- c++17文件系统::recursive_directory迭代器()在mac上没有给出这样的目录,但在windows上
- 使用迭代器时如何访问对象在向量中的位置?
- 哪些因素使迭代器在调试模式下如此缓慢 (VC++ 2012)
- 使用指针在字符串上缓慢迭代