我有这段代码:
std::set<unsigned long>::iterator it;
for (it = SERVER_IPS.begin(); it != SERVER_IPS.end(); ++it) {
u_long f = it; // error here
}
没有->first
值。
我该如何获取这个值?
std::set<unsigned long>::iterator it;
for (it = SERVER_IPS.begin(); it != SERVER_IPS.end(); ++it) {
u_long f = *it; // Note the "*" here
}
如果你使用的是C++11功能,你可以使用基于范围的for循环:
for(auto f : SERVER_IPS) {
// use f here
}
另一个符合C++11标准的例子:
set<int> data;
data.insert(4);
data.insert(5);
for (const int &number : data)
cout << number;
只需在it
之前使用*
:
set<unsigned long>::iterator it;
for (it = myset.begin(); it != myset.end(); ++it) {
cout << *it;
}
这将取消引用它并允许您访问迭代器当前所在的元素。
如何迭代std::set?
int main(int argc,char *argv[])
{
std::set<int> mset;
mset.insert(1);
mset.insert(2);
mset.insert(3);
for ( auto it = mset.begin(); it != mset.end(); it++ )
std::cout << *it;
}
for(auto i : mset) std::cout << i;
。 - Jack Deethstd::set
不是使用连续的内存块分配的,如果有人想要按照正常方式迭代到第k
个元素,那么通常的方法将无法奏效。std::vector<int> vec{1, 2, 3, 4, 5};
int k = 3;
for (auto itr = vec.begin(); itr < vec.begin() + k; itr++)
cout << *itr << " ";
std::unordered_set<int> s{1, 2, 3, 4, 5};
int k = 3;
int index = 0;
auto itr = s.begin();
while (true)
{
if (index == k)
break;
cout << *itr++ << " ";
index++;
}
const u_long& f = *it;
。 - Robᵩ