Trung tâm đào tạo thiết kế vi mạch Semicon


  • ĐĂNG KÝ TÀI KHOẢN ĐỂ TRUY CẬP NHIỀU TÀI LIỆU HƠN!
  • Create an account
    *
    *
    *
    *
    *
    Fields marked with an asterisk (*) are required.
semicon_lab.jpg

Lập trình firmware: Bit significant, Bit shifting

E-mail Print PDF

Phân biệt MSB và LSB

msb và lsb (Chữ thường)

- msb: most significant bit

- lsb: least significant bit

Hai khái niệm này được dùng trong phạm vi 1 byte.

- msb là cái bít quan trọng nhất ở byte đó. Hiểu đơn giản, byte nào mà mất cái bit này đi(gán bít này bằng 0) thì giá trị của byte đó bị thay đổi đáng kể (có khi là đổi trắng thay đen, đổi từ âm sang dương :D)

- lsb thì ngược lại.

 

Ví dụ: Trên hình ta có số 10100101 = 165

Mất msb thì số đó thành 00100101 = 37

Mất lsb thì số đó thành 10100100 = 164

MSB và LSB (Chữ hoa)

- MSB: Most Significant Byte

- LSB: Least Significant Byte

Hiểu đơn giản:

- MSB là byte quan trọng nhất trong một string hoặc buffer.

- LSB thì ngược lại.

Hai khái niệm này cũng liên quan đến việc tổ chức các byte dữ liệu trong bộ nhớ (memory, register..vv). Nó cũng liên quan đến khái niệm Endian (hay Big Endian ) và Endianless (Litte Endian).

Ví dụ: Trong code ta có một string:

string[3] = {'A', 'B', 'C'} ;

Ba phần tử này được lưu thế nào trong bộ nhớ?

Bộ nhớ thì được đánh địa chỉ từ thấp đến cao. Vậy, thằng A được đánh ở địa chỉ nào, thằng C ở địa chỉ nào? Điều này hoàn toàn phụ thuộc vào hệ thống( MCU platform) là big-endian system hay little endian system.

Hiểu đơn giản, thằng Big-Endian là thằng “đuôi to”, MSB sẽ được xếp ở địa chỉ thấp rồi các byte sau được sếp theo địa chỉ to dần.

Ngược lại Little Endian là thằng “đuôi nhỏ”, LSB được xếp ở địa chỉ thấp, các byte tiếp theo được sếp ở địa chỉ to dần.

Định nghĩa từ Wikipedia:

The terms endian and endianness refer to the convention used to interpret the bytes making up a data word when those bytes are stored incomputer memory

 

Phân biệt Arithmetic Shift và Logical Shift

Hai khái niệm này đều liên quan đến phép dịch bít và các phép toán liên quan đến bit (bitwise operation).

Câu hỏi đặt ra ở đây là: vị trí mà bit bị dịch đi ấy (vacant bit position) thì ta điền số mấy vào vị trị đó, 0 hay là 1?

Logical Shift

Ta điền số 0 vào các vị trí bị dịch. Hiểu đơn giản trong trường hợp một byte, nó giống như 1 cái hàng đợi (queue). Một bít đi ra một đầu thì đầu kia lại được chèn thêm một bít giá trị 0 vào.

Arithmetic Shift (phép dịch số học)

Giá trị được điền vào phụ thuộc vào dấu của byte đó. msb là bit được sử dụng để đánh dấu âm dương cho số đó. Dấu của số này sẽ ko bị thay đổi sau phép dịch số học. Ví dụ, -2 dịch số học sang trái 1 bít thì thành -4.

Phép dịch số học hay được sử dụng để nhân/chia một số nguyên có dấu (signed integer) cho 2.

Nguồn: Thanhnt Blog

Bạn Có Đam Mê Với Vi Mạch hay Nhúng      -     Bạn Muốn Trau Dồi Thêm Kĩ Năng

Mong Muốn Có Thêm Cơ Hội Trong Công Việc

    Và Trở Thành Một Người Có Giá Trị Hơn

Bạn Chưa Biết Phương Thức Nào Nhanh Chóng Để Đạt Được Chúng

Hãy Để Chúng Tôi Hỗ Trợ Cho Bạn. SEMICON  

 

Hotline: 0972.800.931 - 0938.838.404 (Mr Long)

 

Last Updated ( Monday, 22 July 2019 19:35 )  

Related Articles

Chat Zalo