首页 > 解决方案 > C 程序中的意外结果,使用 Malloc 和 for 循环

问题描述

我的 C 代码有问题:

#include<stdlib.h>
#include<stdio.h>


int main()
{
    int i1,j1,k1;
    int n_block;
    struct  block
    {
        int i,j,k;
    } *blocks;
    n_block=3;
    i1=4;
    k1=3;
    j1=2;
    blocks=malloc(n_block*sizeof(blocks));
    for(int count=0;count<=n_block-1;count++){
        printf("count %d\n",count);
        blocks[count].i=i1;
        blocks[count].j=j1;
        blocks[count].k=k1;
        printf("results:%d\n",blocks[count].i);
        printf("results:%d\n",blocks[count].j);
        printf("results:%d\n",blocks[count].k);
    }
}

预期的输出是:

count 0
results:4
results:2
results:3
count 1
results:4
results:2
results:3
count 2
results:4
results:2
results:3

但我得到:

count 0
results:4
results:2
results:3
count 1
results:4
results:2
results:3
count 2
results:4
results:2
results:1970496882

我想最后一个结果是指针的值,但为什么会发生呢?

我试图修改for循环(不修改n_block):

for(int count=0;count<=n_block+1;count++)

我得到:

count 0
results:4
results:2
results:3
count 1
results:4
results:2
results:3
count 2
results:4
results:2
results:1970496882
count 3
results:4
results:2612
results:10
count 4
results:4
results:2
results:3

所以,问题是,为什么会这样?

谢谢

标签: cfor-loopstructprintfmalloc

解决方案


如果malloc该语句sizeof(blocks)将评估为指针的大小,则在您的情况下sizeof(blocks) != sizeof(struct block)

更改malloc

 blocks = malloc(n_block * (sizeof( struct block) ) ); // more readable

for loop这里过于复杂,坚持基础

for(int count=0; count < n_block; count++ )

推荐阅读