Crystal’s syntax is heavily inspired by Ruby’s, so it feels natural to read and easy to write, and has the added benefit of a lower learning curve for experienced Ruby devs.
Crystal is statically type checked, so any type errors will be caught early by the compiler rather than fail on runtime. Moreover, and to keep the language clean, Crystal has built-in type inference, so most type annotations are unneeded.
Null reference checks
All types are non-nilable in Crystal, and nilable variables are represented as a union between the type and nil. As a consequence, the compiler will automatically check for null references in compile time, helping prevent the dreadful billion-dollar mistake.
Running the previous file:
Crystal’s answer to metaprogramming is a powerful macro system, which ranges from basic templating and AST inspection, to types inspection and running arbitrary external programs.
Crystal uses green threads, called fibers, to achieve concurrency. Fibers communicate with each other using channels, as in Go or Clojure, without having to turn to shared memory or locks.
Crystal has a dedicated syntax to easily call native libraries, eliminating the need to reimplement low-level tasks.
Crystal libraries are packed as Shards, and distributed via Git without needing a centralised repository. Built in commands allow dependencies to be easily specified through a YAML file and fetched from their respective repositories.
Articles from our blog
Using CircleCI 2.0 for your Crystal projects
|Crystal 0.29.0 released!||05 Jun 2019|
|Crystal 0.28.0 released!||17 Apr 2019|
|Crystal 0.27.2 released!||05 Feb 2019|
|Crystal 0.27.1 released!||30 Jan 2019|
|Crystal 0.27.0 released!||01 Nov 2018|
|Crystal 0.26.1 released!||27 Aug 2018|
|Crystal 0.26.0 released!||09 Aug 2018|
|Crystal 0.25.1 released!||28 Jun 2018|
|Crystal 0.25.0 released!||15 Jun 2018|
|Crystal 0.24.2 released!||09 Mar 2018|