这段时间编程遇到的小坑

  • 迭代器的使用
    遍历一个vector<自定义的结构体> v,结构体里面部分是计算的输入,部分是输出。于是我图简单直接写了:

    for(auto iter : v)
        v.a = Algorthim(v.b);

    后来就直接用v进行后来的计算了,发现出错。原来auto iter是不会改变v数组本身的值的!
    因为这种写法展开就是:

    for(auto iter : v)
    {
    
    }
    等同于:
    
    for(auto piter = v.begin(); piter != v.end(); piter++)
    {
           auto iter = *piter;   
           iter.a = XXX;    //不会修改值
           *piter->a = XXX;    //会修改值
    }

    等同于是一个形参,没有修改数组本身的值。

  • opencv的大坑!
    1 cv::Mat img;
    2 img.resize(80,80); //这个函数竟然不是resize图像大小,而是类似vector的resize的存在,只改变的img的行数
    3 
    4 resize(img, img, cv::size(80,80)); //这个才能改变图像的大小
  • opencv一个坑接一个坑

    ①浅拷贝的情况:

    //赋值方式为浅拷贝
    cv::Mat img1, img2;
    img1=imread("test.jpg");  //将任意一张名为test.jpg的图片放置于工程文件夹test中
    img2 = img1; //浅拷贝,修改img2的时候,同时修改img1
    
    //传参时1:
    void Func1(cv::Mat img1)
    {
       cv::Mat img2 = img2;  //浅拷贝
    }
    
    //传参时2:
    void Func1(unsigned char* data, int width, int height)
    {
       cv::Mat img2(height, width, CV_8UC3, data); //浅拷贝
    }

    ②深拷贝的情况:

    img2.copyTo(img1) 
    img1=img2.clone()
  • opencv另外一个坑:

    Mat中的图像数据是不对齐的,而IplImage中的图像数据是4字节对齐的,所以在访问IplImage图像数据的时候,要特别注意widthStep这个属性,每行的字节数不是width*nchannels而是widthStep,因为每行可能会有字节填充的。

    因此,读像素值的时候,注意,不要读错了。

posted @ 2017-12-21 16:44  mengmee  阅读(165)  评论(0编辑  收藏  举报