Zeiger-Arithmetik in C ++ verwendet Sizeof (Typ) Inkrementierung anstelle von Byte-Inkrementierung?
Ich bin verwirrt über das Verhalten der Zeigerarithmetik in C ++. Ich habe ein Array und möchte von dem aktuellen N Elemente vorwärts gehen. Da in C ++ der Zeiger die Speicheradresse in BYTES ist, erschien mir der Code als logischnewaddr = curaddr + N * sizeof(mytype)
. Es hat jedoch Fehler verursacht; später fand ich das mitnewaddr = curaddr + N
alles funktioniert einwandfrei. Warum so? Sollte es wirklich Adresse + N anstelle von Adresse + N * sizeof sein?
Ein Teil meines Codes, in dem ich ihn bemerkt habe (2D-Array mit dem gesamten Speicher, der als ein Block zugewiesen wurde):
// creating pointers to the beginning of each line
if((Content = (int **)malloc(_Height * sizeof(int *))) != NULL)
{
// allocating a single memory chunk for the whole array
if((Content[0] = (int *)malloc(_Width * _Height * sizeof(int))) != NULL)
{
// setting up line pointers' values
int * LineAddress = Content[0];
int Step = _Width * sizeof(int); // <-- this gives errors, just "_Width" is ok
for(int i=0; i<_Height; ++i)
{
Content[i] = LineAddress; // faster than
LineAddress += Step; // Content[i] = Content[0] + i * Step;
}
// everything went ok, setting Width and Height values now
Width = _Width;
Height = _Height;
// success
return 1;
}
else
{
// insufficient memory available
// need to delete line pointers
free(Content);
return 0;
}
}
else
{
// insufficient memory available
return 0;
}