Frage zu Bit Operatoren in der Programmierung

DennisXX

Bekanntes Mitglied
Hi Folks !

Ich habe mich schon des öfteren gefragt, wofür man in der Programmierung (egal um welche konkrete Programmiersprache es geht), sogenannte Bit Operatoren benötigt und was man damit machen kann!? Mir sind diese Dinge in fast jeder Programmiersprachenereferenz übder den Weg gelaufen, aber so richtig habe ich davon noch nie den Sinn verstanden.

Ist das eher ein nettes Zusatzfeature in der Programmierung, oder kann und muss man diese Sache ernsthaft gebrauchen?

Greetz
Dennis
 

Fu3L

Top Contributor
Wenn sie dir in jeder Sprache über den Weg laufen, werden die wohl ihre Berechtigung haben.

Mit denen kannst du bestimmte Operationen eben sehr schnell ausführen, weil diese bit-operatoren sehr "maschinennah sind"

Natürlich wäre es bei heutigen Prozessoren Quatsch für jedes x*2 zu schreiben x << 1, weil das zu verstehen zu umständlich ist, wenn jemand deinen Code liest. Aber sowas wie folgender Code kann bei millionenfachem Aufruf schon einen Effekt haben:

Java:
//Entweder so:
if(x%2==0) {

//oder so, selbst mit Methodenaufruf viel schneller (vllt inline?)
if(isEven(x)) {

//Mit dieser Methode:
public boolean isEven(long x) {
  return (x >> 1) << 1 == x;
}

Edit: Habs nochmal getestet: Folgendes, ohne aufwändige Modulo-Operation, ist auch nur ganz minimal schneller, nichts im Vergleich zu den Bit-Operatoren.
Java:
public boolean isEven(long x) {
  return (x/2)*2 == x;
}
 
Zuletzt bearbeitet:

DennisXX

Bekanntes Mitglied
Hi Folks !

Also wenn ich ehrlich bin Fu3L habe ich ein Codebeispiel noch nicht so ganz verstanden. Würdest du dich evtl. dazu bereiterklären, dass etwas ausführlicher zu beschreiben?

Hab vielen Dank !

Greetz
Dennis
 

Fu3L

Top Contributor
Ich habe dort zwei Möglichkeiten dargestellt, um zu testen, ob eine Zahl gerade ist (englisch: even ;)).
Die eine wie man sie oft findet und die fast jeder sofort versteht mit der Modulo Operation. Bei der anderen Möglichkeit habe ich absichtlich noch einen Methodenaufruf eingefügt, weil der das Verständnis fördern soll, da es bei bit-operatoren nicht sofort für jeden ersichtlich ist, was dort passiert.
Was die einzelnen bit-operatoren so anstellen, kannst du in deinem Programmierbuch selber nachlesen oder Googlen ;)
 

Cola_Colin

Top Contributor
Der Geschwindigkeitsaspekt ist imho nur recht selten von Bedeutung.
Wichtig werden diese Operatoren, wenn du irgendwelche Daten auf bit Ebene manipulieren willst.
Man kann über sie gezielt einzelne Bits einer Zahl verändern, oder aber auch solche Umwandlungen machen:

Java:
    private static byte[] intToBytes(int i) {
        byte[] dest = new byte[4];
        dest[3] = (byte) (i >>> 24);
        dest[2] = (byte) (i >>> 16);
        dest[1] = (byte) (i >>> 8);
        dest[0] = (byte) (i);

        return dest;
    }

    private static int bytesToInt(byte[] b) {
        int result = 0;

        result |= (0xFF & b[3]) << 24;
        result |= (0xFF & b[2]) << 16;
        result |= (0xFF & b[1]) << 8;
        result |= (0xFF & b[0]);

        return result;   
    }

Das ist dann hilfreich, wenn man irgendwo einen Integer übertragen will, aber eben nur byte Arrays übertragen werden können.
 

Marco13

