DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> AJAX入門 >> AJAX詳解 >> Ruby and Subversion
Ruby and Subversion
編輯:AJAX詳解     

Feedback on "Ten Things a Java Programmer Should Know About Ruby"

This is a compilation of feedback I received for a list of things Java programmers should be aware of when looking at Ruby. This list is not the final version, nor are all (most) of the ideas in this list mine. This is merely a temporarty holding spot for these ideas while I assemble a talk/article/presentation on the topic.

If you have a problem with anything on this list, please bring it up with the person who made the suggestion (i.e. not me!)

However, if you have further suggestions for this list, feel free to drop me a note at jim@weirichhouse.org.

bullet Boolean methods end in ?. Dangerous methods end in ! bullet you can fit in your mind and write code without looking at the docs every six minutes bullet less syntax and less typing bullet Discipline. Because of its inherent flexibility, Ruby require more self-discipline bullet "." (dot) is a method call operator. "::" (colon-colon) is a scope Operator. bullet Ruby classes are Objects (therefore String.new, not new String()) bullet Everything is an Object bullet Ruby does not have type casting. bullet Compared to Java, XML is agile. Compared to Ruby, XML is Heavy. bullet Ruby has O/R mappers, so find your Ruby "hibernate", but drop any preconceptions. bullet Don't worry about early performance optimization bullet Enjoy closures and blocks bullet No method overloading bullet Don't worry about interfaces, enjoy Duck Typing. bullet Reflection in Ruby is much easIEr than in Java, and more deeply into the language than the Java.lang.reflect tack-on. bullet That you can write Ruby in Java (http://jruby.sourceforge.Net) bullet Everything is an expression. bullet local_variable, @instance_variable, $global_variable, Constants, (and @@class_variables) bullet Java static methods do not (quite) translate to Ruby class methods. bullet you can have variable number of parameters, and multiple return values bullet Ruby is not a Silver Bullet, unlike Java, right? :-) bullet Ruby is a language to be used everywhere. You use it even in templates. No need for "Velocity/JSP." bullet Web-development is possible with other languages besides Java. bullet Many things that you're used to thinking of as syntax are now just bullet Ruby is strongly typed, not statically typed bullet Ruby has extensive reflection capabilitIEs bullet Ruby is dynamic. You can add, remove and modify objects, classes and methods at runtime. bullet REXML vs. JAXP. I rest my case. bullet KISS bullet Think in terms of methods (behaviors) instead of classes. bullet you cannot rely on the compiler to catch trivial mistakes bullet No explicit types. Probably the most disconcerting thing for a Javahead bullet ruby has shortcuts for Accessor methods which reduces alot of redundant coding in Java bullet you can use string interpolation, ex: "x: #{@myvar}" instead of having to say "x:" + myvar' bullet no semi-colons, optional parenthesis bullet Ruby classes are always "open". bullet C extensions/wrappers are *much* easIEr in Ruby than JNI interfaces in Java bullet Ruby has MVC and OO programming and librarIEs, but drop any preconceptions. bullet In Ruby data is strongly typed, but variables are *not* bullet Once you start coding Ruby, going back to Java is painful. bullet CamelCase for class names, names_with_underscores for methods and variables. bullet stop writing so much code bullet ri is your friend. irb is your other frIEnd. bullet eval bullet the builtin classes are much faster because they're written in C and not Ruby bullet Avoid external utility classes bullet Use class methods to define pseudo-compile directives bullet You probably don't need FactorIEs bullet Enumerable is your frIEnd bullet Typing is the enemy bullet No external configuration files bullet method_missing bullet Singleton methods bullet Ruby packaging vs Java packaging bullet ruby has multiple inheritance through mixins (this is sooo nice to have) bullet writing code in ruby, can improve the code you write in Java bullet Ruby is agile, perfectly suited for XP bullet Ruby's OO is message based. bullet Fixed what's wrong with Perl bullet Fixes what's wrong with Python bullet It's super productive (like Perl, Python and Smalltalk)- maybe 5-10x Java. bullet Is a lot like Smalltalk, but doesn't look as funny bullet Is a lot like JavaScript, but more OO and more for ful app development bullet Blocks and Closures bullet Open Classes bullet Duck Typing bullet "finally" is called "ensure" bullet Use blocks for transactional behavior like like File.open does. bullet Help at: http://ruby-lang.org/en, http://ruby-doc.org/, news:comp.lang.ruby, irc:ruby-talk bullet An instance of a class can be extended to be subtly different, without needing to subclass. bullet you can change your mind about whether .foo is a simple property or a complex method call, without affecting the interface to your class. bullet HEREDOC strings with variable interpolation make large chunks of output really easy to construct. bullet For good (but subtle) reasons, you have to leave the '++' and '--' behind.

Top 10 Things I Like About Subversion

I've been using Subversion for over two months as my repository on a project at work and I've recently transitioned all of my personal projects on my Powerbook from CVS to Subversion. I'm really digging Subversion and can't imagine or remember what it was like before I found it.

I wrote this up a few days ago for a meeting at work and thought I'd share it with everyone in blogspace. In no particular order, here are the top 10 things I like about Subversion:

  1. Atomic Commits: It's all or nothing! If even one file out of 100 has troubles, then nothing gets committed. My repository is never in an inconsistent state.
  2. Tools Support: If you don't like the command line (and I do), then you have Tortoise. But since I'm an Eclipse user, I tend to enjoy Subclipse (I've read several people who say that Subclipse has problems, but I've had nothing but success with it for over two months).
  3. Hooks: Automatically kick off a build, fire an e-mail, or update my issue tracking system...just by committing some files.
  4. Web-browsable Repository: Without having to do much additional setup (other than apache), I get to browse my repository via my favorite web-browser.
  5. Easy branching/tagging/merging: I create a new tag or branch by simply making a logical copy in the repository. Couldn't be smoother.
  6. EfficIEnt handling of binary files: It's my understanding that binary files are stored based on binary diffs to be more efficIEnt.
  7. Everything is versioned: Even directorIEs and meta-data.
  8. Externals: I haven't had the privilege of using externals yet, but they sound darn cool. Check out a project and all other projects that it depends on all at once.
  9. Concurrent versioning: Just like CVS. I don't have to lock something before I can commit changes.
  10. Easy refactoring: I can rename a file or repackage a class and Subversion's smart enough to keep keep the file's history.

And for an eleventh thing that I like: I've got an Excellent Subversion book to help me out.

XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved