Delphi-PRAXiS
Seite 2 von 2     12   

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Programmieren allgemein (https://www.delphipraxis.net/40-programmieren-allgemein/)
-   -   Schnelle SwapByte Routine - Bits swappen (https://www.delphipraxis.net/188343-schnelle-swapbyte-routine-bits-swappen.html)

Neutral General 23. Feb 2016 13:49

AW: Schnelle SwapByte Routine - Bits swappen
 
Das Array ist wahrscheinlich noch schneller als das case, aber sonst ist alles was berechnet werden muss natürlich langsamer.

bytecook 23. Feb 2016 14:12

AW: Schnelle SwapByte Routine - Bits swappen
 
Zitat:

Zitat von Neutral General (Beitrag 1331110)
Das Array ist wahrscheinlich noch schneller als das case, aber sonst ist alles was berechnet werden muss natürlich langsamer.


Kann durchwegs sein, mal sehen wie sich das auf die Laufzeit / generierten Code auswirkt. Habe dieses Uralt-Beispiel heute mal meinem jungen Mitarbeiter (IT Azubi und zudem Sohn) gezeigt,
als Antwort auf die Frage, wozu Case eigentlich gut sei ....

himitsu 23. Feb 2016 14:37

AW: Schnelle SwapByte Routine - Bits swappen
 
Beim Case wird jeder einzelne Wert verglichen, bis etwas getroffen wird.
Beim Array wird der Eingabewert direkt als Index/Offset verwendet.

Neutral General 23. Feb 2016 15:03

AW: Schnelle SwapByte Routine - Bits swappen
 
Zitat:

Zitat von himitsu (Beitrag 1331118)
Beim Case wird jeder einzelne Wert verglichen, bis etwas getroffen wird.
Beim Array wird der Eingabewert direkt als Index/Offset verwendet.

Das stimmt so auch nicht. Der Compiler legt oft Sprungtabellen an wodurch das case-of selbst eine Art Array auf Assemblerebene wird. (Und gerade bei diesem case-of bietet es sich mehr als an)
Da gibts dann auch keinen so großen Unterschied zu einem direkten Zugriff auf ein Array. Wobei der direkte Zugriff sicherlich immernoch ein Stückchen schneller (und in meinen Augen) schöner zu lesen ist als das gigantische case-of.

Notwendig ist ein case-of nicht, aber für Aufzählungswerte oder oft auch für Zahlenwerte ist es manchmal eine etwas übersichtlichere Alternative zu einer endlosen if-then-else Verkettung.

Mikkey 26. Feb 2016 21:16

AW: Schnelle SwapByte Routine - Bits swappen
 
Hätte noch etwas vermutlich ganz schnelles:

Code:
MOVZX AX, BYTE PTR[a]
RCR AL,1
RCL AH,1
RCR AL,1
RCL AH,1
RCR AL,1
RCL AH,1
RCR AL,1
RCL AH,1
RCR AL,1
RCL AH,1
RCR AL,1
RCL AH,1
RCR AL,1
RCL AH,1
RCR AL,1
RCL AH,1
MOV BYTE PTR[a],AH


Alle Zeitangaben in WEZ +1. Es ist jetzt 12:53 Uhr.
Seite 2 von 2     12   

Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz