• 这段时间编程遇到的小坑


    • 迭代器的使用
      遍历一个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,因为每行可能会有字节填充的。

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

  • 相关阅读:
    把一件简单的事情做好你就不简单了
    一个经验尚浅的码农五年软件开发的一点自我总结,对工作五年的反思~
    我就是一名房地产经纪人!不是中介,谁能明白我们呢?
    我与父辈的酒局
    郎意难坚,侬情自热(文/王路)
    红灯须硬闯,马路要横穿(文/王路)
    孩子,你慢慢来
    职场六年后的一点点感言
    有幸见到一朵花的绽放
    当你遇到她
  • 原文地址:https://www.cnblogs.com/liumeng-blog/p/8081336.html
Copyright © 2020-2023  润新知