2

我正在创建一个两线程数组求和程序,我正在使用 windows.h 线程。这是我到目前为止的代码。

#include "StdAfx.h"
#include <stdio.h>
#include <iostream>
#include <windows.h>
#include <process.h>     // needed for _beginthread()

void  silly( void * );   // function prototype

using namespace std;

int arraySum[100];

int main()
{
    // Our program's first thread starts in the main() function.

    printf( "Now in the main() function.\n" );


    for(int i = 0 ; i  < 100 ; i++){
        arraySum[i] = i;
    }

    // Let's now create our second thread and ask it to start
    // in the silly() function.


    _beginthread( silly, 0, (void*)1 );
    _beginthread( silly, 0, (void*)2 );

    Sleep( 100 );

    int a;
    cin >> a;

}

void  silly( void *arg )
{
    printf( "The silly() function was passed %d\n", (INT_PTR)arg ) ;
    int partialSum = 0;
    for(int i =50*((INT_PTR)arg - 1); i < 50 * ((INT_PTR)arg) ; i++){
    partialSum == arraySum[i];
    }
}

我似乎觉得很难做的是让函数将分区总和返回给 main 方法。有人可以帮我吗。

4

3 回答 3

6

传递一个intto的地址silly(),它可以作为输入和输出参数,并silly()使用调用者所需的值填充它:

int silly_result_1 = 1;
int silly_result_2 = 2;

_beginthread( silly, 0, (void*)&silly_result_1 );
_beginthread( silly, 0, (void*)&silly_result_2 );

void silly( void *a_arg )
{
    int* arg = (int*) a_arg;
}

您需要等待两个线程完成。


请注意,其地址被传递的变量必须_beginthread()在线程的生命周期内存在。例如,以下将导致未定义的行为:

void _start_my_thread()
{
    int silly_result = 2;
    _beginthread( silly, 0, (void*)&silly_result );
} /* 'silly_result' is out of scope but still used by the thread. */

这可以通过为变量动态分配内存来解决(并决定是主线程还是新线程负责销毁分配的内存)。

于 2012-09-26T13:59:35.343 回答
5

你不能让线程本身返回一些东西。相反,您可以在开始调用中使用结构。

_beginthread( silly, 0, (void*)1 );

如果您将其更改为

typedef struct dataStruct {
    int ID;
    int returnValue;
};

dataStruct thread_1;
thread_1.ID = 1;
thread_1.returnValue = 0;
_beginthread( silly, 0, (void*)&thread_1 );

然后在您的线程中根据需要设置 returnValue,并且可以从那里继续

于 2012-09-26T13:59:24.093 回答
0

在 C++11 中,您可能希望为此使用期货:

#include <future>
#include <numeric>
#include <iostream>

int arraySum[100];

int partial_sum(int start)
{
    int sum = 0;
    for(int i = start; i < start + 50; ++i)
        sum += arraySum[i];
    return sum;
}

int main()
{
    for(int i = 0 ; i  < 100 ; i++)
    {
        arraySum[i] = i;
    }
    auto a = std::async([]() {return partial_sum(0);});
    auto b = std::async([]() {return partial_sum(50);});
    std::cout << a.get() + b.get() << "\n";
}

也许你想传递一个std::launch::async启动策略std::async来强制创建线程。

于 2012-09-26T14:26:17.433 回答