我正在做一个涉及使用winthreads乘以矩阵的作业。
我是C的新手,这就是我所拥有的所有代码(我在这里读了一些帖子)。
#include <stdlib.h>
#include <stdio.h>
#include <time.h>
#define M 3
#define K 3
#define N 3
#define NUMBER_OF_THREADS 9
int A[M][K] = { {1,4,3}, {2,5,4}, {3,6,1} };
int B[K][N] = { {8,7,6}, {5,4,3}, {7,3,1} };
int C[M][N];
clock_t start,end;
struct v
{
int i;
int j;
};
DWORD WINAPI MatrixMult(LPVOID Param)
{
int a;
DWORD sum = 0;
struct v *data = Param;
for(a = 0; a < 3; a++)
{
sum = sum + ((A[data->i][a]) * (B[a][data->j]));
}
C[data->i][data->j] = sum;
return 0;
}
int main()
{
struct v *data = malloc(sizeof(struct v));
int i, j, k;
DWORD ThreadIds[NUMBER_OF_THREADS];
HANDLE ThreadHandles[NUMBER_OF_THREADS];
int thread_index = 0;
start = clock();
for (i = 0; i < M; i++)
{
for (j = 0; j < N; j++ )
{
data->i = i;
data->j = j;
ThreadHandles[thread_index] = CreateThread (NULL, 0, MatrixMult, &data, 0, &ThreadIds[thread_index]);
if (!ThreadHandles)
{
printf("Error, threads cannot be created");
return 1;
}
}
thread_index++;
}
printf("Result:\n");
for (i = 0; i < M; i++)
{
for (j = 0; j < N; j++)
{
printf("C[%d][%d] = %f\n", i,j, C[i][j]);
}
}
for (i = 0; i < 9; i++)
{
CloseHandle(ThreadHandles[i]);
}
end = clock();
printf("Tiempo = %d", end - start);
return 0;
}
我对这个程序有一些问题,它编译,但它没有运行,它在0x775f15de异常中标记错误,在读取0x3468a3bc时出错。任何有关此错误存在的想法以及如何解决?
答案 0 :(得分:2)
至少有三个问题:
data
是struct v*
,但它的地址作为参数传递给线程(即struct v**
),然后被解释为struct v*
}。这是不正确的,可能是错误的原因。
所有线程都将在名为struct v
的{{1}}的同一个实例上执行。这将引入竞争条件。为每个线程分配一个新的data
,并在不再需要时为其设置线程struct v
。
free()
的类型为C[i][j]
,但int
的格式说明符为printf()
。这是不正确的,它应该是%f
(与其他参数一样)。
请注意,不需要转换%d
(Do I cast the result of malloc?)的返回值。从发布的代码中编写malloc()
行的更常见和更好的方法是:
malloc()
请记住struct v* data = malloc(sizeof(*data));
什么是free()
d。