5 Data in depth

 

This chapter covers

  • Learning how the computer represents data
  • Building a working CPU emulator
  • Creating your own numeric data type
  • Understanding floating-point numbers

This chapter is all about understanding how zeroes and ones can become much larger objects like text, images, and sound. We will also touch on how computers do computation.

By the end of the chapter, you will have emulated a fully functional computer with CPU, memory, and user-defined functions. You will break apart floating-point numbers to create a numeric data type of your own that only takes a single byte. The chapter introduces a number of terms, such as endianness and integer overflow, that may not be familiar to programmers who have never done systems programming.

5.1 Bit patterns and types

A small but important lesson is that a single bit pattern can mean different things. The type system of a higher-level language, such as Rust, is just an artificial abstraction over reality. Understanding this becomes important as you begin to unravel some of that abstraction and to gain a deeper understanding of how computers work.

Listing 5.1 (in ch5-int-vs-int.rs) is an example that uses the same bit pattern to represent two different numbers. The type system—not the CPU—is what makes this distinction. The following shows the listing’s output:

a: 1100001111000011 50115
b: 1100001111000011 -15421

5.2 Life of an integer

5.2.1 Understanding endianness

5.3 Representing decimal numbers

5.4 Floating-point numbers

5.4.1 Looking inside an f32

5.4.2 Isolating the sign bit

5.4.3 Isolating the exponent

5.4.4 Isolate the mantissa

5.4.5 Dissecting a floating-point number

5.5 Fixed-point number formats

5.6 Generating random probabilities from random bytes

sitemap