Ruby extend Method
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.
Basic extend Example
This simple example demonstrates how to extend an object with module methods. The methods become available on that specific object only.
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.
Extending Class Objects
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.
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 Module Extension
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.
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.
Extending Inside Classes
The extend method can be used inside class definitions to add
module methods to the class object itself. This is different from include.
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.
Dynamic Extension
Objects can be extended dynamically at runtime. This allows for flexible object behavior modification based on program conditions.
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.
Extending Core Objects
Ruby's core objects can be extended with custom methods. This should be done judiciously to avoid conflicts and confusion.
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.
Extend vs Include
This example contrasts extend and include to clarify
their different behaviors. They serve related but distinct purposes.
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.
Source
Ruby Module#extend Documentation
This tutorial covered Ruby's extend method with practical examples showing object extension, class methods, and dynamic behavior modification.
Author
List all Ruby tutorials.