when I use char array subscript as in this example:
int main(){
char pos=0;
int array[100]={};
for(pos=0;pos<100;pos++)
printf("%i\n", array[pos]);
return 0;
}
I am getting warning that I am using char array subscript:
warning: array subscript has type ‘char’ [-Wchar-subscripts]
Which is OK, because I have this warning enabled.
GCC manual says:
-Wchar-subscripts Warn if an array subscript has type "char". This is a common cause of error, as programmers often forget that this type is signed on some machines. This warning is enabled by -Wall.
So this warning should prevent of using negative array index. My question is, why is this warning active only on char and not also on other signed types?
Thank you.
Plainly put, it's complaining about your index being of type
character
.Simply convert
pos
to anint
and the warning will disappear.As for why this warning appears, you've stated it yourself. A
char
datatype can only address values from 0 - 255 (if unsigned) or even just 127 (if signed). For a normal array, that's a rather meager number and you could quickly forget about thesigned
bit and accidentally access array location -128 (by actually accessing array element 128).As long as your array is smaller than 127, you'll be fine and you can ignore the warning, but let's be honest...these three extra bytes in your memory footprint won't make your application inefficient, will it?
This is because
int
is always signed.char
doesn't have to.char
can be signed or unsigned, depending on implementation. (there are three distinct types -char
,signed char
,unsigned char
)But what's the problem? I can just use values from 0 to 127. Can this hurt me silently?
Oh, yes it can.
Because native
char
can be either unsigned or signed.Note that it's perfect legal to use negative subscript. For instance:
Now I can use
ptr[-1]
which is equivalent toarr[4]
. Ifchar
happens to be unsigned in the implementation, it can never be a negative value.