在函数中操作int的数组时堆栈粉碎错误

问题描述 投票:0回答:1

因此,我正在尝试创建一个简单的程序,该程序采用部分已满的数组,并在开头添加一个整数,将所有现有元素向右移动。看起来我在这里添加并正确地移动了一些东西,但是一旦所有代码执行完毕,我就会得到一个堆栈粉碎检测到的错误。

这是我的代码:

#include <stdio.h>

void addCommand(int *, int, int);

void main() {
    int i;
    int list[10];
    list[0] = 1;
    list[1] = 5;

    printf("Before add:\n");
    for (i = 0; i < 2; i++) {
        printf("%d\n", list[i]);
    }

    addCommand(list, sizeof(list), 4);

    printf("Adding 4:\n");
    for (i = 0; i < 3; i++) {
        printf("%d\n", list[i]);
    }
}


void addCommand(int *arr, int size, int new) {
    int k;
    printf("%d", arr[0]);   
    for (k = size - 1; k >= 0; k--) {
         if (&arr[k] != NULL) {     
            if (k > 0) {        
                arr[k] = arr[k-1];
            } else {
                arr[k] = new;
            }
        }   
    }   
}

这是输出:

enter image description here

如果有人能指出我在这里做错了什么,我将不胜感激!

c arrays function pointers stack
1个回答
3
投票
addCommand(list, sizeof(list), 4);

上面的行不传递列表数组中的元素数。你必须做这样的事情:

sizeof(arr)/sizeof(arr[0])
© www.soinside.com 2019 - 2024. All rights reserved.