|
"http://www.w3.org/TR/REC-html40/strict.dtd">
This chapter addresses a few practical issues. Statement delimitersSome languages require some kind of punctuation, often a semicolon
( CommentsWhy write comments? Although well written code tends to be self-documenting, it is often helpful to scribble in the margins, and it can be a mistake to believe that others will be able to look at your code and immediately see it the way you do. Besides, for practical purposes, you yourself are a different person within a few days anyway; which of us hasn't gone back to fix or enhance a program after the passage of time and said, I know I wrote this, but what in blazes does it mean? Some experienced programmers will point out, quite correctly, that contradictory or outdated comments can be worse than none at all. Certainly, comments shouldn't be a substitute for readable code; if your code is unclear, it's probably also buggy. You may find that you need to comment more while you are learning ruby, and then less as you become better at expressing your ideas in simple, elegant, readable code. Ruby follows a common scripting convention, which is to use a pound
symbol ( Also, to facilitate large comment blocks, the ruby interpreter also
ignores anything between a line starting with "
Organizing your codeThe ruby interpreter processes code as it reads it. There is nothing like a compilation phase; if something hasn't been read yet, it is simply undefined.
This does not, as it might seem at first glance, force you to organize your code in a strictly bottom-up fashion. When the interpreter encounters a method definition, it can safely include undefined references, as long as you can be sure they will be defined by the time the method is actually invoked:
So while this may seem less convenient than what you may be used to
in Perl or Java, it is less restrictive than trying to write C without
prototypes (which would require you to always maintain a partial
ordering of what references what). Putting top-level code at the
bottom of a source file always works. And even this is less of an
annoyance than it might at first seem. A sensible and painless way to
enforce the behavior you want is to define a
It also helps that ruby provides tools for breaking complicated
programs into readable, reusable, logically related chunks. We have
already seen the use of That's it...This tutorial should be enough to get you started writing programs in Ruby. As further questions arise, you can dig into the reference manual to learn about ruby in more depth. The FAQ and library reference are also important resources. Good luck, and happy coding!
|