method! and method?

G

Gene Angelo

I am trying to find the meaning of ! and ? appended to method names but
I cannot find what they mean. Can someone explain?
 
J

Jesús Gabriel y Galán

I am trying to find the meaning of ! and ? appended to method names but
I cannot find what they mean. Can someone explain?

From the language functionality point of view, they don't mean
anything. They just happen to be valid characters for method names,
and people can use them to give more readability to their code.

The core and stdlib classes, though, typically use ! to denote a
"dangerous" method. For example a method that modifies the receiver or
some side effect. They usually come in pairs with their counterpart
having the same name without the !, and usually it means that they
both do the same task, but the ! version will modify the receiver. See
for example String#gsub and String#gsub!. The ? on the other hand is
typically used when the method is a query method, when calling the
method would be like asking the object something. Things like
Enumerable#include? or Object#equal?

Please take note that these are just conventions of method names. You
will find destructive or dangerous methods without a !, and query
methods without a ?, and possibly the other way around.

Jesus.
 
B

Brian Candler

Gene said:
I am trying to find the meaning of ! and ? appended to method names but
I cannot find what they mean. Can someone explain?

They don't mean anything - they are just part of the name. That is, in

str.downcase!

the method you are calling is called :downcase! - which is a distinct
method to :downcase

However, there are conventions as to when they should be used. Methods
ending ? typically query the properties of some object and return a
boolean-like result, while methods ending ! are "dangerous" in some way,
such as modifying the state of the object when a non-modifying
alternative method is available.
 
J

Jörg W Mittag

Gene said:
I am trying to find the meaning of ! and ? appended to method names but
I cannot find what they mean. Can someone explain?

They aren't appended to the method name. They are part of the method
name. A method ending in '!' or '?' means pretty much the same as a
method name ending in 'a' or 'z': it means whatever the author of that
method wants it to mean.

There is a convention, however: a method name ending in '?' usually
indicates a method that returns either a truthy or a falsy value. For
example, take the `Integer#even?` method. An integer is either even or
it's not. Or `Array#empty?`, `Numeric#zero?`, `Time#thursday?`: an
array is either empty or not, a number is either zero or not, a
specific date is either a thursday or not.

For a method name ending in '!', the convention is the following: if
there are two methods that both perform the same operation, but in a
slightly different way, then they both get the same name, but the one
which is more "surprising" gets an exclamation point appended. For
eample: `String#downcase` downcases as string. It returns a new
downcased string, but leaves the original untouched.
`String#downcase!` *also* downcases a string, but *it* destroys the
original string and *replaces* it with a downcased version.

jwm
 

Ask a Question

Want to reply to this thread or ask your own question?

You'll need to choose a username for the site, which only take a couple of moments. After that, you can post your question and our members will help you out.

Ask a Question

Members online

No members online now.

Forum statistics

Threads
474,145
Messages
2,570,826
Members
47,371
Latest member
Brkaa

Latest Threads

Top