如何解决如何在for循环中创建自动迭代,这将为其分配指针而不是值
我想创建这样的自动迭代循环:
std::vector<sometype> vector1;
for(auto it : vector1)
{
if(&it == &vector1.at(4))
//do something...
else
continue;
}
但是我发现当它等于vector1.at(4)时,其“ it”的地址与vector1.at(4)中的地址不同。我该怎么做才能分配给“ it”的值而不是值,而是当前指向的值的循环。
解决方法
您可以使用引用(在变量声明中添加&
)来完成类似的操作。
std::vector<sometype> vector1;
for(auto& it : vector1) // add &
{
if(&it == &vector1.at(4))
//do something...
else
continue;
}
,
将您的代码视为算法的伪代码,它基本上会尝试解决
- 检查(通过O(n)而不是O(1)成本),如果向量至少包含5个元素。
- 如果为
true
,请转到2。 - 否则什么也不做。
- 如果为
- 用第5个元素做些事。
如果确实是这种情况,则实际上不需要for循环,您可以在有条件访问{O {1}的第5个元素之前,查询向量的大小}}:
//do something...
或者,如果尝试进行越界访问,则可以使用带有异常处理的bounds-checking元素访问器at()
clong。
在基于范围的for循环中
std::vector<sometype> vector1;
for(auto it : vector1)
{
if(&it == &vector1.at(4))
//do something...
else
continue;
}
it
不是迭代器。它是sometype
类型的对象,将对应元素的值存储在向量中。
例如,应该使用引用代替创建对象
std::vector<sometype> vector1;
for( auto &value : vector1)
{
if( &value == &vector1.at(4))
//do something...
else
continue;
}
请注意,带有else的else语句没有太大意义。你可以简单地写
std::vector<sometype> vector1;
for( auto &value : vector1)
{
if( &value == &vector1.at(4))
//do something...
}
虽然目前尚不清楚为什么当向量中只有一个元素满足条件时,为什么要使用基于范围的for循环。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。