Du bist nicht angemeldet.

Stilllegung des Forums
Das Forum wurde am 05.06.2023 nach über 20 Jahren stillgelegt (weitere Informationen und ein kleiner Rückblick).
Registrierungen, Anmeldungen und Postings sind nicht mehr möglich. Öffentliche Inhalte sind weiterhin zugänglich.
Das Team von spieleprogrammierer.de bedankt sich bei der Community für die vielen schönen Jahre.
Wenn du eine deutschsprachige Spieleentwickler-Community suchst, schau doch mal im Discord und auf ZFX vorbei!

Werbeanzeige

Firefly

Alter Hase

Beiträge: 484

Wohnort: Irgendwoundnirgendwo

  • Private Nachricht senden

11

20.01.2009, 10:03

gut zu wissen^^ allerdings ist der "normale" [] operator mit size_t oder?

David_pb

Community-Fossil

Beiträge: 3 886

Beruf: 3D Graphics Programmer

  • Private Nachricht senden

12

20.01.2009, 10:05

Zitat von »"Firefly"«

gut zu wissen^^ allerdings ist der "normale" [] operator mit size_t oder?


Was ist schon normal. Außerdem gibt es nur einen [] Operator, was zwischen den Klammern steht ist total beliebig (wenn auch vllt manchmal syntaktisch falsch). ;)

David Scherfgen

Administrator

Beiträge: 10 382

Wohnort: Hildesheim

Beruf: Wissenschaftlicher Mitarbeiter

  • Private Nachricht senden

13

20.01.2009, 11:13

Der "normale" Operator [] bei z.B. a ist nur eine andere Schreibweise für *(a + b). Der funktioniert also mit allem, was auch mit *(a + b) funktioniert.
Darum ist a[b] auch dasselbe wie b[a], solange man den Operator nicht überladen hat.

14

20.01.2009, 15:13

Nja daraus lässt sich dann aber die Frage stellen was mit folgendem ist:

C-/C++-Quelltext

1
2
3
4
5
6
int* ptr_array(new int[10]);
int* ptr_it = &ptr_array[2];

// nach *(a+b) == a[b]

assert(ptr_array[-1] == *(ptr_array - 1));
delete [] ptr_array;

Sollte demnach definiert sein, auch wenn eigtl. erst ein Index ab 0 beim nicht überladenen operator[] in allen Lehrbüchern angegeben wird ;)
Devil Entertainment :: Your education is our inspiration
Der Spieleprogrammierer :: Community Magazin
Merlin - A Legend awakes :: You are a dedicated C++ (DirectX) programmer and you have ability to work in a team? Contact us!
Siedler II.5 RttR :: The old settlers-style is comming back!

Also known as (D)Evil

dot

Supermoderator

Beiträge: 9 757

Wohnort: Graz

  • Private Nachricht senden

15

20.01.2009, 15:18

Zitat von »"Deviloper"«

Sollte demnach definiert sein, auch wenn eigtl. erst ein Index ab 0 beim nicht überladenen operator[] in allen Lehrbüchern angegeben wird ;)


ne, iirc is das undefiniert weil das dereferenzieren von einem element vor dem array net definiert is (genaugenommen is afaik sogar schon das bloße ausrechnen von einem zeiger drauf undefiniert)...

David_pb

Community-Fossil

Beiträge: 3 886

Beruf: 3D Graphics Programmer

  • Private Nachricht senden

16

20.01.2009, 15:33

Das geht ja auch:

C-/C++-Quelltext

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
template< typename T >
T* Allocate( int size )
{
    int* tmp = ( int* )malloc( sizeof T * size + sizeof (int) );
    *tmp = size;
    return tmp+1;
}

int main()
{
    int* p = Allocate<int>( 10 );
    for ( int i = 0; i < 10; ++i )
        p[i] = i;

    printf( "Size: %d\n", p[-1] );
    for ( int i = 0; i < 10; ++i )
        printf( "%d\n", p[i] );

}

drakon

Supermoderator

Beiträge: 6 513

Wohnort: Schweiz

Beruf: Entrepreneur

  • Private Nachricht senden

17

20.01.2009, 15:37

Zitat von »"dot"«

Zitat von »"Deviloper"«

Sollte demnach definiert sein, auch wenn eigtl. erst ein Index ab 0 beim nicht überladenen operator[] in allen Lehrbüchern angegeben wird


ne, iirc is das undefiniert weil das dereferenzieren von einem element vor dem array net definiert is (genaugenommen is afaik sogar schon das bloße ausrechnen von einem zeiger drauf undefiniert)...



Er hat aber kein Array, sondern ein Zeiger auf int. Und auf den wendet er den Dekrement Operator an (respektive -1, was aber das gleiche, wie Dekrement bedeutet (natürlich ohne Überladung der Operatoren +/--)) und das ist so erlaubt. (5.2.6/2).

Und der Zugriff mit einem negativen Wert ist ebenfalls erlaubt.

Zitat von »"ISO/IEC 14882 5.2.1"«


A postfix expression followed by an expression in square brackets is a postfix expression. One of the
expressions shall have the type “pointer to T” and the other shall have enumeration or integral type. The
result is an lvalue of type “T.” The type “T” shall be a completely-defined object type.56) The expression
E1[E2] is identical (by definition) to *((E1)+(E2)).



EDIT by dot: Sry drakon, hab versehentlich deinen Beitrag editiert. Ich hoff ich hab alles wieder richtig hergestellt (warum muss der edit knopf auch direkt neben dem zitieren button sein *grml*...)

dot

Supermoderator

Beiträge: 9 757

Wohnort: Graz

  • Private Nachricht senden

18

20.01.2009, 15:47

natürlich kompilliert das. es geht ja nicht um den negativen wert in den klammern, klar is der erlaubt, ist ja nur pointerarithmetik.
nichts desto trotz berechnet er da einen zeiger auf ein element _vor_ dem allokierten speicherbereich und dereferenziert diesen. und sowas is einfach undefiniert.

hab grad keine zeit, von mir aus such ich nacher noch die entsprechende stelle im standard (iirc ist lediglich das berechnen der adresse des ersten elementes _nach_ dem array definiert um die geschichte mit den iteratoren sauber über die bühne zu bringen).

drakon

Supermoderator

Beiträge: 6 513

Wohnort: Schweiz

Beruf: Entrepreneur

  • Private Nachricht senden

19

20.01.2009, 15:57

Hmm. Ich denke mal, dass er da nicht mit ptr_array, sondern ptr_it rechnen wollte. (Sonst hätte die Variable auch gar keinen Sinn in seinem Beispiel. ;))

Werbeanzeige