VB.NET'te Bitsel İşlemler

VB.NET, bit düzeyi işlemlerini doğrudan desteklemez. Framework 1.1 (VB.NET 2003), bit kaydırma operatörlerini (<< ve >>), ancak ayrı bitleri işlemek için genel bir amaç yoktur. Bit işlemleri Yapabilmek çok faydalı olacak. Örneğin, programınızın bit manipülasyonu gerektiren başka bir sistemle arayüz kurması gerekebilir. Ancak ek olarak, bireysel bitler kullanılarak yapılabilecek birçok püf noktası var. Bu makalede, VB.NET kullanarak bit manipülasyonu ile neler yapılabileceği incelenmektedir.

Anlamalısın bitsel operatörler her şeyden önce. VB.NET'te bunlar:

  • Ve
  • Veya
  • xor
  • Değil

Bitsel, işlemlerin iki ikili sayı üzerinde adım adım gerçekleştirilebileceği anlamına gelir. Microsoft kullanır doğruluk tabloları bitsel işlemleri belgelemek. İçin doğruluk tablosu Ve dır-dir:

1. Bit 2. Bit Sonucu
1 1 1
1 0 0
0 1 0
0 0 0

Okulumda öğrettiler Karnaugh bunun yerine haritalar. Dört işlemin tümü için Karnaugh haritası aşağıdaki çizimde gösterilmiştir.


Resmi görüntülemek için Buraya tıklayın
Geri dönmek için tarayıcınızdaki Geri düğmesini tıklayın

instagram viewer

İşte basit bir örnek kullanarak Ve iki, dört bit ikili sayılarla işlem:

1100 sonucu Ve 1010 1000'dir.

Çünkü 1 Ve 1 1'dir (ilk bit) ve geri kalanı 0'dır.

Başlangıç ​​olarak, şu bit işlemlerine bakalım: Hangi VB.NET'te doğrudan desteklenir: bit kaydırma. Hem sağa sola kaydırma hem de sağa kaydırma mevcut olsa da, aynı şekilde çalışırlar, böylece sadece sola kaydırma tartışılacaktır. Bit kaydırma, çoğunlukla şifreleme, görüntü işleme ve iletişimde kullanılır.

VB.NET'in bit kaydırma işlemleri ...

  • Yalnızca dört tür tamsayı ile çalışın: Bayt, Kısa, tamsayı, ve Uzun
  • Are aritmetik vardiya işlemleri. Bu, sonucun sonundan ötelenen bitlerin atılacağı ve diğer uçta açılan bit konumlarının sıfıra ayarlandığı anlamına gelir. Alternatif, dairesel bit kaydırma olarak adlandırılır ve bir ucundan ötelenen bitler basitçe diğer uca eklenir. VB.NET, dairesel bit kaydırmayı doğrudan desteklemez. İhtiyacınız varsa, eski moda bir şekilde kodlamanız gerekir: çarpma veya bölme 2.
  • Asla taşma istisnası oluşturmayın. VB.NET olası problemlerle ilgilenir ve size bunun ne anlama geldiğini göstereceğim. Belirtildiği gibi, kendi bit kaydırma işleminizi 2 ile çarparak veya bölerek kodlayabilirsiniz, ancak "kendi kodunuzu yazın" yaklaşımında, programınızın çalışmasına neden olabilecek taşma istisnalarını test etmeniz gerekir çökmesine.

Standart bir bit kaydırma işlemi şöyle görünecektir:

Dim Başlangıç ​​Değeri Tamsayı Olarak = 14913080
Tamsayı Olarak Kaydırdıktan Sonra Dim Değeri
ValueAfterShifting = Başlangıç ​​Değeri << 50

Kelimelerde, bu işlem ikili değeri alır 0000 0000 1110 0011 1000 1110 0011 1000 (14913080, eşdeğer ondalık değerdir - birkaç kez tekrarlanan 3 3 ve 3 1 serilerinin olduğuna dikkat edin) ve 50 yeri sola kaydırır. Ancak bir Tamsayı sadece 32 bit uzunluğunda olduğundan, 50 yer kaydırmak anlamsızdır. VB.NET bu sorunu çözer maskeleme vardiya sayımı kullanılan veri türüyle eşleşen standart bir değere sahiptir. Bu durumda, ValueAfterShifting bir tamsayı kaydırılabilecek maksimum değer 32 bittir. Çalışan standart maske değeri 31 ondalık veya 11111'dir.

Maskeleme bu durumda 50 değerinin Vemaske ile ed. Bu, söz konusu veri türü için kaydırılabilecek maksimum bit sayısını verir.

Ondalık olarak:

50 ve 31 dır-dir 18 - Değiştirilebilen maksimum bit sayısı

Aslında ikili olarak daha mantıklı. Vites değiştirme işlemi için kullanılamayan yüksek dereceli bitler basitçe çıkarılır.

110010 ve 11111 dır-dir 10010

Kod pasajı yürütüldüğünde sonuç 954204160 veya ikili olarak 0011 1000 1110 0000 0000 0000 0000 0000 0000 olur. İlk ikili sayının sol tarafındaki 18 bit kaydırılır ve sağ taraftaki 14 bit sola kaydırılır.

Değişen bitlerle ilgili diğer büyük sorun, kaydırılacak yer sayısı negatif bir sayı olduğunda olan şeydir. Değiştirmek ve neler olduğunu görmek için bit sayısı olarak -50 kullanalım.

ValueAfterShifting = Başlangıç ​​Değeri << -50

Bu kod snippet'i yürütüldüğünde, -477233152 veya 1110 0011 1000 1110 0000 0000 0000 0000 ikili kodunu alırız. Sayı 14 yer değiştirildi. Neden 14? VB.NET, yer sayısının imzasız bir tam sayı olduğunu varsayar ve Ve aynı maske ile çalışma (Tamsayılar için 31).

1111 1111 1111 1111 1111 1111 1100 1110
0000 0000 0000 0000 0000 0000 0001 1111
(Ve)
0000 0000 0000 0000 0000 0000 0000 1110

İkili 1110 14 ondalıktır. Bunun, pozitif 50 yeri değiştirmenin tersi olduğuna dikkat edin.

Bir sonraki sayfada, ile başlayan diğer bazı bit işlemlerine geçiyoruz. Xor Şifrelemesi!

Bit işlemlerinin bir kullanımının şifreleme olduğunu belirttim. Xor şifreleme, bir dosyayı "şifrelemenin" popüler ve basit bir yoludur. Makalemde, VB.NET kullanarak Çok Basit Şifreleme, bunun yerine dize manipülasyonu kullanarak daha iyi bir yol göstereceğim. Ancak Xor şifrelemesi o kadar yaygın ki en azından açıklanmayı hak ediyor.

Bir metin dizesini şifrelemek, onu bir metin dizesiyle açık bir ilişkisi olmayan başka bir metin dizesine çevirmek anlamına gelir. Ayrıca tekrar şifresini çözmek için bir yola ihtiyacınız var. Xor şifrelemesi, dizideki her karakter için ikili ASCII kodunu Xor işlemini kullanarak başka bir karaktere çevirir. Bu çeviriyi yapabilmek için, Xor'da kullanmak için başka bir numaraya ihtiyacınız var. Bu ikinci sayıya anahtar denir.

Xor şifrelemesine "simetrik algoritma" denir. Bu, şifreleme anahtarını şifre çözme anahtarı olarak da kullanabileceğimiz anlamına gelir.

Anahtar olarak "A" yı kullanalım ve "Temel" kelimesini şifreleyelim. "A" için ASCII kodu:

0100 0001 (ondalık 65)

Basic için ASCII kodu:

B - 0100 0010
a - 0110 0001
s - 0111 0011
ben - 0110 1001
c - 0110 0011

xor Bunların her biri:

0000 0011 - ondalık 3
0010 0000 - ondalık 32
0011 0010 - ondalık 50
0010 1000 - ondalık 40
0010 0010 - ondalık 34

Bu küçük rutin hile yapar:

- Xor Şifrelemesi -
Kısa Dim
ResultString. Metin = ""
Tamsayı Olarak Dim KeyChar
KeyChar = Asc (EncryptionKey. Metin)
İ = 1 için Len (InputString. Metin)
ResultString. Metin & = _
Chr (KeyChar X veya _
Artan (Orta (InputString). Metin, i, 1)))
Sonraki

Sonuç bu çizimde görülebilir:


Resmi görüntülemek için Buraya tıklayın
Geri dönmek için tarayıcınızdaki Geri düğmesini tıklayın

Şifrelemeyi tersine çevirmek için, dizeyi Result TextBox'dan Dize TextBox'a kopyalayıp yapıştırmanız ve düğmeye tekrar tıklamanız yeterlidir.

Bitsel işleçlerle yapabileceğiniz başka bir örnek, geçici depolama için üçüncü bir değişken bildirmeden iki Tamsayıyı değiştirmektir. Yıllar önce montaj dili programlarında yaptıkları şey budur. Artık çok kullanışlı değil, ancak yapabileceğinize inanmayan birini bulabilirseniz bir gün bir bahis kazanabilirsiniz. Her durumda, nasıl yapılacağı hakkında hala sorularınız varsa xor bu şekilde çalışmak onları dinlendirmelidir. İşte kod:

Tam Sayı Olarak Dim FirstInt
Tamsayı Olarak Dim SecondInt
FirstInt = CInt (FirstIntBox. Metin)
SecondInt = CInt (SecondIntBox. Metin)
FirstInt = FirstInt X veya SecondInt
SecondInt = FirstInt X veya SecondInt
FirstInt = FirstInt X veya SecondInt
ResultBox. Metin = "İlk Tamsayı:" & _
FirstInt. ToString & "-" & _
"İkinci Tamsayı:" & _
SecondInt. ToString

İşte işte kod:


Resmi görüntülemek için Buraya tıklayın
Geri dönmek için tarayıcınızdaki Geri düğmesini tıklayın

Bu çalışmaların neden "öğrenci için bir egzersiz olarak" bırakılacağını tam olarak anlamak.

Bir sonraki sayfada hedefe ulaşıyoruz: Genel Bit Manipülasyonu

Bu hileler eğlenceli ve eğitici olmasına rağmen, hala genel bit manipülasyonunun yerini tutmazlar. Gerçekten bit düzeyine inerseniz, istediğiniz tek tek bitleri incelemek, ayarlamak veya değiştirmek için bir yoldur. .NET'te eksik olan gerçek kod budur.

Belki de eksik olmasının nedeni, aynı şeyi yapan alt rutinleri yazmanın o kadar zor olmamasıdır.

Bunu yapmak isteyebileceğiniz tipik bir neden, bazen bir bayrak baytı. Bazı uygulamalar, özellikle de derleyici gibi düşük seviyeli dillerde yazılmış olanlar, sekiz boolean bayrağını tek bir baytta tutacaktır. Örneğin, 6502 işlemci yongasının durum kaydı bu bilgileri tek bir 8 bit baytta tutar:

Bit 7. Negatif bayrak
Bit 6. Taşma bayrağı
Bit 5. kullanılmamış
Bit 4. Bayrağı kır
Bit 3. Ondalık bayrak
Bit 2. Kesme-devre dışı bırakma bayrağı
Bit 1. Sıfır bayrağı
Bit 0. Bayrak taşımak

