Symbols and strings

Hi,
as a long-term perl user just recently converted to ruby, I'm curious
about one particular syntax "feature": ruby symbols and how they
relate to strings.

Isn't really :name a shortcut for "name"? (I read somewhere in an
explanation of attr_reader that e.g :age was the "name" of the
variable age, while age is the actual content of that variable). If
so, couldn't you use this in hash keys as well, e.g say hashvar[:key]
instead of hashvar['key'].

Are there situations where you cannot use symbols instead of strings,
or the other way around?

I might be too used to the way strings and barewords are handled in
perl (if something looks like a string, and it's not a function call,
it's interpreted as a string. This means you can say $hashvar{key}
without quoting the key).

This question is asked very frequently, please search the archives for
more info.
I will try to give a very quick answer nevertheless:

Symbols are immutable, thus great to represent immutable data, often
that makes them an excellent choice for hash keys
{ :the_value => 42, :alternatively => 22, :or_even => 101010 }
they just do not play the role of Strings, coming from Perl you just
had to use Strings, you did not have a tool for names (wait a moment
was there not such a thing as references to constants?).
Very roughly put I see Symbols as name, and Strings as data, whenever
I can use Symbols I use them, comes natural after some time.

HTH
Robert

···

On 8/14/07, maghac <magnus.hacker@gmail.com> wrote:

Hi,
as a long-term perl user just recently converted to ruby, I'm curious
about one particular syntax "feature": ruby symbols and how they
relate to strings.

Isn't really :name a shortcut for "name"? (I read somewhere in an
explanation of attr_reader that e.g :age was the "name" of the
variable age, while age is the actual content of that variable). If
so, couldn't you use this in hash keys as well, e.g say hashvar[:key]
instead of hashvar['key'].

Are there situations where you cannot use symbols instead of strings,
or the other way around?

I might be too used to the way strings and barewords are handled in
perl (if something looks like a string, and it's not a function call,
it's interpreted as a string. This means you can say $hashvar{key}
without quoting the key).

--
[...] as simple as possible, but no simpler.
-- Attributed to Albert Einstein

Alle martedì 14 agosto 2007, maghac ha scritto:

Hi,
as a long-term perl user just recently converted to ruby, I'm curious
about one particular syntax "feature": ruby symbols and how they
relate to strings.

Isn't really :name a shortcut for "name"? (I read somewhere in an
explanation of attr_reader that e.g :age was the "name" of the
variable age, while age is the actual content of that variable). If
so, couldn't you use this in hash keys as well, e.g say hashvar[:key]
instead of hashvar['key'].

Are there situations where you cannot use symbols instead of strings,
or the other way around?

I might be too used to the way strings and barewords are handled in
perl (if something looks like a string, and it's not a function call,
it's interpreted as a string. This means you can say $hashvar{key}
without quoting the key).

Symbols and strings are two different things. There are several situations in
which you can pass a method either a symbol or a string, but this happens
because who wrote the method took into account both possibilities. For
instance, attr_reader and similar, send, instance_variable_get and
instance_variable_set, define_method can take both a string or a symbol.
Module#const_get, instead, only accepts a symbol.

You can see that string and symbols are different using hashes:

h = { :a => 1}
puts h[:a]
=> 1
puts h['a']
=> nil
h['a'] = 2
puts h['a']
=> 2
puts h[:a]
=> 1

There have been several threads on this topic. I suggest you look at them.

I hope this helps

Stefano

Thanks, that cleared a few things for me.

I found something in the FAQ about it, but it didn't really answer my
question on the differences/similiarities between symbols and strings.

thanks
Magnus

···

On Aug 14, 11:11 am, "Robert Dober" <robert.do...@gmail.com> wrote:

On 8/14/07, maghac <magnus.hac...@gmail.com> wrote:

> Hi,
> as a long-term perl user just recently converted to ruby, I'm curious
> about one particular syntax "feature": ruby symbols and how they
> relate to strings.

> Isn't really :name a shortcut for "name"? (I read somewhere in an
> explanation of attr_reader that e.g :age was the "name" of the
> variable age, while age is the actual content of that variable). If
> so, couldn't you use this in hash keys as well, e.g say hashvar[:key]
> instead of hashvar['key'].

> Are there situations where you cannot use symbols instead of strings,
> or the other way around?

> I might be too used to the way strings and barewords are handled in
> perl (if something looks like a string, and it's not a function call,
> it's interpreted as a string. This means you can say $hashvar{key}
> without quoting the key).

This question is asked very frequently, please search the archives for
more info.
I will try to give a very quick answer nevertheless:

