|
Dit artikel is gepubliceerd op zondag 31 juli 2011 op vbvoorbeelden, bezoek de website voor een recente versie van dit artikel of andere artikels.
Bitshift operatoren als >> en << verschuiven de bits van de binaire voorstellingen van gehele getallen respectievelijk naar rechts of naar links. De rechter operand geeft aan hoeveel in rang wordt verschoven. Visual Basic 2010 Broncode Module BitShiftOperatorsExample1 Sub Main() Console.WriteLine(7 << 2) Console.WriteLine(7 >> 1) Dim number As Integer = 7 number <<= 2 Console.WriteLine(number) number = 7 number >>= 1 Console.WriteLine(number) Console.ReadLine() End SubEnd ModuleDownload Visual Basic 2010 Broncode Download Visual C# Sourcecode
Console Application Output 28
3
28
3 Verschuif men de bits van 111 ( decimaal 7 ) 2 posities op naar links dan bekomt men 11100 ( decimaal 28 ). De bijgekomen bits worden opgevuld met een 0-bit. Het verschuiven van een bit naar links, zal dit nummer met 2 vermenigvuldigen. 7 met 2 bits opschuiven naar links zal dus 7 twee maal vermenigvuldigen met 2 ( 7 * 2 * 2 = 28 ).
Verschuif de bits van 111 ( decimaal 7 ) 1 positie op naar rechts, dan valt de rechtse bit er af en bekom je 011 of 3 ( decimaal ). Het verschuiven van de bits naar rechts zal het getal delen door 2.
Deze vormen van vermenigvuldiging en deling ( altijd met factor of deler 2 ) is sneller dan de normale vermenigvuldiging of deling die de processor maakt. 4.4.1. Bitshift en Toekennings OperatorenOok voor deze bitshift operatoren bestaan assignment versies ( (1) en (2) ). boven
4.4.2. Waarom Bitshift Operatoren GebruikenStel dat we van een getal de meest rechtse bit die 1 is wensen te weten. Dan kan dit simpel met de And en >> operator worden bepaald (1).
Een alternatief zou erin bestaan dit op te lossen aan de hand van een deling door 2 tot de rest na deling door 2 nul oplevert (2). Visual Basic 2010 Broncode Module BitShiftOperatorsExample2 Sub Main() Dim value As Integer Dim position As Integer Dim counter As Integer Dim start As Integer value = 12 position = 1 Do While (value And 1) = 0 value >>= 1 position += 1 Loop Console.WriteLine( "12 : Bit at position " & position & " from the right is 1.") value = 12 position = 1 Do While value Mod 2 <> 1 value /= 2 position += 1 Loop Console.WriteLine( "12 : Bit at position " & position & " from the right is 1.") start = Environment.TickCount() For counter = 1 To 10000000 value = counter position = 0 Do While (value And 1) = 0 value >>= 1 position += 1 Loop Next Console.WriteLine( "Bitwise calculation done in " & Environment.TickCount() - start & " tickcounts.") start = Environment.TickCount() For counter = 1 To 10000000 value = counter position = 0 Do While value Mod 2 <> 1 value /= 2 position += 1 Loop Next Console.WriteLine( "Normal calculation done in " & Environment.TickCount() - start & " tickcounts.") Console.ReadLine() End SubEnd ModuleDownload Visual Basic 2010 Broncode Download Visual C# Sourcecode
Console Application Output 12 : Bit at position 3 from the right is 1.
12 : Bit at position 3 from the right is 1.
Bitwise calculation done in 125 tickcounts.
Normal calculation done in 499 tickcounts. Als we werkwijzen (1) en (2) voldoende herhalen (3) merk je duidelijk een snelheidsverschil op.
Dit artikel is gepubliceerd op zondag 31 juli 2011 op vbvoorbeelden, bezoek de website voor een recente versie van dit artikel of andere artikels.
|