Top Contributor
Ja, es gibt viele Bereiche wo man z.B. int in byte zerlegen muss oder bytes zu ints zusammensetzen. Das von Cola_Colin beschriebene muss man auch oft in der Bildverarbeitung machen, wo eine Farbe als RGBA in einem int gespeichert ist, und man den Rot, Grün, Blau und Alpha-Teil als einzlene bytes rauspfriemeln muss.
Was ganz anderes ist, dass es praktisch sein kann, z.B. in einem long die gleiche Information unterbringen zu können, wie in 64 booleans: Man kann Flags (also quasi-boolean-Werte) damit sehr kompakt speichern.
Das Modulo würde ich zwar doch eher mit [c]if ((x&1)==0)[/c] machen. Aber einen Eindruck, was noch alles geht, bekommt man auf dieser Seite: Bit Twiddling Hacks
 

Empire Phoenix

Top Contributor
Stelll dir for du willst schnell wissen ob zwei objecte collidiren können (physic engine, jbullet) du hast eienn int mit seinen x stellen,
nun machst du bei beiden bitmasken durch bit operationen

0101010101001 ein Haus oder whatever
0100000000000 ein geschoss

jetzt ne und operation drauf:
0100000000000
ergebnis != 0
-> collisionsevente sollen ausgeführt werden.

Vorteil :
Im gegensatz zu dutzenden if's oder vergelichbarer logic kann ich mithilfe einer einzigen operation und einem if, statt ein if pro stelle das ganze überprüfen.
 

Landei

Top Contributor
Ein schönes Beispiel ist die Klasse [c]java.util.BitSet[/c], mit der man alle möglichen Dinge - vom Primzahlsieb bis zum Bloom-Filter - implementieren kann. Theoretisch hätte man eine ähnliche Funktionalität mit einer [c]List<Boolean>[/c], aber vieeel langsamer und umständlicher. Der Source-Code von BitSet ist voller Bit-Operationen. Ähnliches gilt auch für die Klassen BigInteger und BigDecimal.
 

Fu3L

Top Contributor
Dann will ich auch nochmal ein Beispiel posten, wo es einfach nur praktisch ist, die bit-Operatoren zu nutzen:
GPU Gems 3: Chapter 1. Generating Complex Procedural Terrains Using the GPU | NVIDIA Developer Zone
In Abschnitt 1.2 soll man für jede Ecke des Quaders eine Stelle der Binärzahl auf 1 oder 0 setzen, je nach Ergebnis. Die resultierende Zahl dient dann weiter um passende Dreiecke aus einem Array auszuwählen. Man kann diese boolean-Werte, die man in den einzelnen Stellen hat, also direkt zusammengefasst nutzen.

In diesem speziellen Fall könnte man auch einfach immer +1, +2, +4, +8 rechnen, aber | (1<<0), |(1<<1), |(1<<2) ginge auch und man weiß dann eben sicher: Da verändere ich genau dieses eine Bit und kann die Position direkt ablesen. (Und es ist sogar ganz minimal schneller, grad paar Durchläufe getestet)

@Marco: Tatsache, die Variante von dir zum Testen auf Gerade oder Ungerade ist auch wieder schneller und danke für den Link ;) (Ist gut für meine Project Euler Programme, da versuch ich immer das Maximum an Geschwindigkeit rauszuholen ;))
 
Zuletzt bearbeitet:
Ähnliche Java Themen
  Titel Forum Antworten Datum
