How do I iterate over a Constant Vector?

后端 未结 6 869
终归单人心
终归单人心 2020-12-02 22:16

I have a vector of Student which has a field name.

I want to iterate over the vector.

void print(const vector& students)
    {
            


        
相关标签:
6条回答
  • 2020-12-02 22:31

    C++11 style:

    void print(const vector<Student>& students) {
        for(auto const& student : students) {
                cout << student.name << endl;
        }
    }
    
    0 讨论(0)
  • 2020-12-02 22:43
    void print(const vector<Student>& students)
        {
        for(auto it = students.begin(); it != students.end(); ++it)
            {
                cout << it->name << endl;
            }
        }
    
    0 讨论(0)
  • 2020-12-02 22:44

    You have two (three in C++11) options: const_iterators and indexes (+ "range-for" in C++11)

    void func(const std::vector<type>& vec) {
      std::vector<type>::const_iterator iter;
      for (iter = vec.begin(); iter != vec.end(); ++iter)
        // do something with *iter
    
      /* or
      for (size_t index = 0; index != vec.size(); ++index)
        // do something with vec[index]
    
      // as of C++11
      for (const auto& item: vec)
        // do something with item
      */
    }
    

    You should prefer using != instead of < with iterators - the latter does not work with all iterators, the former will. With the former you can even make the code more generic (so that you could even change the container type without touching the loop)

    template<typename Container>
    void func(const Container& container) {
      typename Container::const_iterator iter;
      for (iter = container.begin(); iter != container.end(); ++iter)
        // work with *iter
    }
    
    0 讨论(0)
  • 2020-12-02 22:47

    Use const_iterator instead. An iterator allows modification of the vector, so you can't get one from a const container.

    Also, the idiomatic way to write this loop uses it != students.end() instead of < (though this should work on a vector).

    0 讨论(0)
  • 2020-12-02 22:48

    Instead of vector<Student>::iterator, use vector<Student>::const_iterator.

    0 讨论(0)
  • 2020-12-02 22:51
    void print(const vector<Student>& students)
        {
        vector<Student>::const_iterator it; // const_iterator
        for(it = students.begin(); it != students.end(); it++)
            {
                cout << it->name << endl;
            }
        }
    
    0 讨论(0)
提交回复
热议问题