(Wikipedia'dan)

Kodunuzun bu tür verilerle çalışması gerekiyorsa, genel amaçlı bit işleme koduna ihtiyacınız vardır. Bu kod işi yapacak!

ClearBit Sub, 1 tabanlı nth biti temizler
'(MyBit) tamsayı (MyByte).
Sub ClearBit (ByRef MyByte, ByVal MyBit)
Int16 olarak Dim BitMask
'2 - nth güç biti kümesiyle bir bit maskesi oluşturun:
BitMask = 2 ^ (MyBit - 1)
'Nci Bit'i temizle:
MyByte = MyByte Ve BitMask Değil
End Sub
'ExamineBit işlevi doğru veya yanlış döndürür
'1 tabanlı nth bitin değerine bağlı olarak (MyBit)
'tamsayı (MyByte).
Function ExamineBit (ByVal MyByte, ByVal MyBit) Boole Olarak
Int16 olarak Dim BitMask
BitMask = 2 ^ (MyBit - 1)
ExamineBit = ((MyByte Ve BitMask)> 0)
Bitiş Fonksiyonu
SetBit Sub, 1 tabanlı, n. Biti ayarlayacaktır.
'(MyBit) tamsayı (MyByte).
Alt SetBit (ByRef MyByte, ByVal MyBit)
Int16 olarak Dim BitMask
BitMask = 2 ^ (MyBit - 1)
MyByte = MyByte Veya BitMask
End Sub
'ToggleBit Sub durumu değiştirecek
'tabanlı, n. bitin (MyBit)
'tamsayı (MyByte).
Sub ToggleBit (ByRef MyByte, ByVal MyBit)
Int16 olarak Dim BitMask
BitMask = 2 ^ (MyBit - 1)
MyByte = MyByte Xor BitMask
End Sub

Kodu göstermek için, bu rutin kodu çağırır (Tıklama Altında kodlanmamış parametreler):

Özel Alt ExBitCode_Click (...
Dim Byte1, Byte2 As Byte
Dim MyByte, MyBit
Dim StatusOfBit Boolean Olarak
Dim SelectedRB As String
Durumsatırı. Metin = ""
SelectedRB = GetCheckedRadioButton (Me) .Ad
Byte1 = ByteNum. Metin 'Bit Bayraklarına Dönüştürülecek Sayı
Byte2 = BitNum. Metin 'Değiştirilecek bit
'Aşağıdaki yüksek dereceli baytı temizler ve yalnızca
'düşük sıralı bayt:
MyByte = Bayt1 ve HFF
MyBit = Bayt2
Seçili Vaka SeçinRB
Durum "ClearBitButton"
ClearBit (MyByte, MyBit)
Durumsatırı. Metin = "Yeni Bayt:" ve MyByte
Vaka "ExamineBitButton"
StatusOfBit = ExamineBit (MyByte, MyBit)
Durumsatırı. Metin = "Bit" ve MyBit & _
"is" ve StatusOfBit
Durum "SetBitButton"
SetBit (MyByte, MyBit)
Durumsatırı. Metin = "Yeni Bayt:" ve MyByte
Vaka "ToggleBitButton"
ToggleBit (MyByte, MyBit)
Durumsatırı. Metin = "Yeni Bayt:" ve MyByte
Bitiş Seçimi
End Sub
Özel İşlev GetCheckedRadioButton (_
ByVal Parent As Control) _
RadioButton olarak
Dim FormControl Denetim Olarak
RadioButton olarak Dim RB
Üst öğedeki her FormControl için. Kontroller
FormControl varsa. GetType () GetType (RadioButton) Sonra
RB = DirectCast (FormControl, RadioButton)
RB.Kontrol Edildiyse RB'yi Döndür
End If
Sonraki
Geri Dönüş Hiçbir Şey
Bitiş Fonksiyonu

Uygulamadaki kod şuna benzer:


Resmi görüntülemek için Buraya tıklayın
Geri dönmek için tarayıcınızdaki Geri düğmesini tıklayın