Portál AbcLinuxu, 2. května 2025 15:41
int x(char *c) {}
a int x(char c[]) {}
?
gcc -S soubor.c
. Tam by mělo být vidět, že je to stejné.
$ diff -u test1.s test2.s --- test1.s 2010-10-23 20:01:04.090000164 +0200 +++ test2.s 2010-10-23 20:01:08.480000156 +0200 @@ -1,4 +1,4 @@ - .file "test1.c" + .file "test2.c" .text .globl main .type main, @function @@ -10,9 +10,7 @@ movq %rsp, %rbp .cfi_offset 6, -16 .cfi_def_cfa_register 6 - leaq -16(%rbp), %rax - addq $4, %rax - movl $1, (%rax) + movl $1, -12(%rbp) movl $0, %eax leave .cfi_def_cfa 7, 8test1 používá
*(pole+1)=1
a test2 používá pole[1]=1
.
Ovšem jakmile povolím optimalizaci, alespoň -O1, tak to stejné je.
i[pole]=1
.
pole[i]
je ítý prvek pole, ne? Tak by měla znít definice. Že je to interně v implementaci převedeno na *(pole+i) by mělo být každému putna respektive do toho by nikomu nemělo být nic. A nezávisle na tom na co se to interně převede by němělo jít napsat i[pole]
protože to je prostě sémantický nesmysl...
hranaté závorky jsou jen a pouze syntaktická zkratkaS tím souhlasím, i když je to zkratka jen pro indexování, nikoliv definice což je matoucí věc č.1 (
int[2][3]
a int**
není totéž; nelze napsat int 3[foo]
místo int foo[3]
)
A matoucí věc č.2 je že syntaktická zkratka foo[3]
nemusí a nemá mít za následek syntaktickou zkratku 3[foo]
.
Pan Occam by vědělCimrman taky... "spočítali jste padlé". V podstatě by se dalo říct, že škoda na uživatelích toho jazyka je neomezeně velká, protože tuhle pitomost se musí každý učit. Na druhou stranu je jen malé množství překladačů, kde by bylo třeba řešit aby to nebyla pitomost.
Naprostá většina uživatelů Céčka o tom nikdy nepřemýšlela a hranaté závorky nepoužila jiným než intuitivním způsobem.Což je docela dobrý důvod proč by tam ta další "feature" *neměla* být.
Kde jste vzal nějakou škodu?Já nikde... to byl Váš dotaz. Abychom nemluvili o dvou různých věcech - pro mne je zrovna *tahle* feature dost nezajímavá, respektive chápu důvody jejího vzniku. Spíš mě to štve jako instance neustále opakujícího se principu který jsem naznačil v 1. příspěvku.
Což je docela dobrý důvod proč by tam ta další "feature" *neměla* být.Ona to ale není další featura, nýbrž prostý důsledek definice.
Ty důsledky jsou triviální, pouze pohled, který jste si na ně zvolil Vy, je zbytečně složitý.Já si nemyslím, že by to bylo o složitosti, ale souhlasím, že máme dva různé úhly pohledu.
Mimochodem, definice libovolného turingovsky úplného programovacího jazyka má nepředstavitelně složité důsledky, počínaje třeba prostou existencí nevyčíslitelných problémů. Proti tomu jsou nějaké syntaktické a sémantické detaily naprosto irelevantní.Nemyslím si, že by míra složitosti měla být záminkou pro "držet hubu a krok"
Tiskni
Sdílej:
ISSN 1214-1267, (c) 1999-2007 Stickfish s.r.o.