在共享内存 inc C 中存储带有向量的结构

Store a struct with vectors in shared memory inc C

我正在尝试将二维数组(矩阵)存储在共享内存中。我正在使用 ubuntu 和 C.

这是我的代码:

结构

typedef struct {
    int data[COLUN_CAP];
} Colonna;

typedef struct {
    int nc;
    key_t colK;
    Colonna colonne[10];
} Matrix;

初始化矩阵的函数:

void iniz_mat(Matrix *M, int n) {
    M->nc = n;
    int i, k;
    for (i = 0; i < M->nc; i++) {      
        printf("Colonna: %d \n", i);
        for (k = 0; k < COLUN_CAP; k++) {  
            M->colonne[i].data[k] = rand() % 10;
        }
    }
}

主程序

key_t shmKM;   
int n;

shmKM = ftok(PATH_SHM, CHAR_SHMM);
scanf("%d", &n);
int idshmM = shmget(shmKM, sizeof(Matrix) + sizeof(Colonna) * 10, IPC_CREAT | 0664);
Matrix *Mat;
Mat = (Matrix *)shmat(idshmM, 0, 0);
iniz_mat(Mat, n);

我收到分段错误(核心转储)错误。我想存储一个列数可变的矩阵,但显然我不能存储一个固定的矩阵。提示?


编辑: 因此,对于可变数量的列,我尝试了:

typedef struct {
    int nc;
    key_t colK;
    Colonna colonne[];
} Matrix;

当然还有:

int idshmM = shmget(shmKM, sizeof(Matrix) + sizeof(Colonna) * n, IPC_CREAT | 0664);

它没有给出任何错误,但是当我打印矩阵时,我只得到每列的前两行。

打印函数的代码如下:

void print_matrix(Matrix *M) {
    int i, k;
    for (k = 0; k < COLUN_CAP; k++) {
        for (i = 0; i < M->nc; i++)
            printf("%d  ", M->colonne[k].data[i]); 
        printf("\n");      
    }
}

所以我得到了矩阵的视觉表示。 COLUN_CAP为每列元素个数,设置为5.


哦打印功能错了(倒置i和k)我觉得很愚蠢。感谢大家的帮助!

在您的示例代码中,为什么要为 10 个 Colonna 结构分配空间? Matrix 最多可容纳 10 个 Colonna,处理超过 10 将需要一个灵活的阵列。使用灵活的数组,您可以为适当数量的 Colonna 结构分配空间,并以可移植的方式对它们进行寻址。使用这个:

typedef struct {
    int data[COLUN_CAP];
} Colonna;

typedef struct {
    int nc;
    key_t colK;
    Colonna colonne[];
} Matrix;

int idshmM = shmget(shmKM, sizeof(Matrix) + sizeof(Colonna) * n, IPC_CREAT | 0664);

此外,您应该检查 shmgetshmat 系统调用中的错误。 shmat returns (void *)-1 出现错误。使用 strerror() 输出信息性错误消息。