I wrote the following code:
void buildArrays(char *pLastLetter[],int length[], int size, const char str[]) {
int i;
int strIndex = 0;
int letterCounter = 0;
for (i=0; i<size; i++) {
while ( (str[strIndex] != SEPERATOR) || (str[strIndex] !开发者_JS百科= '\0') ) {
letterCounter++;
strIndex++;
}
pLastLetter[i] = &str[strIndex-1];
length[i] = letterCounter;
letterCounter = 0;
strIndex++;
}
}
and I'm getting the above warning on pLastLetter[i] = &str[strIndex-1];
pLastLetter is a pointers array that points to a char in str[].
Anyone knows why I'm getting it and how to fix it?
Well, as you said yourself, pLastLetter
is an array of char *
pointers, while str
is an array of const char
. The &str[strIndex-1]
expression has type const char*
. You are not allowed to assign a const char*
value to a char *
pointer. That would violate the rules of const-correctness. In fact, what you are doing is an error in C. C compilers traditionally report it as a mere "warning" to avoid breaking some old legacy code.
As for "how to fix it"... It depends on what you are trying to do. Either make pLastLetter
an array of const char*
or remove the const
from str
.
str is const, pLastLetter isn't. It's saying the const qualifier is discarded if you do this.
精彩评论