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;
}

Antworten auf die Frage(3)

Ihre Antwort auf die Frage