Book Image

Polished Ruby Programming

By : Jeremy Evans
5 (1)
Book Image

Polished Ruby Programming

5 (1)
By: Jeremy Evans

Overview of this book

Anyone striving to become an expert Ruby programmer needs to be able to write maintainable applications. Polished Ruby Programming will help you get better at designing scalable and robust Ruby programs, so that no matter how big the codebase grows, maintaining it will be a breeze. This book takes you on a journey through implementation approaches for many common programming situations, the trade-offs inherent in each approach, and why you may choose to use different approaches in different situations. You'll start by refreshing Ruby fundamentals, such as correctly using core classes, class and method design, variable usage, error handling, and code formatting. Then you'll move on to higher-level programming principles, such as library design, use of metaprogramming and domain-specific languages, and refactoring. Finally, you'll learn principles specific to web application development, such as how to choose a database and web framework, and how to use advanced security features. By the end of this Ruby programming book, you’ll be a well rounded web developer with a deep understanding of Ruby. While most code examples and principles discussed in the book apply to all Ruby versions, some examples and principles are specific to Ruby 3.0, the latest release at the time of publication.
Table of Contents (23 chapters)
1
Section 1: Fundamental Ruby Programming Principles
8
Section 2: Ruby Library Programming Principles
17
Section 3: Ruby Web Programming Principles

Understanding that no code is faster than no code

The phrase No code is faster than no code was the motto of the old Ruby web framework named Merb, which focused heavily on performance. Another, less poetic way of phrasing the same principle is, If you can get the same result without executing any code, any approach that requires executing code will be slower. A simplification of the principle would be, The fastest code is usually the code that does the least. In general, if you want the code to be as fast as possible, you need to find a way to get the same results while doing less work.

There are cases where doing less work can require an algorithmic change, such as changing from a linear scan of an array to using a hash table lookup. There are other cases where doing less work can be accomplished by caching results. Sometimes, doing less work can be accomplished by restructuring your code to delay computation until it is needed, or even better, figuring out computation is not...