Early Stages of a Program
Test first. Use RAD tools. Don't optimize early. There's lots of advice for the early stages of a program.
Today's issue of java.net includes posts on each of these three items. We are featuring a chapter excerpt from Johannes Link's book "Unit Testing in Java How tests drive the code". Publisher Morgan Kaufmann gave us permission to post this pdf excerpt from the book that focuses on test driven development of GUIs. Often GUIs give new TDD developers a tough time. How can you test that a GUI does what it's supposed to do without bringing it up on the screen and playing with it? Johannes presents what he calls "The Direct Way".
This is the first time we've used a pdf of a book excerpt. We weren't sure how to best handle it. We didn't want you to click on a link and find yourself downloading a pdf without warning. We also wanted to give you a chance to provide talkback on the content as you can with every other article. So Sarah and I decided that the HTML would be a small introduction to the article that made it clear that the link is a pdf. If you have suggestions for how we can handle this in the future, feel free to drop me an email at email@example.com .
Today's Weblogs begin with James Gosling's entry Is it ever too early to optimize? James acknowledges that his bias probably stems from having "learned to progam on a machine with only 4K of RAM." Given the availability of cheap RAM and faster machines, we don't always design with enough attention to "cleanliness". He explains
In the "no premature optimization" model of the world, you ignore performance and build your system as cleanly as possible. Then you measure and tune. But after the tuning is done you can still find that the system is slow, but there's no real performance problem that you can localize. It's just a generalized, diffused slowness. A lot of small things spread everywhere that add up.
There are times that you need to consider performance from the start. One example that Gosling offers is "if you were building an editor for 3D models, almost all parts of the application interact with the model data structure. You can do a lot to hide the details, but there's only so much you can hide. If you don't think hard about the data structure right at the beginning of building the application, you're likely to end up with big problems. "
Philip Brittan gives his take on a similar issue in his post RAD Tool Let-down. He writes that RAD tools are appropriate for getting a prototype of an application but that
building the GUI through code does have some big advantages, and, personally, I almost never use a GUI builder for a production application. Here’s why. GUI builders give developers a component-by-component interface onto the window and treat properties as literal values. [...] The GUI builder gives me a really quick way to put the window together but ends up with a pretty brittle design that requires lots of manual labor to make subsequent changes.
Philip also considers the suggestions made in Joshua Marinacci's article, but still wants something "more sophisticated than just setting properties on components." In the talkback you'll find a discussion of some other alternatives with links to projects.
Brett McLaughlin's first blog explains why he Switched .. then switched back .. and then switched again. Brett is currently back using Mac OS X and is enjoying his reunion with his favorite UNIX tools and looking forward to the Panther release.
In Also in Java Today , you'll find a link to my Core Java Tech Tip on Using the TransferHandler.This tip started as an idea suggested in Gosling's blog URLs are your friend. This tip shows you how to modify the drop part of drag and drop with a custom TransferHandler. In the final example, you try to create a URL associated with the dropped item.
We also link to a DevX piece on how to Make your Java Data More Useful with Treemap Visualization. For complex sets of data, you can't just rely on tables or pie charts or bar graphs. Laurence Moroney introduces JTreeMap and shows examples including a link to Smart Money . He also shows you how to create your own tree map.
In Projects and Communities , the JXTA community provides you with a collection of JXTA tutorials to help you get started using the technology. We also feature the JavaPedia page on Frameworks and Libraries . This popular page continues to grow. Add your favorite Frameworks or Libraries or join in the discussion.
In today's java.net News Headlines :
- Apache Newsletter Issue: 2 Published
- JSR-231 - Java Bindings for OpenGL Submitted to JCP
- JSR 232 - Mobile Operational Management Submission
- JSOS 3.60 New Components
- SCOs Threats: Companies, Who Cares?
Registered users can submit news items for the
href="http://today.java.net/today/news/">java.net News Page using our
news submission form.
All submissions go through an editorial review by news director Steve
Mallet before being posted to the site. You can also subscribe to the href="http://today.java.net/pub/q/news_rss?x-ver=1.0">java.net News RSS
Current and upcoming Java Events:
- October 16-21 LISA (17th USENIX Systems Administration Conference)
- October 20-24 UML2003
- October 22-23 I javaHispano Conference
- October 22 Liverpool JUG: technical meeting
- October 26-31 Colorado Software Summit
- October 27-30 O'Reilly Mac OS X Conference
- October 28-29 Sun Tech Days
- October 29 JAIN Technology Day at London Bridge
Registered users can submit event listings for the
href="http://www.java.net/events">java.net Events Page using our
href="http://today.java.net/cs/user/create/e"> events submission form.
All submissions go through an editorial review before being posted to the
This blog is delivered weekdays as the
href="http://today.java.net/pub/q/java_today_rss?x-ver=1.0">Java Today RSS
feed. Once this page is no longer featured as the front page of href="http://today.java.net"> Java Today it will be archived at href="http://today.java.net/today/archive/index_10162003.html">
http://today.java.net/today/archive/index_10162003.html. You can
access other past issues in the href="http://today.java.net/today/archive/">java.net Archive.