Zrebna Frage zu Test-Driven Development (TDD) Java Basics - Anfänger-Themen 3
I Frage Thymeleaf -> Fehler ignorieren und mit "" ersetzen? Java Basics - Anfänger-Themen 15
I Frage Thymeleaf -> Prefix / Suffix ändern? Java Basics - Anfänger-Themen 11
D Rekursions Probleme / frage Java Basics - Anfänger-Themen 4
T Frage zu Parse Java Basics - Anfänger-Themen 2
H Frage an die Profis Java Basics - Anfänger-Themen 4
J Eine konzeptionelle Frage zu OOP Java Basics - Anfänger-Themen 3
P Frage zu Rekursion und Backtracking Java Basics - Anfänger-Themen 2
H Frage zur Ausgabe Java Basics - Anfänger-Themen 4
H Frage zu arithmetischen Operationen Java Basics - Anfänger-Themen 20
F Kurze Frage zu replace() Java Basics - Anfänger-Themen 19
JavaSchmecktLecker Polymorphie Frage zur Methodenüberschreibung Java Basics - Anfänger-Themen 21
J Frage zu einem "Taschenrechner" code Java Basics - Anfänger-Themen 9
B Erste Schritte Frage zu Instanzierung und Referenzen Java Basics - Anfänger-Themen 8
DoubleM Runtime.getRuntime().exec Frage Java Basics - Anfänger-Themen 2
J Eine theoretische Frage zur Praxis - JPanel oder Canvas Java Basics - Anfänger-Themen 5
O Frage: Formaler Typbezeichner? Java Basics - Anfänger-Themen 3
I BlueJ Queue Frage für Klausur Java Basics - Anfänger-Themen 2
N Verständnis Frage zu Variablen Java Basics - Anfänger-Themen 3
N Spezielle frage zum Comparator Java Basics - Anfänger-Themen 6
L Frage zum Array Java Basics - Anfänger-Themen 1
A Frage zum UML Design Java Basics - Anfänger-Themen 1
I Hilfe bei Klausur Frage Java Basics - Anfänger-Themen 8
izoards Drucken Frage zu FAQ Beitrag Java Basics - Anfänger-Themen 2
J Frage zu meinem Code (OOP) Java Basics - Anfänger-Themen 4
sserio Split() -> Regex Frage. Java Basics - Anfänger-Themen 7
A OCA Study Guide: 2. Frage aus Kapitel 3 Java Basics - Anfänger-Themen 9
sserio Date Library Frage Java Basics - Anfänger-Themen 9
Max246Sch Frage zu Währungsrechner Code Java Basics - Anfänger-Themen 2
sserio Frage zu HashMaps Java Basics - Anfänger-Themen 20
sserio Frage zu Threading - Multithreading Java Basics - Anfänger-Themen 2
sserio Frage zu Lambda Ausdrücken Java Basics - Anfänger-Themen 7
sserio Frage zu BigInteger Java Basics - Anfänger-Themen 1
D Frage bzgl. Enum-Handhabung Java Basics - Anfänger-Themen 16
xxx12 Frage Java Basics - Anfänger-Themen 2
I Generelle Frage zu Mikroservices (Spring Boot?), Docker... Java Basics - Anfänger-Themen 7
R Frage zu Methoden (Rückgabewert u. ohne.) Java Basics - Anfänger-Themen 2
A Frage zur programmierung Java Basics - Anfänger-Themen 12
M Frage zur Methode split der Klasse String Java Basics - Anfänger-Themen 32
R Input/Output Frage zu Java IO Java Basics - Anfänger-Themen 6
M Frage zu printWriter Java Basics - Anfänger-Themen 5
C Frage zu OLSMultipleLinearRegression Java Basics - Anfänger-Themen 31
KogoroMori21 Frage zum Euklidischen Algorithmus Java Basics - Anfänger-Themen 11
S Verständnis-Frage zu einer HÜ? Java Basics - Anfänger-Themen 1
F Frage betreff Programm mit dem man C++-Code in JAVA-Code übersetzen lassen kann Java Basics - Anfänger-Themen 2
L Frage zur Ticket Maschine Java Basics - Anfänger-Themen 1
J Frage zu OOP-Klassendiagramm Java Basics - Anfänger-Themen 8
OSchriever Frage zu Compiler Java Basics - Anfänger-Themen 8
H Frage zu Throw Exception Java Basics - Anfänger-Themen 2
TimoN11 Frage zu Java-Vererbung (Cast) Java Basics - Anfänger-Themen 5
Bademeister007 Hallo Leute ich hab eine Frage zur ArrayList Java Basics - Anfänger-Themen 8
F Frage betreff Programmierbücher zu Lagerverwaltung als Konsolenprogramm Java Basics - Anfänger-Themen 3
dieter000 Kurze Frage kann mir ejmand kurz diesen Code erklären, bzw wie man die zeilen erklärt und so Java Basics - Anfänger-Themen 1
I String.split regex Frage Java Basics - Anfänger-Themen 2
N Best Practice Frage zum MVC-Pattern Java Basics - Anfänger-Themen 2
dieter000 Frage zu einem Beispiel... Java Basics - Anfänger-Themen 5
J Frage zum Loggen Java Basics - Anfänger-Themen 18
J Methoden Frage: Array-Werte in anderer Methode ändern Java Basics - Anfänger-Themen 4
Zrebna Frage zum "Referenzen-konzept" in Java Java Basics - Anfänger-Themen 8
JD_1998 Array-Position aus einer Methode in einer anderen ausgeben (Kurze Frage) Java Basics - Anfänger-Themen 2
marcooooo Frage zu bestimmten Beispiel Java Basics - Anfänger-Themen 31
NeoLexx equals()-Methode Verständnis Frage anhand Code Beispiel Java Basics - Anfänger-Themen 22
N Input/Output Eine Frage über system.out.println. Java Basics - Anfänger-Themen 10
B Erste Schritte Learning Coding (!) Frage an erfahrene Programmierer. Java Basics - Anfänger-Themen 23
M konzeptuelle Frage: In welcher Klasse definiert man am Besten Methoden, die die Kommunikation mit dem User regeln? Java Basics - Anfänger-Themen 8
B Frage zum Code verständnis im Resultat Java Basics - Anfänger-Themen 10
C Exception-Frage Java Basics - Anfänger-Themen 3
J Eine Frage zur Schreibweise == ? : Java Basics - Anfänger-Themen 3
S Frage des Designs Java Basics - Anfänger-Themen 1
JavaTalksToMe Extends/Implements Frage Java Basics - Anfänger-Themen 3
pkm Frage zu Servletfunktion Java Basics - Anfänger-Themen 0
B Frage zur Währungsumrechnung Java Basics - Anfänger-Themen 3
S Allgemeine Frage über Generics und Vererbungen Java Basics - Anfänger-Themen 5
Kirby.exe Frage zur Verwendung von Interfaces Java Basics - Anfänger-Themen 6
D Frage zu Strings einer Exception Java Basics - Anfänger-Themen 4
L Wie frage ich ab, ob in einem Array, Werte doppelt vorkommen? Java Basics - Anfänger-Themen 4
D Frage zur IDE IntelliJ IDEA Java Basics - Anfänger-Themen 6
H Frage zum 2d Array Java Basics - Anfänger-Themen 1
N Frage zum Newton-Fraktal Java Basics - Anfänger-Themen 1
H Frage zu interfaces Java Basics - Anfänger-Themen 1
J Frage dazu Variablen klassenübergreifend zu verändern Java Basics - Anfänger-Themen 22
I Frage zu SkipList Java Basics - Anfänger-Themen 4
G Frage zu JScrollPane Java Basics - Anfänger-Themen 12
Kirby.exe Allgemeine Frage Java Basics - Anfänger-Themen 3
W Frage zu anonymen Klassen Java Basics - Anfänger-Themen 4
J Kleine Frage zu OOP Java Basics - Anfänger-Themen 371
S Frage Klasse und Objekte Java Basics - Anfänger-Themen 2
F Frage zu Iteratoren Java Basics - Anfänger-Themen 2
C Erste Schritte Frage zur ArrayList Java Basics - Anfänger-Themen 15
J Frage zur Vererbung Java Basics - Anfänger-Themen 1
H Frage zur ermittlung eines doppelte Paars aus Sotieralgorithmus Java Basics - Anfänger-Themen 4
H Frage zum Array Java Basics - Anfänger-Themen 17
G Schach -Frage 2- Maussteuerung Java Basics - Anfänger-Themen 7
G Schach in Java - Allgemeine Frage zur Architektur Java Basics - Anfänger-Themen 7
B Fachliche Frage bei Rechnungen Java Basics - Anfänger-Themen 16
B Frage zu: String... strings -> Ungleiche Anzahl an Parameter? Java Basics - Anfänger-Themen 4
B Frage zu Datenbank Design - Rechnungen, Angebote... und deren Positionen Java Basics - Anfänger-Themen 4
H Frage zu Parameter einer Methode Java Basics - Anfänger-Themen 2
H Einfache Frage zur Punktnotation objektname.methode(wert) Java Basics - Anfänger-Themen 2
H Frage zu Parameter einer Methode Java Basics - Anfänger-Themen 3

Ähnliche Java Themen

Neue Themen


Oben