一、c++ resize函数
resize函数是c++标准库vector容器的一个成员函数,用于改变vector的大小。它可以使vector变大或变小,根据变化的大小,它可能会在vector的末尾添加新元素,或者从末尾删除元素。
resize的形式如下:
void resize (size_type n);
void resize (size_type n, value_type val);
第一个参数表示新的大小,第二个可选参数表示插入的新值(缺省为默认构造函数值,可以是一个默认值,也可以是一个可变参数模板包)。
下面是一个使用resize函数的示例:
#include <iostream>
#include <vector>
int main ()
{
std::vector<int> myvector;
// 添加元素
for (int i=1; i<10; i++) myvector.push_back(i);
myvector.resize(5);
myvector.resize(8,100);
myvector.resize(12);
std::cout << "myvector contains:";
for (int i=0;i<myvector.size();i++)
std::cout << ' ' << myvector[i];
std::cout << '\n';
return 0;
}
运行以上示例代码,输出结果如下:
myvector contains: 1 2 3 4 5 100 100 100 0 0 0 0
可以看到,myvector删除了最后5个元素,然后在其末尾添加了元素100,最后再添加了4个零。
二、c++ resize函数报错忽略
在调用resize函数时,可能会遇到这样一些错误:
- Invalid write of size
- Invalid read of size
- Invalid free
这时可以在代码中添加一些错误捕获,忽略这些错误,使程序正常运行:
#define _GLIBCXX_DEBUG
#include <iostream>
#include <vector>
int main ()
{
std::vector<int> myvector {0, 1, 2, 3, 4, 5};
try {
myvector.resize(1000);
}
catch (std::length_error &e) {
std::cerr << "Length error: " << e.what() << '\n';
}
catch (...) {
std::cerr << "Some other error!\n";
}
std::cout << "myvector contains:";
for (int i=0;i<myvector.size();i++)
std::cout << ' ' << myvector[i];
std::cout << '\n';
return 0;
}
以上代码中,我们使用了try-catch结构,将错误分别捕获并打印到标准错误输出流中。注意,在使用此技巧时需要定义宏_GLIBCXX_DEBUG。
三、c++ resize报错
在调用resize函数时,可能还会遇到以下错误:
- vector::_M_fill_insert
- vector::_M_range_insert
这些错误通常是因为非法访问vector的元素而导致的。解决方法是使用迭代器对vector的元素进行访问。以下是一个示例代码:
#include <iostream>
#include <vector>
int main() {
std::vector<int> vec { 1, 2, 3 };
std::vector<int> new_vec;
new_vec.resize(vec.size() + 1);
std::copy(vec.begin(), vec.end(), new_vec.begin());
// 插入值
int value = 4;
auto it = new_vec.begin();
it += 2;
new_vec.insert(it, value);
std::cout << "Before:\n";
for (int i : vec) std::cout << i << ' ';
std::cout << '\n';
std::cout << "After:\n";
for (int i : new_vec) std::cout << i << ' ';
std::cout << '\n';
}
以上代码中,我们使用了迭代器遍历vector,并使用insert函数在vector中插入一个元素。这种方法避免了上述错误。
四、c++ resize异常
在调用resize函数时,可能会抛出以下异常:
- std::length_error
这种异常是std::vector的标准异常之一,表示试图分配大于最大元素个数(即max_size())的内存。以下是一个示例代码:
#include <iostream>
#include <vector>
int main ()
{
std::vector<int> myvector {0, 1, 2, 3, 4, 5};
try {
myvector.resize(myvector.max_size()+1);
}
catch (std::length_error &e) {
std::cerr << "Length error: " << e.what() << '\n';
}
return 0;
}
五、c++ resize报异常
在调用resize函数时,可能会出现以下错误:
- allocator
::allocate()
这是通常因为allocator
六、c++ resize image
在使用resize函数时,可以将其用于图片处理中,用于缩放图片。以下是一个示例代码:
#include <iostream>
#include <opencv2/core/core.hpp>
#include <opencv2/highgui/highgui.hpp>
#include <opencv2/imgproc/imgproc.hpp>
int main()
{
cv::Mat image = cv::imread("test.jpg", CV_LOAD_IMAGE_COLOR);
cv::Size size(400, 400);
cv::Mat dst;
cv::resize(image, dst, size);
cv::imshow("Resized Image", dst);
cv::waitKey(0);
return 0;
}
以上代码使用OpenCV库加载图片,并使用resize函数对其进行缩放。
七、c++ resize实现原理
resize函数实现的本质是动态内存分配和拷贝元素。当vector的大小变化时,如果新的大小大于现有内存,vector将动态地分配一块新内存,并将旧的元素拷贝到新的内存中。
vector最初分配的内存大小在每次重新分配时都会倍增,以提高效率。最多可以分配2^n个元素,n是vector重新分配次数的最大值。
八、c++ resize报错如何跳过
在使用resize函数时,有时我们希望即使出现错误,程序也能够继续执行。下面是一个示例代码,当出现任何错误时,程序将继续执行:
#define _GLIBCXX_DEBUG
#include <iostream>
#include <vector>
int main ()
{
std::vector<int> myvector;
try {
myvector.resize(1000000);
}
catch (...) {}
std::cout << "myvector contains " << myvector.size() << " elements.\n";
return 0;
}
以上代码将resize函数尝试调整vector大小,如果出现任何错误,程序将忽略并继续执行。
九、c++ resize空间复杂度
resize函数的空间复杂度取决于被调用的大小。如果新大小大于原始大小,则将分配多余的内存。如果新大小小于原始大小,则将在vector尾部删除多余的元素。
下面是一个示例代码,演示vector调整大小后的空间占用情况:
#include <iostream>
#include <vector>
int main ()
{
std::vector<int> myvector {0, 1, 2, 3, 4, 5};
std::cout << "Before resize: " << myvector.capacity() << '\n';
myvector.resize(20);
std::cout << "After resize: " << myvector.capacity() << '\n';
return 0;
}
运行以上代码,输出结果如下:
Before resize: 6
After resize: 20
可以看到,调整vector大小后,它的容量发生了变化。