Zum Inhalt springen

Bitrotation


Gast Tobias Unger

Empfohlene Beiträge

Gast Tobias Unger
Geschrieben

Hallo!

Wie kann ich in C++ ne´ Bitoperation machen?!

Eine Linkssrotation!

also im Byte 1011 1000 soll das letzte Bit nach Links wegrücken! Das letzte soll dann wieder rechts reingeschoben werden.

Danke!!!

MfG

NetzKing

Geschrieben

Natürlich macht man sowas mit dem Inline-Assembler:

char zahl=0x81; diese Zahl wird mit nur einem Befehl rotiert

__asm

{

rol zahl,1

}

andersrum wäre: ror zahl,1

Bitrotationen wurden leider gar nicht in C Prozessorkonform berücksichtigt, obwohl jeder Prozessor beschleunigte Standardbefehle für Bitshift&rotate mit und ohne arithmetische Berücksichtigung hat, weshalb es da nur eingeschränkte und alles andere als optimierte Möglichkeiten gibt:

z.B. halt so:

zahl=zahl<<1|(bool)(zahl&0x80);

da kommt aber ein riesen Assembler-Code bei raus:

movsx ecx,byte ptr [ebp-8]

shl ecx,1

movsx edx,byte ptr [ebp-8]

and edx,80h

neg edx

sbb edx,edx

neg edx

and edx,0FFh

or ecx,edx

mov byte ptr [ebp-8],cl

... was doch ein klein wenig länger braucht.

Erstelle ein Benutzerkonto oder melde Dich an, um zu kommentieren

Du musst ein Benutzerkonto haben, um einen Kommentar verfassen zu können

Benutzerkonto erstellen

Neues Benutzerkonto für unsere Community erstellen. Es ist einfach!

Neues Benutzerkonto erstellen

Anmelden

Du hast bereits ein Benutzerkonto? Melde Dich hier an.

Jetzt anmelden

Fachinformatiker.de, 2024 by SE Internet Services

fidelogo_small.png

Schicke uns eine Nachricht!

Fachinformatiker.de ist die größte IT-Community
rund um Ausbildung, Job, Weiterbildung für IT-Fachkräfte.

Fachinformatiker.de App

Download on the App Store
Get it on Google Play

Kontakt

Hier werben?
Oder sende eine E-Mail an

Social media u. feeds

Jobboard für Fachinformatiker und IT-Fachkräfte

×
×
  • Neu erstellen...