Symbols are immutable, thus great to represent immutable data, often
that makes them an excellent choice for hash keys
{ :the_value => 42, :alternatively => 22, :or_even => 101010 }
they just do not play the role of Strings, coming from Perl you just
had to use Strings, you did not have a tool for names (wait a moment
was there not such a thing as references to constants?).
Very roughly put I see Symbols as name, and Strings as data, whenever
I can use Symbols I use them, comes natural after some time.

HTH
Robert
--
[...] as simple as possible, but no simpler.
-- Attributed to Albert Einstein

maghac wrote:

  

Hi,
as a long-term perl user just recently converted to ruby, I'm curious
about one particular syntax "feature": ruby symbols and how they
relate to strings.
      Isn't really :name a shortcut for "name"? (I read somewhere in an
explanation of attr_reader that e.g :age was the "name" of the
variable age, while age is the actual content of that variable). If
so, couldn't you use this in hash keys as well, e.g say hashvar[:key]
instead of hashvar['key'].
      Are there situations where you cannot use symbols instead of strings,
or the other way around?
      I might be too used to the way strings and barewords are handled in
perl (if something looks like a string, and it's not a function call,
it's interpreted as a string. This means you can say $hashvar{key}
without quoting the key).
      

This question is asked very frequently, please search the archives for
more info.
I will try to give a very quick answer nevertheless:

Symbols are immutable, thus great to represent immutable data, often
that makes them an excellent choice for hash keys
{ :the_value => 42, :alternatively => 22, :or_even => 101010 }
they just do not play the role of Strings, coming from Perl you just
had to use Strings, you did not have a tool for names (wait a moment
was there not such a thing as references to constants?).
Very roughly put I see Symbols as name, and Strings as data, whenever
I can use Symbols I use them, comes natural after some time.

HTH
Robert
--
[...] as simple as possible, but no simpler.
-- Attributed to Albert Einstein
    
Thanks, that cleared a few things for me.

I found something in the FAQ about it, but it didn't really answer my
question on the differences/similiarities between symbols and strings.

thanks
Magnus

Don't make more out of this than there is. A symbol is a kind of literal in Ruby. It's the name of a number. You pick the name, Ruby picks the number. Ruby guarantees that whenever you use the symbol in your program it will always refer to the same number.

That's it. That's all there is. Really.

Given a symbol, you can retrieve its name in the form of a string with the #to_s method. You can convert a string (or almost any sequence of characters, for that matter) to a symbol with the #to_sym method. Most methods that accept symbol arguments, like attr_reader and kin, accept strings as well. All attr_reader does with your symbol is use its name as the name of the attribute.

···

On Aug 14, 11:11 am, "Robert Dober" <robert.do...@gmail.com> wrote:

On 8/14/07, maghac <magnus.hac...@gmail.com> wrote:

--
RMagick OS X Installer [http://rubyforge.org/projects/rmagick/\]
RMagick Hints & Tips [http://rubyforge.org/forum/forum.php?forum_id=1618\]
RMagick Installation FAQ [http://rmagick.rubyforge.org/install-faq.html\]

Tim Hunter wrote:

Don't make more out of this than there is. A symbol is a kind of literal
in Ruby. It's the name of a number. You pick the name, Ruby picks the
number. Ruby guarantees that whenever you use the symbol in your program
it will always refer to the same number.

:foo.object_id == :foo.object_id

So if you add a method to one :foo, can anyone who invokes :foo access
the method?

···

--
Phlip
Test Driven Ajax (on Rails) [Book]
^ assert_xpath
O'Reilly Media - Technology and Business Training <-- assert_latest Model

Hi --

···

On Tue, 14 Aug 2007, Phlip wrote:

Tim Hunter wrote:

Don't make more out of this than there is. A symbol is a kind of literal
in Ruby. It's the name of a number. You pick the name, Ruby picks the
number. Ruby guarantees that whenever you use the symbol in your program
it will always refer to the same number.

:foo.object_id == :foo.object_id

So if you add a method to one :foo, can anyone who invokes :foo access
the method?

$ ruby -ve 'class << :abc; end'
ruby 1.8.6 (2007-03-13 patchlevel 0) [i686-darwin8.9.1]
-e:1: no virtual class for Symbol (TypeError)

David

--
* Books:
   RAILS ROUTING (new! http://www.awprofessional.com/title/0321509242\)
   RUBY FOR RAILS (http://www.manning.com/black\)
* Ruby/Rails training
     & consulting: Ruby Power and Light, LLC (http://www.rubypal.com)