Basics
Getting started, basic data types, and basic operations.
Getting Started
Installing Elixir
Installation instructions for each OS can be found on elixir-lang.org in the Installing Elixir guide.
After Elixir is installed, you can find the installed version.
% elixir -v
Erlang/OTP {{ site.erlang.OTP }} [erts-{{ site.erlang.erts }}] [source] [64-bit] [smp:4:4] [ds:4:4:10] [async-threads:10] [hipe] [kernel-poll:false] [dtrace]
Elixir {{ site.elixir.version }}Trying Interactive Mode
Elixir comes with IEx, an interactive shell, which allows us to evaluate Elixir expressions as we go.
To get started, let’s run iex:
Erlang/OTP {{ site.erlang.OTP }} [erts-{{ site.erlang.erts }}] [source] [64-bit] [smp:4:4] [ds:4:4:10] [async-threads:10] [hipe] [kernel-poll:false] [dtrace]
Interactive Elixir ({{ site.elixir.version }}) - press Ctrl+C to exit (type h() ENTER for help)
iex>
Note: On Windows PowerShell, you need to type iex.bat.
Let’s go ahead and give it a try now by typing in a few basic expressions:
iex> 2+3
5
iex> 2+3 == 5
true
iex> String.length("The quick brown fox jumps over the lazy dog")
43Don’t worry if you don’t understand every expression yet, but we hope you get the idea.
Basic Data Types
Integers
iex> 255
255Support for binary, octal, and hexadecimal numbers comes built in:
iex> 0b0110
6
iex> 0o644
420
iex> 0x1F
31Floats
In Elixir, floating point numbers require a decimal after at least one digit; they have 64-bit double precision and support e for exponent values:
iex> 3.14
3.14
iex> .14
** (SyntaxError) iex:2: syntax error before: '.'
iex> 1.0e-10
1.0e-10Booleans
Elixir supports true and false as booleans; everything is truthy except for false and nil:
iex> true
true
iex> false
falseAtoms
An atom is a constant whose name is its value. If you’re familiar with Ruby, these are synonymous with Symbols:
iex> :foo
:foo
iex> :foo == :bar
false
The booleans true and false are also the atoms :true and :false, respectively.
iex> is_atom(true)
true
iex> is_boolean(:true)
true
iex> :true === true
true
Names of modules in Elixir are also atoms. MyApp.MyModule is a valid atom, even if no such module has been declared yet.
iex> is_atom(MyApp.MyModule)
trueAtoms are also used to reference modules from Erlang libraries, including built in ones.
iex> :crypto.strong_rand_bytes 3
<<23, 104, 108>>Strings
Strings in Elixir are UTF-8 encoded and are wrapped in double quotes:
iex> "Hello"
"Hello"
iex> "dziękuję"
"dziękuję"Strings support line breaks and escape sequences:
iex> "foo
...> bar"
"foo\nbar"
iex> "foo\nbar"
"foo\nbar"Elixir also includes more complex data types. We’ll learn more about these when we learn about collections and functions.
Basic Operations
Arithmetic
Elixir supports the basic operators +, -, *, and / as you would expect.
It’s important to remember that / will always return a float:
iex> 2 + 2
4
iex> 2 - 1
1
iex> 2 * 5
10
iex> 10 / 5
2.0If you need integer division or the division remainder (i.e., modulo), Elixir comes with two helpful functions to achieve this:
iex> div(10, 3)
3
iex> rem(10, 3)
1Boolean
Elixir provides the ||, &&, and ! boolean operators.
These support any types:
iex> -20 || true
-20
iex> false || 42
42
iex> 42 && true
true
iex> 42 && nil
nil
iex> !42
false
iex> !false
true
In Elixir, the concept of “truthiness” is very simple: only false and nil are considered falsy. Every other value, including 0, "" (empty string), and [] (empty list), is considered truthy. This strict rule allows boolean operators like ||, &&, and ! to work predictably with any data type for conditional logic.
There are three additional operators whose first argument must be a boolean (true or false):
iex> true and 42
42
iex> false or true
true
iex> not false
true
iex> 42 and true
** (BadBooleanError) expected a boolean on left-side of "and", got: 42
iex> not 42
** (ArgumentError) argument error
Note: Elixir’s and and or actually map to andalso and orelse in Erlang.
Comparison
Elixir comes with all the comparison operators we’re used to: ==, !=, ===, !==, <=, >=, <, and >.
iex> 1 > 2
false
iex> 1 != 2
true
iex> 2 == 2
true
iex> 2 <= 3
true
For strict comparison of integers and floats, use ===:
iex> 2 == 2.0
true
iex> 2 === 2.0
falseAn important feature of Elixir is that any two types can be compared; this is particularly useful in sorting. We don’t need to memorize the sort order, but it is important to be aware of it:
number < atom < reference < function < port < pid < tuple < map < list < bitstringThis can lead to some interesting, yet valid comparisons you may not find in other languages:
iex> :hello > 999
true
iex> {:hello, :world} > [1, 2, 3]
falseString Interpolation
If you’ve used Ruby, string interpolation in Elixir will look familiar:
iex> name = "Sean"
"Sean"
iex> "Hello #{name}"
"Hello Sean"String Concatenation
String concatenation uses the <> operator:
iex> name = "Sean"
"Sean"
iex> "Hello " <> name
"Hello Sean"Caught a mistake or want to contribute to the lesson? Edit this lesson on GitHub!