Các toán tử này được sử dụng đến tính toán trên các số nguyên bằng cách tính toán trên các bit. Các toán tử hội bit, tuyển bit, tuyển loại bit và phủ định bit được tính như sau: chúng ta chuyển đổi các số thập phân sang nhị phân tương ứng, sau đó sử dụng các phép toán tương ứng cho từng bit theo vị trí của nó. Ví dụ như ở trên 210=102, 310=112 và ta sẽ thực hiện các phép toán tương ứng với từng bit. Bit thứ nhất (từ phải sang trái) là 0&1=1, bit thứ hai 1&1=1, như vậy kết quả của phép toán 2&3 là 112 hay 310. Tương tự cho các phép toán còn lại. Nếu hai số có độ dài bit khác nhau, thì ta chỉ việc bổ sung thêm 0 ở số có độ dài bit ngắn hơn, sau đó thực hiện các phép toán như đã nêu. Ở đây bạn lưu ý rằng phép toán tuyển loại sẽ có chân trị là 1 nếu hai bit tương ứng là khác nhau, nếu giống nhau thì tương ứng là 0(1^1=0^0=0, 1^0=0^1=1). Các phép toán hội, tuyển và phủ định vẫn còn đúng như phép toán hội, tuyển và phủ định trên kiểu dữ liệu logic.
Toán tử | Kết quả | |||||||||||||||||||||||||||||||||||||||||||||
~ | Toán tử phủ định bit. Các bit 1 sẽ chuyển thành 0 và ngược lại. Ví dụ ~101=010. | |||||||||||||||||||||||||||||||||||||||||||||
& | Toán tử hội bit. Hội của hai bit 1 bằng 1. Trong mọi trường hợp còn lại, ta nhận được 0. Ví dụ.
Nghĩa là 11&5=1. | |||||||||||||||||||||||||||||||||||||||||||||
| | Toán tử tuyển bit. Tuyển của hai bit 0 bằng 0. Trong mọi trường hợp còn lại, ta nhận được 1. Ví dụ.
Nghĩa là 11|1=11. | |||||||||||||||||||||||||||||||||||||||||||||
^ | Toán tử tuyển loại bit. Tuyển loại của hai bit khác nhau bằng 1. Trong mọi trường hợp còn lại, ta nhận được 0. Ví dụ.
Nghĩa là 11^1=10. | |||||||||||||||||||||||||||||||||||||||||||||
>> | Toán tử dịch bit sang phải. Dịch chuyển toàn bộ dãy bit sang phải theo số bit được chỉ định. Nếu là số dương, ta bổ sung các bit 0 vào đầu. Nếu là số âm, ta bổ sung các số 1 vào đầu. Ví dụ. Đối với số dương
Nghĩa là 11>>1=5. Đối với số âm
Nghĩa là -11>>2=-3. Các bạn cũng cần lưu ý rằng, trong các biểu diễn ở trên, nếu hệ thống được chọn là 32 bit, thì chúng ta cần lấp đầy số bit này: - Nếu số dương thì các bit còn lại sẽ được bổ sung 0 vào phía trước. - Nếu số âm thì các bit còn lại sẽ được bổ sung 1 vào phía trước. Trong các ví dụ trên, phần dãy bit để trắng tương ứng với bit dấu – 1 tương ứng với – và 0 tương ứng với +. | |||||||||||||||||||||||||||||||||||||||||||||
<< | Toán tử dịch bit sang trái. Dịch chuyển toàn bộ dãy bit sang trái theo số bit được chỉ định. Ví dụ. Đối với số dương
Nghĩa là 11<<2=44. | |||||||||||||||||||||||||||||||||||||||||||||
&= |= ^= >>= <<= | Các phép toán gán hợp nhất trên bit. |
Các toán tử dịch trái bit << và dịch phải bit >> nếu thực hiện trực tiếp trên số nguyên hệ thập phân, sẽ được tính như sau: dịch trái tương đương vưới a*2b và dịch phải tương đương với a/2b.
BẠN ƠI CHO MÌNH HỎI :
ReplyDeletez = (x xor (not y)) là sao
Bạn có thể viết dưới dạng ngôn ngữ C như sau:
ReplyDeletez = x ^ (~y);
Cách thực hiện thì như giải thích ở trên cho từng toán tử ^ và ~
viết y
ReplyDeleteviết (not y)
xor : giống -> 0, khác -> 1
x=x<<1 viết tắt lại thành x<<=1 được không các bạn? Lâu ngày không dùng tự nhiên quên.
ReplyDeleteĐược nhé! Tương tự như x=x+1 và x+=1 vậy
Delete