Ruby extend tutorial explains how to use the extend method to add module functionality to objects.
last modified April 27, 2025
This tutorial explains how to use Ruby’s extend method to add module functionality to objects. The extend method is a powerful way to mix in module methods at the object level.
The extend method adds module methods to the receiver’s singleton class. Unlike include, which affects instances, extend works on individual objects. This allows for flexible object augmentation.
Extended methods become available as instance methods on the extended object. This technique is useful for adding functionality to specific objects without affecting their class. Multiple modules can be extended in sequence.
This simple example demonstrates how to extend an object with module methods. The methods become available on that specific object only.
basic_extend.rb
module Greeter def greet “Hello from #{self}” end end
obj = Object.new obj.extend(Greeter)
puts obj.greet
The extend method adds Greeter module methods to obj. Now obj can call greet even though its class doesn’t include this method. Other objects of the same class won’t have this method.
Since classes are objects in Ruby, we can extend them with module methods. This makes the methods available as class methods rather than instance methods.
extend_class.rb
module ClassMethods def class_info “Class name: #{name}” end end
class MyClass extend ClassMethods end
puts MyClass.class_info
Here extend adds class_info as a class method to MyClass. This is a common pattern for adding class-level functionality. The method becomes available on the class itself.
Multiple modules can be extended onto an object. The methods are added in the order they’re extended, with later modules taking precedence in case of conflicts.
multiple_modules.rb
module A def identify “From module A” end end
module B def identify “From module B” end end
obj = Object.new obj.extend(A, B)
puts obj.identify
The output shows B’s version of identify because it was extended last. The order of extension matters when methods have the same name. This demonstrates method lookup precedence.
The extend method can be used inside class definitions to add module methods to the class object itself. This is different from include.
class_extension.rb
module InstanceMethods def instance_identify “Instance method” end end
module ClassMethods def class_identify “Class method” end end
class MyClass include InstanceMethods extend ClassMethods end
puts MyClass.class_identify puts MyClass.new.instance_identify
This example shows the difference between include and extend. include adds instance methods, while extend adds class methods. Both are useful in different scenarios.
Objects can be extended dynamically at runtime. This allows for flexible object behavior modification based on program conditions.
dynamic_extension.rb
module AdminFeatures def admin_action “Performing admin action” end end
module UserFeatures def user_action “Performing user action” end end
class User attr_accessor :role end
user = User.new user.role = :admin
user.extend(AdminFeatures) if user.role == :admin user.extend(UserFeatures) if user.role == :user
puts user.admin_action if user.role == :admin
The user object is extended with different modules based on its role. This pattern enables role-specific functionality without subclassing. The methods only exist on objects that need them.
Ruby’s core objects can be extended with custom methods. This should be done judiciously to avoid conflicts and confusion.
core_extension.rb
module StringExtensions def shout upcase + “!” end end
str = “hello world” str.extend(StringExtensions)
puts str.shout puts “another string”.respond_to?(:shout) # false
Only the specific str object gets the shout method. Other strings remain unaffected. This is safer than monkey-patching the String class directly. It limits the scope of changes.
This example contrasts extend and include to clarify their different behaviors. They serve related but distinct purposes.
extend_vs_include.rb
module SharedMethods def identify “From SharedMethods” end end
class ExtendedClass extend SharedMethods end
class IncludedClass include SharedMethods end
puts ExtendedClass.identify puts IncludedClass.new.identify
ExtendedClass gets identify as a class method, while IncludedClass gets it as an instance method. This demonstrates the key difference between these two approaches to mixing in module functionality.
Ruby Module#extend Documentation
This tutorial covered Ruby’s extend method with practical examples showing object extension, class methods, and dynamic behavior modification.
My name is Jan Bodnar, and I am a passionate programmer with extensive programming experience. I have been writing programming articles since 2007. To date, I have authored over 1,400 articles and 8 e-books. I possess more than ten years of experience in teaching programming.
List all Ruby tutorials.