C++ vector<int>类型 简单使用迭代器出现异常 不知道是什么原因

我刚学容器这一块, 想试试vector的特性, 我想实现一个函数,就是代入一个
vector类型并且原模原样的返回, 最后输出第一个元素的值.
使用方法1, 用另一个vector变量接收返回值, 并且用迭代器获得头部指针没有问题, 方法2不用变量, 直接begin就有问题了, 不知道这里是什么原因

图片说明

vector<int> testVector(vector<int> nums){
    return nums;
}
int main()
{
    vector<int> t = { 2,7,11,15 };

    /*方法1输出正常*/
    vector<int> a = testVector(t);
    vector<int>::iterator it1 = a.begin();
    cout << *it1 << endl;

    /*方法2输出异常*/
    vector<int>::iterator it2 = testVector(t).begin();
    cout << *it2 << endl;

}

出现异常是因为迭代器vector::iterator已经失效了,原因是你的函数testVector的参数Vector是值传递,函数返回的nums其实是一个拷贝构造,但是nums又是一个局部变量,函数返回时内存已经被释放,即迭代器已经失效。

当然的,你可以传递引用或指针作为函数参数,则都是正确的哈。

// 传入引用举例
vector<int> testVector(vector<int> &nums){
    return nums;
}
// 传入指针举例
vector<int> testVector(vector<int> *nums){
    return *nums;
}

以上两种传参举例,返回都指向 t 本身的地址,即迭代器 it2 均指向 t 的第一个元素。( it1 指向 a 的第一个元素)

vector<int>::iterator it2 = testVector(t).begin();编译器为这一行代码创建了一个vector<int> 类型临时对象用于存储testVector(t) 的返回结果。it2是这个临时对象的迭代器。因表达式求值而创建的临时对象,将在表达式语句的末尾(即分号处)被销毁。当通过*it2访问那个临时的vector<int> 对象的元素时,此临时对象已经被销毁。有关临时对象的内容,请参考:https://docs.microsoft.com/en-us/cpp/cpp/temporary-objects