Access Control in Ruby
Ruby gives you three levels of access protection, public, protected and private. The public methods can be called by anyone. In this article, we will look at some examples to learn about the access control and the subtle difference between private and protected access control.
class Foo def testing_public end protected def testing_protected end private def testing_private end def ok testing_public testing_protected testing_private end end f = Foo.new f.ok
This will throw the exception.
NoMethodError: private method ‘ok’ called for Foo.
Only the public method can be called outside the Foo class.
f = Foo.new f.testing_public
will work. The methods
testing_private will not work.
Difference between Private and Protected
The difference between private and protected can be demonstrated using the example below. The Foo class remains the same as shown above.
class Bar < Foo def do_something(parent) parent.testing_public parent.testing_protected parent.testing_private end end b = Bar.new b.do_something(Foo.new)
We can call the protected method but we cannot call the private method. We will get the error:
NoMethodError: private method ‘testing_private’ called for Foo.
This article is based on the blog post by Aaron Patterson.
Watch this Article as ScreencastYou can watch this as a screencast Access Control in Ruby
Software Compatibility Best Practices
I spoke to some of the most talented and experienced software developers. I have created a guide that is filled with valuable insights and actionable ideas to boost developer productivity.
You will gain a better understanding of what's working well for other developers and how they address the software compatibility problems.