1

嗨,伙计们,我很抱歉打扰你,但我开始在这里松懈了..我最近又开始用 C 编程了,我遇到了一些我无法弄清楚的错误..我的 C程序(应该)是一个简单的程序,因此它需要执行以下操作:从键盘读取未定义数量的自然元素,直到读取到 0。之后,它必须计算所有元素的乘积并计算该结果末尾的 0-s 的数量。

int input(int* v)                      {

    int n = 0;   
    do                                                            
    {
        n = n + 1;
        v = (int*) realloc(v,n*sizeof(int));        printf("Enter number %d: ",n);          scanf("%d",&v[n-1]);
    }
    while(v[n-1] != 0);           
    n--;
    return n;  }

int tZeros(int* v, int eNb)     {    
    int i;
    int  val = 1;
    for(i = 0; i < eNb; i++)
    {
        val = val * v[i];        
    }

    i=0;
    while(val % 10 == 0)
    {
        i++;
    }  
    return i; }

int main (int argc, char** argv)     {

    int* v = NULL;                                                  
    int eNb = input(&(*v));                                          
    if(eNb>0)                                                       
    {
        int zeros = tZeros(v, eNb);
        printf("The number of ending zeros in the product of the given numbers is: %d",zeros);

    }
    else
    {
        printf("No elements to do computations with!\n");
    }
    free(v);
    return 0; 
    }

输入函数应该返回两件事:元素的数量和动态数组中的实际元素。但是在输入函数运行后,输入的值都丢失了。我将参数作为指针传递给输入,所以它应该改变正确地址的值对吗?

欢迎所有建议!谢谢!

Ps 我认为问题出在我的数组 v.. 退出输入函数后,它会丢失所有值..

4

1 回答 1

11

C 中的所有内容都是按值传递的,因此当您执行赋值时:

v = (int*) realloc(v,n*sizeof(int));

您正在为变量的本地副本分配一个新值v。如果要更改指针本身的值(而不是修改指针已经指向的值),则需要将指针传递给指针并取消引用一次以执行分配,即

int ModifyPointer( int **v )
{
    // error checking and whatnot
    *v = realloc(*v,n*sizeof(int));
}

这样想;你有一个指针p,它位于内存地址 0xA 并指向内存地址 0xFF。您传递p给一个函数并创建一个副本v。副本v驻留在内存地址 0x2A,但仍指向内存地址 0xFF。

                     p(0xA)      v(0x2A)
                       |            |
                        \          /
                         \        /
                          \      /
                            0xFF

因此,当您取消引用任一指针时,您最终会引用同一块内存,但指针本身位于 memory 的不同位置。因此,当您修改副本的值时,它不会反映在原始值中(即 realloc 在新的内存位置创建一个新指针并将其分配给变量v,但p保持不变。)

于 2011-03-09T00:54:21.773 回答