DaG DaG - 4 months ago 14
C++ Question

Why does a variable become 'const' when I use a [=] capture (using Lambda class)?

Premise #1: I have already solved the error, but I didn't deeply understand the cause of the compiler error.

Premise #2: The goal of this program is to copy a image into another image by a multithreaded process. Maybe a better way exists, but this is not the focus topic of the question (see premise #1).

I wrote a simple program using OpenCV 3.1 library to copy a image into another image. It takes advantage of all cores of the CPU using more threads.

The code is:

#include <opencv2/opencv.hpp>
#include <iostream>
#include <stdio.h>
#include <stdlib.h>
#include <thread>

using namespace cv;
using namespace std;

#define IMG_PATH "..\\img\\50a.png"

void copy_image(const Mat& input, Mat& output, int row_offset, int skip_row)
cout << row_offset;
Size size = input.size();
for (int r = row_offset; r < size.height; r += skip_row)
for (int c = 0; c < size.width; c++)
output.at<Vec3b>(r, c) = input.at<Vec3b>(r, c);

int main()
Mat input_img = imread(IMG_PATH);
Mat output_img = Mat(input_img.size(), input_img.type()); output_img.setTo(255);

vector<thread> threads;
int thread_number = thread::hardware_concurrency();

for (int i = 0; i < thread_number; i++)
cout << i;
auto var = [=]()
return copy_image(input_img, output_img, i, thread_number);


for (auto& thread : threads)

imshow("output_img", output_img);
imwrite("result.png", output_img);

The compiler returns me this error

Error C2664 'void copy_image(const cv::Mat &,cv::Mat &,int,int)':
cannot convert argument 2 from 'const cv::Mat' to 'cv::Mat &'

that it reffers this line of code:

return copy_image(input_img, output_img, i, thread_number);

I solved this error replacing this line

auto var = [=]()

with this

auto var = [=, &input_img, &output_img]()

but actually I don't deeply understand why I received that error.


Captured variables are indeed const in the scope of the lamba:

   // foo, whatever that is, is const

In a mutable lambda, the captured variables are not constant:

mutable {

   // Lambda can modify foo, but it's a copy of the original
   // captured variable