Want to read Slashdot from your mobile device? Point it at m.slashdot.org and keep reading!

 



Forgot your password?
typodupeerror
×
Java Programming

Sun's Joshua Bloch On OOP/OOD In Java 28

f00zbll writes: "A good article about development and OOP/OOD. The lessons apply to most OO languages and OOD. Interview with Joshua Bloch over at Javaworld. Ignore the fact that Java is owned by Sun and use the tips to help your work/project/development."
This discussion has been archived. No new comments can be posted.

Sun's Joshua Bloch On OOP/OOD In Java

Comments Filter:
  • Bloch: "Precisely. In fact, people who try to "do the quickest slop you can throw down" often take longer to produce a working system than people who carefully design the components. But certainly, API design helps if you consider cost over time".

    This is one of the most common fights between us (developers) and management. Often managers are only interested on the fastest route, without considering the maintenance costs down the road.

    I'll be emaling my manager a link to this story (anonimously, of course. I want to keep my job ;-)

    John

    • The fact that you aren't prepared to stand up to your manager is the first sign of a problem. You have to make management understand that you are (I assume) a professional. Development or (hopefully) software engineering is your career, for which you are educated, and that in such areas management does NOT have the required knowledge to act.

      In no other technical profession can management dictate HOW the job should be achieved. They can set budgets and deadlines, and assist in planning, but they do not have the liberty to force a domain expert to act in a certain way.

      This needs to be made more clear to software managers. Software is difficult to write and to maintain. Even though most contracts seem watertight, there is an element of liability implicit in the sale of custom-developed software, which makes YOUR organisation responsible. And as the software engineer someone is going to shit on YOUR head when things go wrong ... not the manager's.

  • by wayn3 ( 147985 ) on Monday January 21, 2002 @11:03AM (#2876338)
    The trouble with these kinds of interviews is that although I appreciate and enjoy Mr. Bloch's contributions to Java and Mr. Venners' forum, they are speaking academicly and not through the world of business. This is a very narrowly focused article and should not be taken as direction for designing software.

    I'd like to hear someone write about how to make the trade-offs architects really face:
    • being forced to use lesser software products and tools due to cost or partnership arrangements;
    • having time-to-market be a larger issue than software reuse
    • attempting design and development when the skill set is diverse

    These topics would be of greater value to the development community than articles which presume hypothetical arrangements.
    • by cwinters ( 879 )

      Did you read the same article I did? Designing robust APIs, decomposing modules and interfaces into simple and testable pieces, defensive programming are all hallmarks of high quality large-scale systems. Articles addressing your concerns have a place -- hey, maybe you could write one! -- but this article is clearly meant for a different audience.

      Chris

    • by jilles ( 20976 ) on Monday January 21, 2002 @01:53PM (#2877391) Homepage
      Time to market these days means being able to reuse and adapt the previous product's software as quickly as possible. A good design is essential for that and companies that don't do good design are outcompeted by companies who manage to produce better quality software in a shorter timeframe.

      The reality of today is that software systems are very large (think millions of lines of code) that represent an investment of many manyears. A quick fix on such code can have a desastrous impact on the time to market of future products. I know of companies that effectively did not bring out new products for two years because they were busy redesigning their software in order to be able to meet future requirements(Netscape is a good example in the public domain).

      One of the reasons Java is currently so successful and has seen a quicker time to market than .Net (which has yet to come to market) is good design. Sun spent a great deal of time thinking about security and flexibility as early as 1995. This investment has allowed Java to mature well before MS managed to get anything significant to market. SUN is actively working with industry partners in its much criticized JCP process. MS on the other hand is dictating standards. MS gets its standards out quicker but the ones that get through the JCP process are of such a quality that they are causing MS some very big headaches in for example the mobile applications domain.

      I am from the academic world and (pretty rare for an acadamic) I frequently visit software developing companies to gather information for my research. The more successful of these companies invariably have very clever software designers in charge of the software development. Also these companies are very much aware that the quality of their software is their competitive edge.
      • Time to market these days means being able to reuse and adapt the previous product's software as quickly as possible.
        Partly. This is "external reuse", where a software component is used on multiple projects. However, "internal reuse" is equally important, where a component (function, data structure, class, whatever) is used multiple times in the same project. This has two advantages:
        1. Less development time, because you're re-using code you have already written.
        2. Less debugging time, because every defect you correct in a shared piece of code fixes several bugs.
        In this way, software components are opposite to mechanical devices: the more they are used, the more reliable they become.
        • I don't see how you could develop without doing internal reuse these days. However, the distinction between internal and external is fading anyway.

          The days that you could start from scratch for a each new product are gone. Many companies are currently finding out the hard way that the cost of that is too much. Take Nokia for example. They produce around 30 or so different mobile phones each year. Each of these phones contains a few million lines of code in software. Obviously, Nokia does not start from scratch for each new phone. Rather they taylor and extend their previous generation software and use it in the next generation phone. The better the design of the old software the easier it is to add new features. Getting new features out a few months before the competitor is critical in the mobile phone industry (one of the reasons Ericsson is having so much trouble).

          The type of blackboard reuse you are talking about is very hard to achieve. Basically COTS is a myth except for some generic GUI components and low level stuff like XML parsing. The problem is that creating a reusable component requires knowledge in advance of the requirements it needs to meet. Something every software developer knows is that unexpected requirements will pop up. Hence you will find yourself editing your carefully designed components after some time. Especially when you use your old components in a new product you will find that the requirements are different and that your components do not match 100% in the new situation.

          This is why you need a good design: to limit the impact of these inevitable changes.
        • In this way, software components are opposite to mechanical devices: the more they are used, the more reliable they become.


          Also, a reliable machine is composed of many duplicate, individually tested components. A well-factored software system does not contain any (or much) redudant or duplicate code!
      • Time to market these days means being able to reuse and adapt the previous product's software as quickly as possible. A good design is essential for that and companies that don't do good design are outcompeted by companies who manage to produce better quality software in a shorter timeframe.

        Great theory. Unfortunately, you forgot that the company who does the quick but not reuseable work gets to market first. If they get there "first enough", the competition are already toast. All the reusability in the world doesn't mean jack if your company has already lost 95% market share to a rival who released 6 months earlier.

        I am a great believer in the fact that "quality is free" -- doing a proper job of things like initial design and documentation more than pays for itself in the long run. However, it's important to do all things in moderation. Remember the old rule that it's only reuseable if it's useable in the first place. There is no point overengineering an initial solution for reuse if you're not going to meet your first set of requirements, which normally includes getting to market within a competitive timeframe. If an initial design isn't up to that, is it really a good design at all?

        One of the reasons Java is currently so successful and has seen a quicker time to market than .Net (which has yet to come to market) is good design.

        Well, that and a few years' headstart, anyway. :-)

    • Perhaps a good related article would be, "how to negotiate with your PM or CTO." Even if one is forced to use lesser tools, some of tips do apply. One in particular was:

      They do advocate leaving out the bells, whistles, and features you don't need and add them later, if a real need is demonstrated. And that's incredibly important, because you can always add a feature, but you can never take it out. Once a feature is there, you can't say, sorry, we screwed up, we want to take it out because other code now depends on it. People will scream. So, when in doubt, leave it out.

      I know that sometimes I am tempted to add x feature to the interface/code, because I think in 2 months the need for it will arise. Sometimes what I predict doesn't pan out. The lessons Joshua relates is very applicable in every day programming. Even if you use functional languages, the same challenges are there and the lessons can be beneficial. It's not always going to be useful, but it can be. It's up to each developer to make the effort. Sometimes you have no choice, but when you do have time, it's worth the trouble to take a minute to think a design/API through.

    • Mr. Bloch is obviously familliar with the world of commercial development seeing he worked for SUN. I think what he has to say is very relevant. My brother has read his book and said it was great. Chris Sells from Developmentor [sellsbrothers.com] also said it was good, reccomending it to C# programmers. Although the issues you mention are also relevant to software development I think what Mr. Bloch is talking about goes to the very core of what is required for good software development.
    • "having time-to-market be a larger issue than software reuse"

      how about a constraint called time-to-version-2.0? The real race happens then, when market expectations and wishes are more apparent.
    • tell that to Netscape.
    • OK, what can you really say about these issues?

      So you do the best with what you can, and it either works or it doesn't, and you make money or you don't, or you stay in business or go out of business.

      If you want to talk about business reality, that's business reality. The dot com boom and the dot com bust are business reality. Incredible hype about Enron followed by its bankruptcy are business reality. The recession is business reality, and so is prosperity. And sometimes business reality is producing crap software that is full of holes.

      You have your compromise already. You work like hell and design well and find out that for all that people in business talk about profit for the company, it all turns out to be the color of their parachute. Then you figure this out and either cheat like all the rest or else you get into a position where you are allowed to write good software, which is almost never software that is sold, unless it's a game or industrial control software. What other kind of compromise were you expecting?

      You can do things properly, or you can do them improperly. When you do them improperly they fail more often. You can pile up good, solid business reasons why you have to do things improperly, and I don't care what color your power tie or how earnest and "forward-looking" you are, or how many inspirational posters you have, doing things improperly leads to failure.

      Any veteran of business software development would know these things and, if honest, would have to write about them. Then people wouldn't like it, and they'd mod it down or not buy the book or tell the author he's an asshole because they want to hear that there's a magic incantation that turns mediocrity into gold. They want to hear about Extreme Programming or The Latest New Buzzword that Embraces Change! The newer the better. Old ideas are annoying, because you've already had time to find out that they don't magically work, while there's always the chance that the latest and greatest will make everything OK and nobody will have to get nailed to a tree.

    • I have no idea why you say this is academic. You may have heard of Josh Bloch's company, the one he is paid to write APIs for. It's called Sun. Sun are very serious about business and not about being academics.


      I consider Josh Bloch's book on Java (Effective Java) to be the best language-specific book on architecture and software engineering I have read. The format is based on Meyer's highly acclaimed Effective C++. Venner's own books are clearly based heavily on his own decades of experience and yet he sees in Bloch's wisdom something which makes software work better for the programmers who have to continue to build it. Also, Gosling, Java's creator says Bloch's book is the only book on Java which he needs. Of course they both work for sun, but there are plenty of other useful books put out by Sun which he could have acclaimed.


      Incidently your point is well taken about the sorts of topics you would like to read about. Those topics are linked directly off Venner's site [artima.com] because he writes about them all the time, including in Java World. Venner's article talks about the monkeys on the back of the software developer. The Biggest monkey is the time-to-market deadline moneky.


      In my view, time to market is important, but it can't possibly be more important than the fact that when you get to the market, you'd better have something worth selling.

    • OK, in order:

      • So your boss chooses a tool because he's buddies with the guy who made the sale... ahem... sorry, 'partnership' arrangement: If it's a language, the techniques and recommendations Mr. Bloch makes become that much more important. Why? Because, in your spare time, you accidentally replace that Visual Cobol (eccchhh) component with Java or Python or.... "It was purely by accident, boss, honest... but look how much more/better it does!" Separation of concerns allows you to upgrade components of the application as you go (granted this is significantly more difficult in a product offering than a business application). Separation of concerns also means easier debugging so you have less work to do in substandard tools. If it's not a language, no problem, tell your boss that you're using the Linux emulator that came with Windows...
      • "Mr. Application Builder, sir, we've changed our business, effective yesterday. You can make the app. do that today, right?" Flexible, extensible, composable code shortens time-to-market. You spend less time debugging (as referenced above), less time writing code (after the first time, admittedly), and when the business changes you don't have to worry about brittle or tangled code breaking when you extend it.
      • "Diverse skills" huh? Do you mean the people on your team have MS Word on their résumés? If you're in charge, you need to teach them. Start by learning and understanding design and analysis patterns. Embed these in your code, point them out to your team members. Communicate in models (UML), and walk your team through the process you use to create them. Do code reviews. It doesn't have to be a review of every line in the application. Pick some code you think is high quality, examine it with the team and show them why you think so. Pick some code you know is low quality, point out the reasons why, have the team suggest ways to improve it and then have them fix it.

      Creating code that can't be reused in similar contexts is like filing down a block of metal every time you need a screwdriver. It's silly. Good code is like a craftsman's favorite set of tools, it can be used in many ways to make customers happy. The recommendations of Mr. Bloch expose how experts in the craft of software construction think about and do their work.

  • Auhhh :-) (Score:3, Interesting)

    by sinserve ( 455889 ) on Monday January 21, 2002 @01:25PM (#2877194)
    This guy just gave me the encouragement I needed.

    As a /standalone/ programmer/designer/analyst, I
    developed this API design philosphy on my own.
    Actually, I have evolved to it.

    If you are in a one-mans shop, or do alot of coding
    for a specific domain, try to roll out your own
    layer of helper APIs on top of the system provided ones.

    I work on win32 and ODBC: I have my own class
    hierchies of *standard* dialogs for DB applications.
    Ex: the ActiveX components for DB Appz (advanced
    list views, financial stats, bar charts and graphs, etc.)
    are really resource greedy (the updating required
    for a dynaset database connection, with millions
    of records being fetched per minute is very
    expensive.)
    So I wrote some ready to run classes, that take
    care of the interface (with all the company logos
    and standard look-and-feel stuff.)
    then wrote some other classes to wrap around the
    "CResultView" classes, and finally,
    wrote some classes that *know* about our strange
    servers, and are optimized for them (including
    a connection "language" I derived, which is nothing
    more than a hand optimization of the subset of
    SQL accepted by oracle.)

    So, if the shop is good to you, be good to them
    and put your talent to work.
    The API method works, and I am a living witness for it.
  • here [artima.com] [www.artima.com]. It's a 12 part continuation of the JavaWorld article.

    Topics include how much subclasses should be "trusted", immutables, reasons for disallowing inheritance, copy v. cloning, factory methods versus constructors, and more.

I don't want to be young again, I just don't want to get any older.

Working...