当我看到这段代码时,我想知道它会毫无问题地运行。
对象将通过引用传递,所以实际上它不是它的副本。 因此,如果您将此引用放入向量中并且对象超出范围,则它不应再可访问。
但确实如此。因此,这可行的唯一原因可能是push_back()
创建了引用对象的副本。这是这种行为的答案吗?
struct struct1 {
int value;
};
std::vector<struct1> testVect;
void pushVect(struct1 & element) {
testVect.push_back(element);
}
void fillVect() {
struct1 s1;
for (int i = 0; i < 10; i++) {
s1.value = i;
pushVect(s1);
}
}
答案 0 :(得分:1)
vector的push_back
方法负责制作副本:来自C++ reference
在向量的末尾添加一个新元素,在其当前的最后一个元素之后。 val的内容被复制(或移动)到新元素。
所以在通话期间
estVect.push_back(element);
矢量与副本一起使用。因此没有问题。