3

我想问一下如何使用非 void 函数作为函数来运行线程。

我的意思是,这样的功能:

void example(Mat& in, Mat& out)

我如何将此函数用于线程beginthreadx

粘贴我要在多线程代码中转换的代码:

#include <opencv\cv.h>
#include <opencv\highgui.h>
#include <stdio.h>
#include <windows.h>
#include <process.h>

using namespace std;
using namespace cv;

//filling array
void acquisisci (Mat in[]){
in[0]=imread("C:/OPENCV/Test/imgtest/bird1.jpg",1);
in[1]=imread("C:/OPENCV/Test/imgtest/bird2.jpg",1);
in[2]=imread("C:/OPENCV/Test/imgtest/bird3.jpg",1);
in[3]=imread("C:/OPENCV/Test/imgtest/pig1.jpg",1);
in[4]=imread("C:/OPENCV/Test/imgtest/pig2.jpg",1);
in[5]=imread("C:/OPENCV/Test/imgtest/pig3.jpg",1);
   }

//grey function
void elabora (Mat& in, Mat& out){
    if (in.channels()==3){
        cvtColor(in,out,CV_BGR2GRAY); //passa al grigio
        }
  }
  //threshold function
  void sogliata(Mat& in, Mat& out){
threshold(in,out,128,255,THRESH_BINARY);//fa la soglia
 }

 //view
  void view (Mat& o){
imshow("Immagine",o);
   waitKey(600);
   }

  int main(){

Mat in[6],ou[6],out[6];

acquisisci(in); 

for (int i=0;i<=5;i++){
elabora(in[i],ou[i]); 
}

for (int i=0;i<=5;i++){
sogliata(ou[i],out[i]);
}   

for (int i=0;i<=5;i++){
view(out[i]); 
}
  return 0;

  }

我可以用并行线程做到这一点吗?

4

3 回答 3

4

_beginthreadex需要线程函数的特定签名。

 void(*thread_func)(void *);

要使用具有不同签名的函数,您通常只需创建一个“thunk”——一个除了调用您真正想要调用的函数之外什么都不做的小函数:

struct params {
    Mat &in;
    Mat &out;        
};

void thread_func(void *input) { 
    params *p = (params *)input;

    example(input->in, input->out);
}

您可能还需要包含类似 Windows 之类的东西,Event以在输出中数据准备就绪时发出信号——您不想在线程中的函数有机会写入数据之前尝试读取它:

struct params {
    Mat &in;
    Mat &out;        
    HANDLE event;

    params() : event(CreateEvent(NULL, 0, 0, NULL)) {}
    ~params() { CloseHandle(event); }
};

void thread_func(void *input) { 
    params *p = (params *)input;

    example(input->in, input->out);
    SetEvent(input->event);
}

然后用 start 调用函数thread_func,当它需要结果时,在事件句柄上做类似WaitForSingleObjectWaitForMultipleObjects的事情,这样它就可以在有需要的数据时继续处理。

于 2013-05-15T16:31:31.417 回答
4

beginthreadx只能与具有单个void*参数的函数一起使用。如果您需要多个参数,请创建一个包含两个值的结构,然后将指向该结构的指针作为唯一属性传递。例如:

struct Args {
  Mat& in;
  Mat& out;
};

void example(void* param) {
  Args* args = (Args*) param;
  process(args->in, args->out);
}
于 2013-05-15T16:20:46.077 回答
2

如果您使用的是 C++11,则可以使用 lambda 和std::thread

Mat in, out;
std::thread([&]{ example(in, out); });

如果您不使用 C++11,那么请忽略这个答案。

于 2013-05-15T16:23:39.580 回答