一、c++ resize函數
resize函數是c++標準庫vector容器的一個成員函數,用于改變vector的大小。它可以使vector變大或變小,根據變化的大小,它可能會在vector的末尾添加新元素,或者從末尾刪除元素。
resize的形式如下:
void resize (size_type n);
void resize (size_type n, value_type val);
第一個參數表示新的大小,第二個可選參數表示插入的新值(缺省為默認構造函數值,可以是一個默認值,也可以是一個可變參數模板包)。
下面是一個使用resize函數的示例:
#include
#include
int main ()
{
std::vector 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 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
#include
int main ()
{
std::vector 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
以上代碼中,我們使用了try-catch結構,將錯誤分別捕獲并打印到標準錯誤輸出流中。注意,在使用此技巧時需要定義宏_GLIBCXX_DEBUG。
三、c++ resize報錯
在調用resize函數時,可能還會遇到以下錯誤:
vector::_M_fill_insert vector::_M_range_insert這些錯誤通常是因為非法訪問vector的元素而導致的。解決方法是使用迭代器對vector的元素進行訪問。以下是一個示例代碼:
#include
#include
int main() {
std::vector vec { 1, 2, 3 };
std::vector 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
#include
int main ()
{
std::vector 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這是通常因為allocator
六、c++ resize image
在使用resize函數時,可以將其用于圖片處理中,用于縮放圖片。以下是一個示例代碼:
#include
#include
#include
#include
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
#include
int main ()
{
std::vector myvector;
try {
myvector.resize(1000000);
}
catch (...) {}
std::cout << "myvector contains " << myvector.size() << " elements.\n";
return 0;
}
以上代碼將resize函數嘗試調整vector大小,如果出現任何錯誤,程序將忽略并繼續執行。
九、c++ resize空間復雜度
resize函數的空間復雜度取決于被調用的大小。如果新大小大于原始大小,則將分配多余的內存。如果新大小小于原始大小,則將在vector尾部刪除多余的元素。
下面是一個示例代碼,演示vector調整大小后的空間占用情況:
#include
#include
int main ()
{
std::vector 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大小后,它的容量發生了變化。