Sign In Start Free Trial
Account

Add to playlist

Create a Playlist

Modal Close icon
You need to login to use this feature.
  • Rust Essentials
  • Toc
  • feedback
Rust Essentials

Rust Essentials

By : Ivo Balbaert
3 (1)
close
Rust Essentials

Rust Essentials

3 (1)
By: Ivo Balbaert

Overview of this book

Rust is the new, open source, fast, and safe systems programming language for the 21st century, developed at Mozilla Research, and with a steadily growing community. It was created to solve the dilemma between high-level, slow code with minimal control over the system, and low-level, fast code with maximum system control. It is no longer necessary to learn C/C++ to develop resource intensive and low-level systems applications. This book will give you a head start to solve systems programming and application tasks with Rust. We start off with an argumentation of Rust's unique place in today's landscape of programming languages. You'll install Rust and learn how to work with its package manager Cargo. The various concepts are introduced step by step: variables, types, functions, and control structures to lay the groundwork. Then we explore more structured data such as strings, arrays, and enums, and you’ll see how pattern matching works. Throughout all this, we stress the unique ways of reasoning that the Rust compiler uses to produce safe code. Next we look at Rust's specific way of error handling, and the overall importance of traits in Rust code. The pillar of memory safety is treated in depth as we explore the various pointer kinds. Next, you’ll see how macros can simplify code generation, and how to compose bigger projects with modules and crates. Finally, you’ll discover how we can write safe concurrent code in Rust and interface with C programs, get a view of the Rust ecosystem, and explore the use of the standard library.
Table of Contents (13 chapters)
close

Built-in traits and operator overloading


The Rust standard library is packed with traits, which are used all over the place. For example, there are traits for which the compiler is capable of providing a basic implementation with a #[derive] attribute, as we saw in the section on Traits:

  • Comparing instances: The Eq and PartialEq trait
  • Ordering instances: The Ord and PartialOrd trait
  • Creating an empty instance: The Default trait
  • To create a zero instance of a numeric data type: The Zero trait

The next chapter shows an example of how to implement the following three traits:

  • Formatting a value using {:?}: The Debug trait, defining an fmt method
  • Copy an instance: The Copy trait
  • Create a duplicate instance: The Clone trait
  • Computing a hash: The Hash trait
  • Adding instances: The Add trait, defining an add method. The + operator is just a nice way to use add: n + m is the same as n.add(m). So if we implement the Add trait, we can use the + operator, this is called operator overloading.
    • The Add trait has the...
bookmark search playlist font-size

Change the font size

margin-width

Change margin width

day-mode

Change background colour

Close icon Search
Country selected

Close icon Your notes and bookmarks

Delete Bookmark

Modal Close icon
Are you sure you want to delete it?
Cancel
Yes, Delete