在C中通过引用传递2d数组

Mic*_*ner 1 c arrays

我一直在寻找和阅读一段时间,我不明白为什么这不起作用.

我正在使用传递一个2d数组&来传递内存中第一个位置的地址.该函数接受char *tokens指向该内存位置的指针.

功能:

void printOutput( FILE* template, char* tokens)
{
    char c = fgetc(template);

    while(c != EOF )
    {
        if( c != '$' )
        {
            printf("%c", c);
        }
        else
        {
            c = fgetc(template);
            int charVal = c-'0';

            if( charVal >= 0 && charVal <= 9 )
            {
                printf("%d" , charVal);
                printf("%s" , tokens[charVal]);
            }
        }
        c = fgetc(template);
    }
   printf("\n\n");
}
Run Code Online (Sandbox Code Playgroud)

该函数调用如下:

printOutput(template, &tokens[0]);
Run Code Online (Sandbox Code Playgroud)

如果我将功能代码放入main函数代替printOutput函数调用,则输出正确显示.

从我所知道的是,在函数调用和运行某事的函数之间的某个地方正在发生,这使我tokens[][]成为一个所有的数组(null).

我相信我的说法不正确,希望有人可以提供帮助.如果需要,我还可以提供更多代码.

我非常感谢任何帮助!

由于答案有帮助,但仍未解决问题,我正在尝试添加main()我的代码中的函数.

int main( int argc, char *argv[] )
{
FILE *template = NULL;
FILE *data = NULL;

char input[INPUT_LENGTH];

template = fopen( "template.txt", "r" );
if ( template != NULL )
{
    data = fopen( "data.txt", "r" );
    if ( data != NULL )
    {

        char input[INPUT_LENGTH];

        while ( fgets(input, INPUT_LENGTH, data) )
        {
            char *token = NULL;
            char *tokens[INPUT_LENGTH][FIELD_LENGTH];

            int pos = 0;
            token = strtok(input, "|");
            while(token != NULL )
            {
                tokens[pos][0] = token;
                token = strtok(NULL, "|");
                pos++;
            }

            printOutput(template, tokens[INPUT_LENGTH][FIELD_LENGTH]);

            rewind(template);
        }

        fclose( data );
    }

    fclose( template );
}

return EXIT_SUCCESS;
Run Code Online (Sandbox Code Playgroud)

}

我现在只能假设这个问题与char *tokens[INPUT_LENGTH][FIELD_LENGTH];宣言有关,但我现在完全不确定.

pad*_*ddy 5

您的2D数组char tokens[X][LEN]在内存中布局为:

Value     : Mem addresses for char[LEN]

tokens[0] :         0 . . . LEN-1
tokens[1] :       LEN . . . 2*LEN-1
tokens[X-1] : (X-1)*LEN . . . X*LEN - 1
Run Code Online (Sandbox Code Playgroud)

相反,char* tokens被解释为:

Value     : Mem addresses for char

tokens[0] : 0
tokens[1] : 1
tokens[2] : 2
Run Code Online (Sandbox Code Playgroud)

现在,当您printf使用字符串格式传递它们时,您将取消引用该值char,而不是char*它期望的值.因此输出/未定义的行为不好.

即使您使用了地址(printf("%s" , &tokens[charVal]);),它仍然不会给您预期的结果,因为它正在解析为错误的地址.

由于您的2D数组具有固定大小,您应该声明如下函数:

void printOutput( FILE* template, char tokens[X][LEN] )
Run Code Online (Sandbox Code Playgroud)

XLEN是两个阵列的尺寸,很显然......如果还不清楚我大量使用他们的后上方=)

这样,编译器就知道如何解释tokens[charVal],这将是一个衰变为a的数组类型char*.


[编辑,因为您提供了更多信息和代码]

您仍然会在阵列之间char*char阵列之间感到困惑.我已经纠正了这一点,tokens应该是一维的一维数组char*.

        char *tokens[INPUT_LENGTH] = { 0 };

        int pos = 0;
        token = strtok(input, "|");
        while(token != NULL )
        {
            tokens[pos] = token;
            token = strtok(NULL, "|");
            pos++;
        }

        printOutput(template, tokens);
Run Code Online (Sandbox Code Playgroud)

另外,printOutput应定义为:

void printOutput( FILE* template, char** tokens)
Run Code Online (Sandbox Code Playgroud)