【发布时间】:2012-10-03 12:23:33
【问题描述】:
我有这个代码:
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; // 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 的特性,你可以使用range-based for loop:
for(auto f : SERVER_IPS) {
// use f here
}
【讨论】:
const u_long& f = *it;。
只需在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;
C++11 标准的另一个例子:
set<int> data;
data.insert(4);
data.insert(5);
for (const int &number : data)
cout << number;
【讨论】:
对初学者可能有用的另一件事是,由于 std::set 没有分配连续的内存块,如果有人想迭代直到 kth 元素,正常方式将无法正常工作。
示例:
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++;
}
【讨论】: