一、c++ resize函數(shù)
resize函數(shù)是c++標(biāo)準(zhǔn)庫vector容器的一個成員函數(shù),用于改變vector的大小。它可以使vector變大或變小,根據(jù)變化的大小,它可能會在vector的末尾添加新元素,或者從末尾刪除元素。
resize的形式如下:
void resize (size_type n);
void resize (size_type n, value_type val);
第一個參數(shù)表示新的大小,第二個可選參數(shù)表示插入的新值(缺省為默認(rèn)構(gòu)造函數(shù)值,可以是一個默認(rèn)值,也可以是一個可變參數(shù)模板包)。
下面是一個使用resize函數(shù)的示例:
#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
運(yùn)行以上示例代碼,輸出結(jié)果如下:
myvector contains: 1 2 3 4 5 100 100 100 0 0 0 0
可以看到,myvector刪除了最后5個元素,然后在其末尾添加了元素100,最后再添加了4個零。
二、c++ resize函數(shù)報(bào)錯忽略
在調(diào)用resize函數(shù)時,可能會遇到這樣一些錯誤:
Invalid write of size Invalid read of size Invalid free這時可以在代碼中添加一些錯誤捕獲,忽略這些錯誤,使程序正常運(yùn)行:
#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結(jié)構(gòu),將錯誤分別捕獲并打印到標(biāo)準(zhǔn)錯誤輸出流中。注意,在使用此技巧時需要定義宏_GLIBCXX_DEBUG。
三、c++ resize報(bào)錯
在調(diào)用resize函數(shù)時,可能還會遇到以下錯誤:
vector::_M_fill_insert vector::_M_range_insert這些錯誤通常是因?yàn)榉欠ㄔL問vector的元素而導(dǎo)致的。解決方法是使用迭代器對vector的元素進(jìn)行訪問。以下是一個示例代碼:
#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函數(shù)在vector中插入一個元素。這種方法避免了上述錯誤。
四、c++ resize異常
在調(diào)用resize函數(shù)時,可能會拋出以下異常:
std::length_error這種異常是std::vector的標(biāo)準(zhǔn)異常之一,表示試圖分配大于最大元素個數(shù)(即max_size())的內(nèi)存。以下是一個示例代碼:
#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報(bào)異常
在調(diào)用resize函數(shù)時,可能會出現(xiàn)以下錯誤:
allocator這是通常因?yàn)閍llocator
六、c++ resize image
在使用resize函數(shù)時,可以將其用于圖片處理中,用于縮放圖片。以下是一個示例代碼:
#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函數(shù)對其進(jìn)行縮放。
七、c++ resize實(shí)現(xiàn)原理
resize函數(shù)實(shí)現(xiàn)的本質(zhì)是動態(tài)內(nèi)存分配和拷貝元素。當(dāng)vector的大小變化時,如果新的大小大于現(xiàn)有內(nèi)存,vector將動態(tài)地分配一塊新內(nèi)存,并將舊的元素拷貝到新的內(nèi)存中。
vector最初分配的內(nèi)存大小在每次重新分配時都會倍增,以提高效率。最多可以分配2^n個元素,n是vector重新分配次數(shù)的最大值。
八、c++ resize報(bào)錯如何跳過
在使用resize函數(shù)時,有時我們希望即使出現(xiàn)錯誤,程序也能夠繼續(xù)執(zhí)行。下面是一個示例代碼,當(dāng)出現(xiàn)任何錯誤時,程序?qū)⒗^續(xù)執(zhí)行:
#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函數(shù)嘗試調(diào)整vector大小,如果出現(xiàn)任何錯誤,程序?qū)⒑雎圆⒗^續(xù)執(zhí)行。
九、c++ resize空間復(fù)雜度
resize函數(shù)的空間復(fù)雜度取決于被調(diào)用的大小。如果新大小大于原始大小,則將分配多余的內(nèi)存。如果新大小小于原始大小,則將在vector尾部刪除多余的元素。
下面是一個示例代碼,演示vector調(diào)整大小后的空間占用情況:
#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;
}
運(yùn)行以上代碼,輸出結(jié)果如下:
Before resize: 6
After resize: 20
可以看到,調(diào)整vector大小后,它的容量發(fā)生了變化。