только что проверил следующее в gdb:
char *a[] = {"one","two","three","four"};
char *b[] = {"one","two","three","four"};
char *c[] = {"two","three","four","five"};
char *d[] = {"one","three","four","six"};
и я получаю следующее:
(gdb) p a
$17 = {0x80961a4 "one", 0x80961a8 "two", 0x80961ac "three", 0x80961b2 "four"}
(gdb) p b
$18 = {0x80961a4 "one", 0x80961a8 "two", 0x80961ac "three", 0x80961b2 "four"}
(gdb) p c
$19 = {0x80961a8 "two", 0x80961ac "three", 0x80961b2 "four", 0x80961b7 "five"}
(gdb) p d
$20 = {0x80961a4 "one", 0x80961ac "three", 0x80961b2 "four", 0x80961bc "six"}
Я действительно удивлен тем, что указатели строк одинаковы для эквивалентных слов. Я бы подумал, что каждая строка будет выделена собственная память в стеке, независимо от того, была ли она такой же, как строка в другом массиве.
Является ли это примером какой-либо оптимизации компилятора или это стандартное поведение для объявления строки такого типа?