小知识:如何取存在数组中的元素指针
怎么样处理需要放在一个容器里放在元素的指针,那个指针该怎么取出来?
我们先来看一段代码
咋看起来没什么问题,可是当程序运行之后,你会发现输出来的东西完全不是你想用的,为什么
在上面这个for循环中,我创建了一个局部变量student,然后我把这个student push到一个vector里,这其实是一次拷贝。然后我把这个指针的地址存到另一个vector studentPointer里面。
可是当这个循环结束,局部变量student就会被释放,所以当我们用指针访问这个地址的时候,它就是野指针,输出的内容是不确定的,因为我们不知道这块内存被如何利用。
所以,其实我们是没有办法实现保存局部变量的指针的,是不能这样做的。
那我们的目的是把每一个元素的数组的指针保存到另外一个数组里面去,我怎么做呢?
可是打印出来并不是我们想要的内容,这里面有一个坑,
因为vector他是自动伸缩的,当我们向students里面存第一个元素的时候,它的内容是s1,地址是2000,所以我把2000这个地址存到studentsPointer里面,这是没有问题的。
可是当我在存第二个元素的时候,students发现空间不够了,所以他会再找一块能存两个元素的内存,把我们这两个元素放进去,把原来的那块内存删除,可是我们studentPointers里面还是存的那块元素的地址呀,于是就会出现野指针,找不到真正的元素。
那么如何解决这个问题呢,申请一块空间足够的内存,这样,vector就不会寻找新的内存了。
此时打印的结果是正确的。
完整代码示例:
#include <iostream>
#include <vector>
#include <string>
class Student {
public:
Student(const std::string& name, int age): _name(name), _age(age) {
}
const std::string& GetName() const {
return _name;
}
int GetAge() const {
return _age;
}
private:
std::string _name;
int _age;
};
int main(int argc, const char * argv[]) {
std::vector<Student> students;
std::vector<Student*> studentPointers;
students.reserve(10);
for (int i = 0; i < 10; ++ i) {
// to_string :int convert to string
Student student(std::string("s") + std::to_string(i), 20 + i);
students.push_back(student);
studentPointers.push_back(&students[i]);
}
for (const Student& student : students) {
std::cout << student.GetName() << ": " << student.GetAge() << std::endl;
}