 
 
    Ruby Concepts - Singleton Classes
1970 words. Time to Read: About 19 minutes.Cover Image credit: Samier Saeed and SitePoint.
Have you ever wondered what a “singleton class” is? Have you ever been talking to someone or reading a blog post and “singleton class” or “singleton method” got used, and you just smile and nod, making a mental note to look it up later? Now is your time. Now is your moment. I’m hoping to explain this concept in more intuitive language and show you how handy it can be.
Side note: a lot of this information came from reading The Well-Grounded Rubyist by David A. Black. This book has a ton of great information and is currently one of my favorite books on Ruby.
The Code
If you’ve written much Ruby, you’ve used these “singleton classes” already without knowing it! First, I’ll show you the code that you’ve probably already written, so you have some context.
You may have also seen it like this:
Up until now, you’ve probably referred to these as “class methods.” You are mostly right. But why do they work? What’s happening here?
Individualization
This is a concept that is central to what makes Ruby so awesome. Individual objects, even of the same class, are different from each other, and they can have different methods defined on them. I’m going to shamelessly use our pets to aid in this example.
Now, when we call smolder on succulent, which we haven’t changed, things go as planned.

But when we call smolder on willy or momo, something different happens!


So, how does this work?  Did we re-define smolder for each pet?  Do me a favor and check out the output of the following:
That’s right! You’re using a singleton method! Now, I think, we’re ready to talk about what a singleton class is.
What is a Singleton Class?
First, a more general programming, less Ruby-specific question: what is a singleton? While there are various definitions that might be more specific for different cases, at its core, a singleton is just something that there is only one of. It is the only one of its kind.
What does that mean in the context of Ruby? Here it is: when you instantiate an object from a class in Ruby, it knows about the methods that its class gives it. It also knows how to look up all of the ancestors to its class. That’s why inheritance works.
“Oh, my class doesn’t have that method? Let’s check its parent class. And that class’s parent class. Etc.”
One of the cool things about Ruby is that the ancestry chain is very unambiguous by design. There is a specific set of rules by which objects search their ancestors, such that there is never any doubt which method gets called.
In addition to knowing about its class, each object is created with a singleton class that it knows about. All the singleton class is is a kind of “ghost class” or, more simply, a bag to hold any methods that are defined only for this particular object. Try this out:
In the inheritance hierarchy, it sits invisibly, just before the objects actual class. However, you can’t see it by looking at the object’s ancestors.
But if we look at the ancestry tree for the singleton class itself:
You can see that it comes in right at the beginning.  Thus, when momo goes to look for the smolder method, it looks first in its singleton class.  Since there is a smolder method there, it calls that one, instead of looking further up the tree to the one defined in the Pet class.
What Does This Have to Do with Class Methods?
Now is when we start to see the power of the singleton class.  Don’t forget that every class is just an object of the class Class.  If that sentence made you start to hyperventilate, don’t worry.  I’ll explain.
And Class is just a class that provides some methods to every instance of it (classes) you create, just like any other class.
So, really, when you’re defining “class methods” that you plan to call directly on the class, what you’re actually doing is defining methods on that particular Class object — in its singleton class!
And… if the singleton class exists, it becomes the parent class to singleton_classes of classes that inherit from the main class. An example should help.
See how Reptile’s singleton class inherits from Pet’s singleton class, and thus the “class methods” available to Pet are also available to Reptile?
Other Tidbits
I think so far, we’ve pretty much covered all of the important bits.  There are, however, a couple more interesting details that I thought were cool that are sort of tangentially related: the somewhat hard to decipher class << self syntax, the different ways of creating class methods, and the use of extend.  Feel free to read on if you’re interested.
Class << self
There are actually two ways to use the class keyword: directly followed by a constant (a la class Gelato), or followed by the “shovel operator” and an object (a la class << momo).  You already know about the first one — it’s the way you usually declare a class!  Let’s focus on the second one, which is the syntax to directly open up an object’s singleton class.  You can think about it as essentially the same as defining methods like we were doing above.
What I mean is this:
You do this all the time when you re-open regular classes to add more functionality.
The syntax class << object; end is just another way of re-opening the object’s singleton class.  The benefit here is that you can define constants and multiple methods all at once instead of one at a time.
It’s a common pattern when adding multiple class methods to a class to see the following:
Maybe you’ve seen this pattern and not known what it is, or maybe you knew it adds class methods but didn’t know what why. Now you know! It’s all thanks to the singleton class!
class << self vs def self.method vs def Pet.method
There are a few different ways to declare class methods.
So what’s the difference?? When do you use one or the other?
The good news is that they’re all basically the same. You can use whichever one makes you the happiest and matches the style of your codebase. The only difference is with #3, and how it deals with constants and scope.
See that the inner_max_pets function has access to the scope inside the Pet class and the constants there?  That’s really the only difference.  Feel free to carry on using your favorite syntax with confidence.
Using Extend to Safely Modify Built-In Classes
Hopefully, at some point, you’ve read a blog post or had someone warn you about the dangers of re-opening built-in Ruby classes. Doing something like the following should be done veeeery carefully.
The dangers include accidentally overwriting built-in methods, having methods clash with other libraries in the same project, and generally making things not behave as expected.  The extend keyword can help with all of that!
What is Extend?
The extend keyword is a lot like include in that it allows you to load functionality into your class/module from other classes/modules.  The difference, however, is that extend puts these methods onto the target object’s singleton class.
Thus, if you use extend inside a class definition instead of include, the methods will get added to the class’s singleton class as class methods instead of being added to the class itself as instance methods.
How Does That Help Us?
So, let’s say that we really needed to have that verbify method on the strings we were using.  While you could create and use a subclass of String, another option would be to extend individual strings!
Cheesy Wrap Up
So remember, singletons aren’t just an intimidating-sounding but not-super-complicated Ruby topic. You are the real singleton — yes, you’re a human, but there’s nobody else quite like you. You’ve got class and your own methods of doing things, and that’s valuable. And now we’ve just added a little more functionality to you.
Author: Ryan Palo | Tags: ruby singleton basics |Like my stuff? Have questions or feedback for me? Want to mentor me or get my help with something? Get in touch! To stay updated, subscribe via RSS