- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我对 C Pthreaded 程序有疑问。我必须计算两个矩阵 m1(nr1
行和 nc1
列)和 m2(nr2
行和 nc2
列)。我创建 nr1 * nc2 线程运行时传递给每个线程 m1 的行数和 m2 的列数相乘。线程,将结果保存在另一个矩阵中。代码是这样的:
#include <stdio.h>
#include <stdlib.h>
#include "pthread.h"
#include "semaphore.h"
struct prodmat{
int row;
int col;
};
int number;
double **dmat1;
double **dmat2;
double **dmatprod;
void ** allocaM2d (int nr, int nc, int dim);
void prodmat(double ** a, double ** b, double ** c, int nr1, int nc1nr2,
int nc2);
void * prodthread(struct prodmat * prod){
pthread_detach (pthread_self ());
//printf("THREAD");
int r,c,k;
r = prod->row;
c = prod->col;
printf("Thread for product of row = %i, column = %i and number = %i\n",r,c,number);
for (k=0; k<number; k++){
//dmatprod[r][c] += dmat1[r][k]*dmat2[k][c];
printf("product of dmat1[%i][%i]=%i * dmat2[%i][%i] = %i\n",r,k,dmat1[r][k],k,c, dmat2[k][c]);
}
}
int main(void) {
int nr1, nc1, nr2, nc2, dim, i, j, k,r,c;
printf("Rows and Columns of the first matrix: ");
scanf ("%d%d",&nr1, &nc1);
do {
printf("Rows and Columns of the second matrix\n");
printf("The number of rows must be equal to nc1 ");
scanf ("%d%d",&nr2, &nc2);
} while (nr2 != nc1);
number = nr2;
// dynamic allocation
dim = sizeof(double);
dmat1 = (double **) allocaM2d(nr1, nc1, dim);
dmat2 = (double **) allocaM2d(nr2, nc2, dim);
dmatprod = (double **) allocaM2d(nr1, nc2, dim);
// in this for i create m1 and m2 and then i print these
k=0;
for(i=0;i<nr1;i++)
for(j=0;j<nc1;j++)
dmat1[i][j] = k++;
for(i=0;i<nr1;i++){
for(j=0;j<nc1;j++)
printf("%lf ", dmat1[i][j]);
printf("\n");
}
printf("\n");
k=0;
for(i=0;i<nr2;i++)
for(j=0;j<nc2;j++)
dmat2[i][j] = k++;
for(i=0;i<nr2;i++){
for(j=0;j<nc2;j++)
printf("%lf ", dmat2[i][j]);
printf("\n");
}
//This is the cycle where i create the threads
r=0; c=0;
for(r=0; r<nr1 ; r++)
{
for(c=0; c<nc2; c++){
struct prodmat * prod; prod= malloc(sizeof(struct prodmat *));
pthread_t * th; th= malloc(sizeof(pthread_t *));
prod->row = r;
prod->col = c;
pthread_create(th,NULL,prodthread,prod);
}
}
/*
prodmat( dmat1, dmat2, dmatprod, nr1, nc1, nc2);
printf("\n");
for(i=0;i<nr1;i++){
for(j=0;j<nc2;j++)
printf("%lf ", dmatprod[i][j]);
printf("\n");
}
*/
//is not important this sleep(100). I will replace in future.
sleep(100);
}
/************************************************************/
void ** allocaM2d (int nr, int nc, int dim){
int i;
void ** m;
char * vd; // byte pointer
m = (void **) malloc(nr * sizeof(void *));
vd = (char *) malloc(nr * nc * dim);
for(i=0;i<nr;i++)
m[i] = &vd[i * nc * dim];
return (void **) m; // return matrix pointer
}
然后我收到 m1 和 m2 的打印品以及产品的打印品,如下所示:
0.000000 1.000000 2.000000 3.000000 4.000000
5.000000 6.000000 7.000000 8.000000 9.000000
10.000000 11.000000 12.000000 13.000000 14.000000
15.000000 16.000000 17.000000 18.000000 19.000000
0.000000 1.000000 2.000000 3.000000
4.000000 5.000000 6.000000 7.000000
8.000000 9.000000 10.000000 11.000000
12.000000 13.000000 14.000000 15.000000
16.000000 17.000000 18.000000 19.000000
Thread for product of row = 3, column = 2 and number = 5
product of dmat1[3][0]=0 * dmat2[2][0] = 0
product of dmat1[3][1]=1 * dmat2[2][0] = 0
product of dmat1[3][2]=2 * dmat2[2][0] = 0
product of dmat1[3][3]=3 * dmat2[2][0] = 0
product of dmat1[3][4]=4 * dmat2[2][0] = 0
但是,在第二部分中,如果 m2 从未被初始化(即使在第一部分中打印显示不同),似乎也是如此。
已解决:正确的代码是这样的:
#include <stdio.h>
#include <stdlib.h>
#include "pthread.h"
#include "semaphore.h"
struct prodmat{
int row;
int col;
};
int number;
double **dmat1;
double **dmat2;
double **dmatprod;
void ** allocaM2d (int nr, int nc, int dim);
void prodmat(double ** a, double ** b, double ** c, int nr1, int nc1nr2,
int nc2);
void * prodthread(struct prodmat * prod){
pthread_detach (pthread_self ());
//printf("THREAD");
int r,c,k;
r = prod->row;
c = prod->col;
//printf("Thread for product of row = %i, column = %i \n",r,c);
for (k=0; k<number; k++){
dmatprod[r][c] += dmat1[r][k]*dmat2[k][c];
//printf("product of dmat1[%i][%i]=%lf * dmat2[%i][%i] = %lf\n",r,k,dmat1[r][k],k,c, dmat2[k][c]);
}
pthread_exit(pthread_self ());
}
void * printer(struct prodmat * prod){
pthread_detach (pthread_self ());
//printf("THREAD");
int r,c,i,j;
r = prod->row;
c = prod->col;
//printf("Thread for product of row = %i, column = %i \n",r,c);
printf("\n\n --> PRODUCT: \n\n");
for(i=0;i<r;i++){
for(j=0;j<c;j++)
printf("%lf ", dmatprod[i][j]);
printf("\n");
}
printf("\n\n ");
pthread_exit(pthread_self ());
}
int main(void) {
int nr1, nc1, nr2, nc2, dim, i, j, k,r,c;
printf("Rows and Columns of the first matrix: ");
scanf ("%d%d",&nr1, &nc1);
do {
printf("Rows and Columns of the second matrix\n");
printf("The number of rows must be equal to nc1 ");
scanf ("%d%d",&nr2, &nc2);
} while (nr2 != nc1);
number = nr2;
// dynamic allocation
dim = sizeof(double);
dmat1 = (double **) allocaM2d(nr1, nc1, dim);
dmat2 = (double **) allocaM2d(nr2, nc2, dim);
dmatprod = (double **) allocaM2d(nr1, nc2, dim);
k=0;
for(i=0;i<nr1;i++)
for(j=0;j<nc1;j++)
dmat1[i][j] = k++;
for(i=0;i<nr1;i++){
for(j=0;j<nc1;j++)
printf("%lf ", dmat1[i][j]);
printf("\n");
}
printf("\n");
k=0;
for(i=0;i<nr2;i++)
for(j=0;j<nc2;j++)
dmat2[i][j] = k++;
for(i=0;i<nr2;i++){
for(j=0;j<nc2;j++)
printf("%lf ", dmat2[i][j]);
printf("\n");
}
r=0; c=0;
for(r=0; r<nr1 ; r++)
{
for(c=0; c<nc2; c++){
struct prodmat * prod; prod= malloc(sizeof(struct prodmat));
pthread_t * th; th= malloc(sizeof(pthread_t ));
prod->row = r;
prod->col = c;
pthread_create(th,NULL,prodthread,prod);
}
}
sleep(1);
struct prodmat * prod; prod= malloc(sizeof(struct prodmat));
pthread_t * th; th= malloc(sizeof(pthread_t ));
prod->row = nr1;
prod->col = nc2;
pthread_create(th,NULL,printer,prod);
/*
prodmat( dmat1, dmat2, dmatprod, nr1, nc1, nc2);
printf("\n");
for(i=0;i<nr1;i++){
for(j=0;j<nc2;j++)
printf("%lf ", dmatprod[i][j]);
printf("\n");
}
*/
pthread_exit(pthread_self ());
}
/************************************************************/
void ** allocaM2d (int nr, int nc, int dim){
int i;
void ** m;
char * vd; // byte pointer
m = (void **) malloc(nr * sizeof(void *));
vd = (char *) malloc(nr * nc * dim);
for(i=0;i<nr;i++)
m[i] = &vd[i * nc * dim];
return (void **) m; // return matrix pointer
}
对于 ex 的 5x5 和 5x5 输入,这会产生:
0.000000 1.000000 2.000000 3.000000 4.000000
5.000000 6.000000 7.000000 8.000000 9.000000
10.000000 11.000000 12.000000 13.000000 14.000000
15.000000 16.000000 17.000000 18.000000 19.000000
20.000000 21.000000 22.000000 23.000000 24.000000
0.000000 1.000000 2.000000 3.000000 4.000000
5.000000 6.000000 7.000000 8.000000 9.000000
10.000000 11.000000 12.000000 13.000000 14.000000
15.000000 16.000000 17.000000 18.000000 19.000000
20.000000 21.000000 22.000000 23.000000 24.000000
--> PRODUCT:
150.000000 160.000000 170.000000 180.000000 190.000000
400.000000 435.000000 470.000000 505.000000 540.000000
650.000000 710.000000 770.000000 830.000000 890.000000
900.000000 985.000000 1070.000000 1155.000000 1240.000000
1150.000000 1260.000000 1370.000000 1480.000000 1590.000000
最佳答案
您的产品 printf
不正确。
printf("product of dmat1[%i][%i]=%i * dmat2[%i][%i] = %i\n",r,k,dmat1[r][k],k,c, dmat2[k][c]);
// ^ wrong ^ wrong
矩阵中的内容是 double float ,您应该使用 %f
或其他合适的浮点格式说明符。
关于c - C 中带有 pthreads 的两个矩阵的乘积,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43136047/
我想使用 li 和 ul 制作一个多级下拉列表,以便显示我博客中按年和月排序的所有文章。我希望我的下拉菜单看起来像 Google Blogspot 下拉菜单: 这是我的 CSS 和 HTML 代码 u
我在 Win 7 64 机器上将 CodeBlocks 与 gcc 4.7.2 和 gmp 5.0.5 结合使用。开始使用 gmpxx 后,我看到一个奇怪的段错误,它不会出现在 +、- 等运算符中,但
我正在使用 tern 为使用 CodeMirror 运行的窗口提供一些增强的智能感知,它工作正常,但我遇到了一个问题,我想添加一些自定义“types”,可以这么说,这样下拉列表中它们旁边就有图标了。我
我正在尝试让我的 PC 成为 Android 2.3.4 设备的 USB 主机,以便能够在不需要实际“附件”的情况下开发 API。为此,我需要将 PC 设置为 USB 主机和“设备”(在我的例子中是运
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 9
我在设置服务器方面几乎是个新手,但遇到了一个问题。我有一个 Ubuntu 16.04 VPS 并安装了 Apache2 和 Tomcat7。我正在为 SSL 使用 LetsEncrypt 和 Cert
我在一个基于谷歌地图的项目上工作了超过 6 个月。我使用的是 Google Maps API V1 及其开发人员 API key 。当我尝试发布应用程序时,我了解到 Google API V1 已被弃
我是 Python 的新手,所以如果我对一些简单的事情感到困惑,请原谅。 我有一个这样的对象: class myObject(object): def __init__(self):
这个问题已经有答案了: How can I access object properties containing special characters? (2 个回答) 已关闭 9 年前。 我正在尝
我有下面的 CSS。我想要的是一种流体/液体(因为缺乏正确的术语)css。我正在为移动设备开发,当我改变模式时 从纵向 View 到陆地 View ,我希望它流畅。现在的图像 在陆地 View 中效
我正在尝试使用可以接受参数的缓存属性装饰器。 我查看了这个实现:http://www.daniweb.com/software-development/python/code/217241/a-cac
这个问题在这里已经有了答案: Understanding slicing (36 个答案) 关闭 6 年前。 以a = [1,2,3,4,5]为例。根据我的直觉,我认为 a[::-1] 与 a[0:
mysqldump -t -u root -p mytestdb mytable --where=datetime LIKE '2014-09%' 这就是我正在做的事情,它会返回: mysqldum
我正在制作销售税计算器,除了总支付金额部分外,其他一切都正常。在我的程序中,我希望能够输入一个数字并获得该项目的税额我还希望能够获得支付的总金额,包括交易中的税金。到目前为止,我编写的代码完成了所有这
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许在 Stack Overflow 上提出有关通用计算硬件和软件的问题。您可以编辑问题,使其成为
我是否必须进行任何额外的设置才能让 apache-airflow 在任务失败时向我发送电子邮件。我的配置文件中有以下内容(与默认值保持不变): [email] email_backend = airf
这个问题在这里已经有了答案: What does the $ symbol do in VBA? (5 个回答) 3年前关闭。 使用返回字符串(如 Left)的内置函数有什么区别吗?或使用与 $ 相同
我有一个用VB6编写的应用程序,我需要使用一个用.NET编写的库。有什么方法可以在我的应用程序上使用该库吗? 谢谢 最佳答案 这取决于。您可以控制.NET库吗? 如果是这样,则可以修改您的库,以便可以
当我创建一个以 ^ 开头的类方法时,我尝试调用它,它给了我一个错误。 class C { method ^test () { "Hi" } } dd C.new.test; Too m
我已经使用 bower 安装了 angularjs 和 materialjs。 凉亭安装 Angular Material 并将“ngMaterial”注入(inject)我的应用程序,但出现此错误。
我是一名优秀的程序员,十分优秀!