CSAPP笔记:Bits, Bytes and Integer01
data:image/s3,"s3://crabby-images/829bb/829bb8615cede921ab9aeaaeeb44793b3e5ccde9" alt=""
course website:here
CSAPP笔记:Bits, Bytes
Representing information as bits
Everything is bits
- 0/1
- encoding/interpreting sets of bits in various ways
- instructions
- represent and manipulate numbers. sets and strings
- why use bits?
- easy to store
- reliably transmitted on noisy and inaccurate wires
data:image/s3,"s3://crabby-images/0bca1/0bca1995fa566e9dcea4dbe9b60c0b0803a558d2" alt="image-20230406101623090"
Encoding Byte Values
- Binary 00000000-11111111
- Decimal 0-255
- Hexadecimal 00-FF
Example Data Representations
data:image/s3,"s3://crabby-images/ca9fb/ca9fb424c3cd225d985cb22613b42e35f0893081" alt="image-20230406102532287"
Bit level manipulation
Boolean algebra
data:image/s3,"s3://crabby-images/a95b4/a95b461b7d7d2282367106b6bdc8efe7d21e59c5" alt="image-20230406102846832"
Example: Representing and manipulating Sets
widely used
data:image/s3,"s3://crabby-images/5a671/5a671045a802f34fe273fb808f89f0e58d74c882" alt="image-20230406103402468"
- symmetric difference is 对称差 in chinese:
data:image/s3,"s3://crabby-images/2daf7/2daf771714312c157840f49b574a5dacc4a122fb" alt="image-20230406103458899"
shift
- left shift
- right shift
- logical shift
- arithmetic shift
- undefined behavior
- shift amount < 0 or >= word size
Integers
Representing signed and unsigned
Encoding Ints
Unsigned
data:image/s3,"s3://crabby-images/d0413/d041382910b5c927971032f040588f5d3a0bb75a" alt="image-20230406105453744"
Signed
- for two’s complement, most significant bit indicated sign
- 0 for nonnegative
- 1 for negative
data:image/s3,"s3://crabby-images/016df/016dfc980325309d94121bb737e7cf429d6edd1c" alt="image-20230406105401555"
Numeric Ranges
Unsigned
0 ~
Two’s Complement(universal)
Minus 1
1111…111
values for W = 16
data:image/s3,"s3://crabby-images/21322/21322f79d2ddf8f394d5ebbb2a9a9bd15d00bad5" alt="image-20230406110240459"
values for different word sizes
data:image/s3,"s3://crabby-images/bdefa/bdefa12b5956ef4151c5c2164a3a245f88daf0cb" alt="image-20230406110440140"
- 64bits TMax has 18 位
Conversion, Casting
Mapping between Signed & Unsigned
data:image/s3,"s3://crabby-images/05056/050567a2e5463e9221a6d4163223f6110dde3b59" alt="image-20230406111407535"
- keep bit representations and reinterpret
data:image/s3,"s3://crabby-images/cade8/cade8f48f8e6179b988349bb79ca419394ab2944" alt="image-20230406111610856"
data:image/s3,"s3://crabby-images/3601b/3601b01a1e0938de5d95430d7f6938c2e95657bd" alt="image-20230406111946568"
data:image/s3,"s3://crabby-images/464a8/464a8d088ab4bff2d8dc4f36ca75bb65e59845f0" alt="image-20230406112126993"
- casting may cause some surprises , we need to be careful
- 0 == 0U
- -1 < 0
- -1 > 0U
- 2147483647U < -2147483648
what does this code return for TMin?
data:image/s3,"s3://crabby-images/30892/30892e730a9b9d83f10cb3291c1e7674e3307dea" alt="image-20230406113449103"
- it will return TMin(100…000)
why UMax = 2TMax+1?
data:image/s3,"s3://crabby-images/acdf2/acdf2013350fbfd76f236186c629093b27342e5a" alt="image-20230406123934287"
What if i is declared unsigned?
data:image/s3,"s3://crabby-images/17a48/17a48cca3dfad2d65cf2cc323d8a4ece149dde6f" alt="image-20230406124159243"
- infinite loop: 0->UMax
another example
data:image/s3,"s3://crabby-images/5ee44/5ee44c268ad431e7355c877856b68301e4182672" alt="image-20230406124603747"
- infinite loop
Expanding, Truncating
Sign Extension
data:image/s3,"s3://crabby-images/b0681/b068152a1fd9374164cb595fbc5b8013474cd1a2" alt="image-20230406125037825"
example:
data:image/s3,"s3://crabby-images/f1e40/f1e40adb7c528b69c8b91a36e8d6169dd471147e" alt="image-20230406125553803"
data:image/s3,"s3://crabby-images/034df/034df4c184a1c1fe4db1c77aaff22e63768a33b9" alt="image-20230406125315446"
data:image/s3,"s3://crabby-images/fe5a1/fe5a1d16f52027c01b114aa315e72a3865921f28" alt="image-20230406125444452"
- the above is a negative number
Truncating
data:image/s3,"s3://crabby-images/f72bd/f72bd97de22d9629ed2b3294fa1e107d6358d368" alt="image-20230406125856661"
- it’ so funny here, the professor does the additions wrongly for two times
data:image/s3,"s3://crabby-images/07905/07905d9d3ba9fcc467d330b45cd650c8f1ca02b6" alt="image-20230406130123284"
- it wasn’t a very interesting example :)
data:image/s3,"s3://crabby-images/deb1e/deb1e9afcd8981d1be977865f44d65e8586aea3e" alt="image-20230406130241157"
- positive number may become negative number
- negative number may become positive number
- Post title:CSAPP笔记:Bits, Bytes and Integer01
- Post author:sixwalter
- Create time:2023-08-05 11:14:26
- Post link:https://coelien.github.io/2023/08/05/course-learning/CMU-213/213_bits01/
- Copyright Notice:All articles in this blog are licensed under BY-NC-SA unless stating additionally.
Comments