すべてを包む const char*
次のスニペットに示すように、を括弧で囲むと問題が解決します。
static const char* const stateNames[5] =
{
("Init state"),
("Run state"),
("Pause state") //comma missing
("Pause state3"),
("Error state")
};
コンマを忘れると、次のようなコンパイルエラーが発生します。 error: called object is not a function or function pointer
ライブデモ
コンマを忘れた場合、実際に起こることは、Cが次のコンマまたは配列の終わりまで実際に2つ(またはそれ以上)の文字列を連結するということです。たとえば、次のようにコンマを忘れたとします。
static const char* const stateNames[] =
{
"Init state",
"Run state",
"Pause state" //comma missing
"Pause state3" //comma missing
"Error state"
};
int main(void)
{
printf("%s\n", stateNames[0]);
return 0;
}
これがgcc-9.2
生成するものです(他のコンパイラは同様のコードを生成します):
.LC0:
.string "Init state"
.string "Run state"
.string "Pause statePause state3Error state" ; oooops look what happened
.quad .LC0
.quad .LC1
.quad .LC2
main:
push rbp
mov rbp, rsp
mov eax, OFFSET FLAT:.LC0
mov rdi, rax
call puts
mov eax, 0
pop rbp
ret
最後の3つの文字列が連結され、配列が期待した長さではないことは明らかです。