SYNOPSIS string clear_bit(string str, int n) BESCHREIBUNG Gibt einen neuen String zurueck, in dem das n-te Bit im String nicht gesetzt ist. Dabei wird selbst nicht veraendert. Jedes Zeichen enthaelt sechs Bits. So kann in jedem Zeichen eine Zahl zwischen 0 und 63 (2^6=64) gespeichert werden. Das erste Zeichen ist der Leerschlag " " mit Wert 0. Das erste Zeichen im String ist jenes mit den niedrigsten Bits (0 bis 5). BEISPIELE string s; s = clear_bit("_", 5); Weil "_" den hoechsten moeglichen Wert enthaelt (63), enthaelt die Variable s nun das Zeichen "?", das dem Wert 31 entspricht (63-2^5=31). string s; s = clear_bit("?<",3); s = clear_bit(s, 8); s enthaelt nun den String "78". "?" entspricht dem Wert 31 und "<" dem Wert 28. "?<" entspricht also dem Wert 31+28<<6=31+1792=1823, was in Binaerschreibweise (hoechstes Bit rechts) 11111000111 ergibt. Werden aus dieser Zahl die Bits 3 und 8 (die Nummerierung beginnt mit dem 0. Bit) ergibt dann: 11101000011. Die ersten 6 Bits 010111 sind in Dezimalschreibweise 23. Die zweiten 6 Bits (0)11000 ergeben 24 in Dezimalschreibweise. Nun entspricht der Wert 23 dem Zeichen "7" und der Wert 24 dem Zeichen "8". Der String s enthaelt also "78". SIEHE AUCH set_bit(E), next_bit(E), last_bit(E), test_bit(E), count_bits(E), and_bits(E), or_bits(E), xor_bits(E), invert_bits(E), copy_bits(E)