cvCloneImage()和cvCopy()的區別

cvCloneImage()每次使用時編譯器會分配新的內存空間,不會覆蓋以前的內容,所以如果在循環中使用內存會迅速減小,每次用完都需要用cvRelease來釋放。

解決方法是使用cvCopy函數代替。
cvCopy(pSrcImg,pImg,NULL);   //代替 pImg = cvCloneImage(pSrcImg);
pImg初始化時必須分配空間,否則上述函數不能執行。
pImg = cvCreateImage(cvSize(IMGWIDHT,IMGHEIGHT),IPL_DEPTH_8U, 3);

Opencv中cvCopy()和cvCloneImage()的區別:

cvCopy的原型是:
void cvCopy( const CvArr* src, CvArr* dst, const CvArr* mask=NULL );
在使用這個函數之前,你必須用cvCreateImage()一類的函數先開一段內存,然後傳遞給dst。cvCopy會把src中的數據複製到dst的內存中。

cvCloneImage的原型是:
IplImage* cvCloneImage( const IplImage* image );
在使用函數之前,不用開闢內存。該函數會自己開一段內存,然後複製好image裏面的數據,然後把這段內存中的數據返回給你。

clone是把所有的都複製過來,也就是說不論你是否設置Roi,Coi等影響copy的參數,clone都會原封不動的克隆過來。
copy就不一樣,只會複製ROI區域等。

用clone複製之後,源圖像在內存中消失後,複製的圖像也變了,而用copy複製,源圖像消失後,複製的圖像不變。

引自:http://hi.baidu.com/gilbertjuly/blog/item/9e78f511fd0938f7c2ce7978.html

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章