Chapter 6. Expressions
LISP programmers know the value of everything, but the cost of nothing.
Alan Perlis, epigram #55
In this chapter, weâll cover the expressions of Rust, the building blocks that make up the body of Rust functions and thus the majority of Rust code. Most things in Rust are expressions. In this chapter, weâll explore the power this brings and how to work with its limitations. Weâll cover control flow, which in Rust is entirely expression-oriented, and how Rustâs foundational operators work in isolation and combination.
A few concepts that technically fall into this category, such as closures and iterators, are deep enough that we will dedicate a whole chapter to them later. For now, we aim to cover as much syntax as possible in a few pages.
An Expression Language
Rust visually resembles the C family of languages, but this is a bit of a ruse. In C, there is a sharp distinction between expressions, bits of code that look something like this:
5
*
(
fahr
-
32
)
/
9
and statements, which look more like this:
for
(;
begin
!=
end
;
++
begin
)
{
if
(
*
begin
==
target
)
break
;
}
Expressions have values. Statements donât.
Rust is what is called an expression language. This means it follows an older tradition, dating back to Lisp, where expressions do all the work.
In C, if
and switch
are statements. They donât produce a value, and they canât be used in the middle of an expression. In Rust, if
and match
can produce values. We already saw a match
expression that ...
Get Programming Rust, 2nd Edition now with the O’Reilly learning platform.
O’Reilly members experience books, live events, courses curated by job role, and more from O’Reilly and nearly 200 top publishers.