Einzelnen Beitrag anzeigen

Benutzerbild von MaBuSE
MaBuSE

Registriert seit: 23. Sep 2002
Ort: Frankfurt am Main (in der Nähe)
1.837 Beiträge
 
Delphi 10 Seattle Enterprise
 
#3

Re: zweitkleinste Informaionseinheit

  Alt 7. Feb 2005, 08:56
Delphi-Quellcode:
uses Math;
...
// n=0 für das rechte Bit, n=7 für das linke Bit
function getBit(Zahl, Bit: Integer):Boolean;
begin
  Result := Zahl and Round(IntPower(2, Bit)) = Round(IntPower(2, Bit));
end;
Diese Funktion ist nicht so performant wie die von Mütze(wegen den Round und IntPower), aber das Prinzip das dahintersteht ist einfach:
Delphi-Quellcode:
Result := Zahl and 1 = 1; // True, wenn 1. Bit gesetzt ist
Result := Zahl and 2 = 2; // True, wenn 2. Bit gesetzt ist
Result := Zahl and 4 = 4; // True, wenn 3. Bit gesetzt ist
Result := Zahl and 8 = 8; // True, wenn 4. Bit gesetzt ist
Result := Zahl and 16 = 16; // True, wenn 5. Bit gesetzt ist
Result := Zahl and 32 = 32; // True, wenn 6. Bit gesetzt ist
Result := Zahl and 64 = 64; // True, wenn 7. Bit gesetzt ist
Result := Zahl and 128 = 128; // True, wenn 8. Bit gesetzt ist
Das kann man auch kombinieren
Result := Zahl and 5 = 5; // True, wenn 1. Bit und das 3. gesetzt ist (5 = 1 + 4) Somit ist es leicht möglich mit nur einem If auf mehrere Bits abzufragen.

Mütze macht eigentlich fast das gleiche, er verschiebt nur vorher die Bits, so das das gesuchte Bit an der 1. Stelle steht, dann braucht er nur noch "and 1 = 1" zu prüfen.
(°¿°) MaBuSE - proud to be a DP member
(°¿°) MaBuSE - proud to be a "Rüsselmops" ;-)
  Mit Zitat antworten Zitat