質問

配分してからポインターへの配列にアクセスしようとするとき:

void tester(char ***p)
{
    int i;
    char **pp;

    pp = *p;
    pp = calloc(10, sizeof(*pp));

    for (i = 0; i < 10; i++)
        printf("%d = %p\n", i, pp[i]);

            *p = pp;
}

void tester_broken(char ***p)
{
    int i;

    *p = calloc(10, sizeof(**p));

    for (i = 0; i < 10; i++)
        printf("%d = %p\n", i, *p[i]);
}

int main(void)
{ 
    char **a;

    tester(&a);
    tester_broken(&a);

    return 0;
}

これらの作品のいずれかと他のセグメント断層の1つを説明できますか?

役に立ちましたか?

解決

それは優先順位の問題です。試す:

void tester_fixed(char ***p)
{
    int i;

    *p = calloc(10, sizeof(**p));

    for (i = 0; i < 10; i++)
        printf("%d = %p\n", i, (*p)[i]);
}

ブラケットオペレーター(配列サブスクリップ)は、アスタリスク演算子(抑制)よりも密接に結合します。括弧はあなたの意図を描写します。

ライセンス: CC-BY-SA帰属
所属していません StackOverflow
scroll top