- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试将序列化结构从一个等级发送到另一个等级。结果是
Segmentation fault: 11
我不知道它来自哪里。
我试图通过打印出一些值来定位问题,并且代码总是在 MPI_Send
和 MPI_Recv
之间中断,但由于它是段错误,因此无法确定这是问题的根源。请赐教。
int N = 11;
struct tests{
int number;
double *fx;
};
void locateMemoryTests(struct tests *t){
t->fx = (double*) malloc(N*sizeof(double));
}
void he(struct tests *t, int N){
int NRank, MyRank;
MPI_Comm_rank( MPI_COMM_WORLD, &MyRank );
MPI_Comm_size( MPI_COMM_WORLD, &NRank );
int st = MyRank * int(N/2);
int en = (MyRank+1) * int(N/2) + (N%2)*MyRank;
for (int i=st; i<en; i++){
t->fx[i] = i*i + 5*(i + t->number);
}
const int nitems = 2;
int blocklengths[2] = {1, N};
MPI_Datatype types[2] = {MPI_INT, MPI_DOUBLE};
MPI_Datatype mpi_tests_type;
MPI_Aint offsets[2];
offsets[0] = offsetof(tests, number);
offsets[1] = offsetof(tests, fx);
MPI_Type_create_struct(nitems, blocklengths, offsets, types, &mpi_tests_type);
MPI_Type_commit(&mpi_tests_type);
MPI_Comm_rank(MPI_COMM_WORLD, &MyRank);
if (MyRank == 0){
struct tests send;
send.number = t->number;
locateMemoryTests(&send);
for (int i=0; i<N; i++){
send.fx[i] = t->fx[i];
}
MPI_Send(&send, 2, mpi_tests_type, 1, 111, MPI_COMM_WORLD);
}
else if (MyRank == 1){
MPI_Status status;
struct tests recv;
locateMemoryTests(&recv);
MPI_Recv(&recv, 2, mpi_tests_type, 0, 111, MPI_COMM_WORLD, &status);
MPI_Type_free(&mpi_tests_type);
}
int main( int argc, char *argv[] ){
int NRank, MyRank;
MPI_Init( &argc, &argv );
MPI_Comm_rank( MPI_COMM_WORLD, &MyRank );
MPI_Comm_size( MPI_COMM_WORLD, &NRank );
struct tests tt;
tt.number = 5;
locateMemoryTests(&tt);
he(&tt,N);
MPI_Finalize();
return 0;
}
最佳答案
您的 MPI 派生数据类型描述了以下 C struct
struct tests{
int number;
double fx[N];
};
但是你用的是不同的
struct tests{
int number;
double *fx;
};
如果 N
不是常量,您可以声明
struct tests{
int number;
double fx[];
};
正确分配这样的结构
取决于您。
另一种选择是保持相同的struct
定义,并手动MPI_Pack()
和MPI_Unpack()
将数据传入/传出临时缓冲区。
关于c++ - 段错误 : Struct Serialisation and MPI Data Transfer in C++,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56507811/
我有一个数组 items[] items[] 中的每一项都是一个结构体。 item 有键 id、date、value(即 item.id、item.date、item.value) 我想使用 Stru
我想存储 100 名员工。 RollNo,姓名,工资,时间(各种数据,我无法在这里解释,但你可以看下面的代码片段来理解 main() { struct day { int hour
这个问题在这里已经有了答案: storage size of ‘names’ isn’t known (3 个答案) 关闭 5 年前。 我正在尝试蓝牙编程,遇到了这个我不明白的问题。基本上,当我使用
这是一个奇怪的事情: 我有一个结构,它包含指向相同类型结构的指针和指向其他类型结构的指针,以及一些其他值。 struct animal { struct animal * father;
我有一个结构定义如下(名称不同) struct str1 { int field1; struct str2; } 我在一个函数中有一个*str1。我想要一个指向 str2 的指针。 所以
DISK_DETECTION_INFO is defined as有什么原因吗? typedef struct _DISK_DETECTION_INFO { DWORD Size
我正在尝试打包一个字符串和一个字符串的长度。 fmt = '
我在创建结构时遇到问题。 我的结构: public struct Device: Codable { let data: DeviceData let meta: Meta? } pu
struct Item { var name:String? var type:String? var value:Int? var tag:Int? } ... ..
// NewReaderSize returns a new Reader whose buffer has at least the specified 43 // size. If the ar
这个问题在这里已经有了答案: Sorting a vector of custom objects (14 个答案) 关闭 3 年前。 在下面的 C++ 片段中, 如何基于 TwoInts 结构中的
#include struct Header { unsigned long long int alignment; }; int main(void) { struct Heade
我有一个目前看起来像这样的结构(缩写为仅显示基本部分): typedef struct { uint32_t baudrate; ... some other internally u
对此没有太多解释,这就是我所拥有的: public struct PACKET_HEADER { public string computerIp; publi
我有以下代码: struct MyStruct{ data: &'a str, } fn get(S: &'a MyStruct) -> &'a str{ S.data } fn se
struct S1 { char c; int i; }; struct S3 { char c1; struct S1 s; double c2; }; 我正
我有一个名为 Parameter 的协议(protocol): protocol Parameter { var name: String { get } var unit: Unit
有 2 个 struct 定义 A 和 A。我知道 struct A 可以包含指向 struct A 的 POINTER 但我不明白为什么 struct A 不能包含struct A(不是指针) 最佳
我有以下代码: struct MyStruct{ data: &'a str, } fn get(S: &'a MyStruct) -> &'a str{ S.data } fn se
为了说明这一点,这里有一个小的不可变结构和一个更新它的函数: (struct timeseries (variable observations) #:transparent) (define (ad
我是一名优秀的程序员,十分优秀!