TweetFollow Us on Twitter

March 92 - Book Review - Developing Object-Oriented Software for the Mac

Book Review - Developing Object-Oriented Software for the Mac

Tom Becker

Developing Object-Oriented Software for the Macintosh
Neal Goldstein and Jeff Alger
Addison-Wesley, January, 1992
347 pages

Neal Goldstein and Jeff Alger have taken something complex and difficult-software engineering-and made it accessible and useful. Their book, Developing Object-Oriented Software for the Macintosh (DOOSM), and its methodology, Solution Based Modeling (SBM), shows a thorough understanding of the problems in developing software and the software engineering technology that can be applied to those problems.

SBM has a well designed graphic interface, called Visual Design Language (VDL). Most important, SBM is designed around the way people think. This is a real breakthrough. Of all the methodologies I've seen, SBM is the first practical one; it has a chance to improve how programmers do their work.

THE MACINTOSH AND SOFTWARE ENGINEERING

Software development methodologies tend to focus on difficult tasks like analysis and design, since there isn't much value in organizing something already straightforward, such as coding.

A methodology has a language for analysis and design concepts, and rules for ensuring the concepts are correct, or at least consistent. A good methodology is easy to use and understand, consistent, complete, flexible, and reliable. It helps diverse people work together, helps you create realistic schedules and budgets and avoid surprises, and helps you create software that meets the users' needs.

Most Macintosh software has been developed without using a formal methodology. Paradoxically, the primary reason for this is the innovation and high standards of the Macintosh. Methodologies, no matter what theories they use, are based on practical experience. The state of the art in methodology has had to catch up with graphic interfaces, event driven architectures, object-oriented programming, and application frameworks. This has meant that methodology is weakest in meeting the challenge of new technologies when it is needed the most.

In spite of the lack of methodology, Macintosh developers have managed to create a lot of excellent software. But there are also many applications that didn't make it, because of technical flaws, schedule problems, or not having the right features. The well educated, demanding users, and the intense competition in Macintosh software means that you can't just write better software. You have to continue to write ever better software, ever faster. The easiest computer to use is still hard to program.

Object programming and application frameworks such as MacApp promised to make Macintosh programming easier by making code more reusable and eliminating the need to deal directly with the Toolbox. It turns out that making code reusable, even with an OBJECT PROGRAMMING language, is harder than just hacking something out. Also, MacApp is well designed and well written, but can be hard to learn. Programming has been made easier, but only for those who manage to become MacApp experts. Making it easier to use object programming and MacApp is the challenge now.

It's interesting to see how object programming and MacApp affect the development process. MacApp frees you from writing a lot of boilerplate code such as main event loops. It separates the user interface from the rest of the program, and provides a fairly rich framework for adaptation. What's left to do is the analysis, interface design, and object design. In other words, MacApp eliminates most of the mindless parts of writing a Macintosh application, leaving only the hard parts. Meanwhile, object programming languages such as Object Pascal and C++ separate software design (class structure, object relationships and interfaces) from implementation (method code).

With object programming and MacApp, the analysis and design work that used to be mushed in with coding is forced into the open. This is good because it gets us closer to the heart of programming [1]. The next step in making programming easier is to come up with a better way to do analysis and design. In other words, a software development methodology.

ABOUT THE BOOK

The book, Developing Object-Oriented Software for the Macintosh, is divided into two parts. The first part establishes the need for SBM and goes into its theoretical background. The second part describes the details of the Visual Design Language (VDL) and SBM. The book also includes a brief appendix on a simple index card system for facilitating SBM.

Object-oriented software development

The first part of the book is written as a tutorial. It explains, in painstaking detail, the theoretical and practical considerations that went into SBM. I could tell this book was written by real engineers. It has structure. Concepts are introduced, described, and summarized. Each section depends on the previous one and leads to the next. Not a sentence was wasted.

This part of the book is well written, even entertaining. The authors present concepts with a clarity and confidence that comes from practical experience and repeated refinement. The examples are good and humor is used appropriately.

The first chapter establishes the need for improvement in how we develop software. It demolishes the standard myths of software development, then defines the characteristics of a good methodology and introduces object-oriented software development, more of which is covered in the following chapters.

The second chapter explains object programming, including inheritance, polymorphism, and class libraries.

The primary purpose of chapter 3, the Folklore of Object-Oriented Software Development, is the debunking of objectivism, the belief that objects in a computer program work the same way as real objects in the real world (and vice versa). The attractiveness of objectivism is easy to understand when you consider that a major early use of object-oriented programming was for simulation, where the purpose is to model real world objects. Real-time control is another application where there is a strong resemblance between the objects inside and the ones outside the computer. For most applications, however, objectivism really doesn't work. Real world objects have identity and structure, and may be similar to other objects in different ways, but real world objects are too complicated to be organized into hierarchies, even with multiple inheritance. Computer objects are an organization of code and data for the convenience of the programmer. Objects allow you to write software that has minimal side effects when it runs. Objects make it easier to modify the software because interfaces between objects are well defined and dependencies can be minimized. Class hierarchies are simply another convenience that allow code and data definitions for similar objects to be consolidated.

Chapter 4, Sample Applications (Why Aren't They Easy), is one of the best parts of the book. It shows how the classic object-oriented design approaches fall apart for non-trivial examples. It describes the messes you can get into. Object programmers will recognize them. It looks at how an expert might approach the problem, the principles behind that approach, and the characteristics of a good object-oriented design.

Chapter 5 is a short primer on cognitive science. It describes how people think in terms of cognitive categories, and the difference between overlapping categories (how people think), and hierarchical classes (how people think they think). This is a little subtle, but important because it is the primary justification for using planes, scenarios, and calibration in SBM, instead of using a top-down or linear approach.

Solution based modeling

The second part of the book is written as a reference. It gets down to brass tacks and describes how to use SBM.

Chapter 6 describes the Visual Design Language, which is used to communicate design information throughout the rest of the book. This is human interface design at its best. The authors worked with a graphic design firm to create VDL, and it shows. VDL simply looks better than the symbols for other methodologies. Perspective is used to make symbols easier to recognize, while packing more meaningful information into diagrams. The symbols are not hard to draw. This lets non-programmers participate more fully in analysis and design.

Chapter 7 is an overview of SBM. Chapters 8 through 11 describe the Business, Technology, Execution, and Program planes in a Solution Based Model.

The fundamental unit in a Solution Based Model is the scenario, a description in VDL of a single topic or concept. Scenarios are supposed to be simple-something that can be easily drawn on an index card. There is no fixed structure that the scenarios have to fit into. Instead, a calibration process is used to find inconsistencies among overlapping scenarios.

This is another great thing about SBM. It's hard for people to be simultaneously creative and critical; it always works better if you can separate the two dynamics. The different levels of abstraction in a project, such as requirements, specification, design, and implementation, are handled in SBM as planes. The relationships between planes are described using scenarios, just like everything else. The calibration process ensures that the model is valid from top to bottom. The same methodology is used for the whole software life cycle.

The Business plane is where you do requirements analysis. You describe how things are done now (the reference model), and how they will be done with the new system (the solution model). SBM can do an impact analysis by looking at the differences between the reference and solution models. This has enormous value for justifying a system proposal, marketing, planning, and training.

The Technology plane is where you do the system specification, in the form of a user interface model, content model, and environment model. The separation between the Business and Technology planes is a key factor. The Business plane focuses on people and how they do their work. The Technology plane focuses on the computer system and how it appears to the user.

The Execution plane contains the user interface, content, and environment architectures. This is where you design the objects and interfaces and figure out how library building blocks will be used in the system. The Business and Technology planes describe real-world objects (such as people, forms, reports, screens and keyboards) while the Execution plane describes software objects (such as views, documents, and commands). This is where you apply the theory on the failures of the classic object-oriented design approaches. If objectivism were true, the contents of the Execution plane would look just like the Business and Technology planes, when actually it takes real work to design the run-time objects. In practice, the principles of good object design are the same as those for good software design: well defined modules with minimal interdependencies.

The Program plane is where you design the types and classes for implementing the system. There is an important distinction between the Execution plane, which describes how the run-time objects are organized, and the Program plane, which describes how the source code is organized. This helps you avoid a common pitfall: confusing objects and classes.

The second part of the book is not as easy to understand as the first part. Because it's written as a reference, there isn't as much continuity between sections. I needed to read through it twice to fit everything together. For example, I got confused because I couldn't tell the difference between the "reference frame" and the "reference model" in the business plane. That was cleared up in the last chapter, which talks about looping around to the next iteration in the software life-cycle.

The concepts that I had the most difficulty with were how dangling threads are managed and how calibration is performed. The theory is clear, but the details are skimpy. It would help to have a worked out example-such as for the Payroll sample application-that goes through the whole SBM process, showing overlapping scenarios, dangling threads, calibration, and scenario revision. Of course, that might double the size of the book.

EVALUATION

SBM could clearly use a CASE (Computer Aided Software Engineering) tool. The tool would have a VDL drawing module for creating and editing scenarios that would be stored in a database. The database would make it easy to navigate through overlapping scenarios, and calibration could be automated. If a CASE tool came out soon enough and weren't too expensive, it could become a useful standard for communicating design information.

It would help to have more worked out examples and diagrams; they would be even more useful on-line. The ultimate test would be a diagram of SBM, done using its own Visual Design Language.

DOOSM is the result of two years of work by Neal Goldstein and Jeff Alger. In some respects the book has the feel of a version 1.0.0, but the authors' experience and hard work shows through. To quote James Plamondon, "MacApp is not just a bunch of user interface code, it is a library of accumulated wisdom on Macintosh programming." The real value of SBM is its accumulated wisdom. Get a copy, and study it carefully. And have your manager and any non-programmers on your team read the first part, at least. Any one of the many insights in the book will make it worthwhile.

 

Community Search:
MacTech Search:

Software Updates via MacUpdate

A Better Finder Rename 9.52 - File, phot...
A Better Finder Rename is the most complete renaming solution available on the market today. That's why, since 1996, tens of thousands of hobbyists, professionals and businesses depend on A Better... Read more
OmniFocus 2.2.3 - GTD task manager with...
OmniFocus helps you manage your tasks the way that you want, freeing you to focus your attention on the things that matter to you most. Capturing tasks and ideas is always a keyboard shortcut away in... Read more
TinkerTool 5.4 - Expanded preference set...
TinkerTool is an application that gives you access to additional preference settings Apple has built into Mac OS X. This allows to activate hidden features in the operating system and in some of the... Read more
Tinderbox 6.3.1 - Store and organize you...
Tinderbox is a personal content management assistant. It stores your notes, ideas, and plans. It can help you organize and understand them. And Tinderbox helps you share ideas through Web journals... Read more
Parallels Desktop 10.2.2 - Run Windows a...
Parallels Desktop is simply the world's bestselling, top-rated, and most trusted solution for running Windows applications on your Mac. With Parallels Desktop for Mac, you can seamlessly run both... Read more
Adobe Premiere Pro CC 2015 9.0.1 - Digit...
Premiere Pro CC 2015 is available as part of Adobe Creative Cloud for as little as $19.99/month (or $9.99/month if you're a previous Premiere Pro customer). Premiere Pro CS6 is still available for... Read more
Adobe After Effects CC 2015 13.5.1 - Cre...
After Effects CC 2015 is available as part of Adobe Creative Cloud for as little as $19.99/month (or $9.99/month if you're a previous After Effects customer). After Effects CS6 is still available... Read more
Adobe Creative Cloud 2.2.0.129 - Access...
Adobe Creative Cloud costs $49.99/month (or less if you're a previous Creative Suite customer). Creative Suite 6 is still available for purchase (without a monthly plan) if you prefer. Introducing... Read more
Tower 2.2.3 - Version control with Git m...
Tower is a powerful Git client for OS X that makes using Git easy and more efficient. Users benefit from its elegant and comprehensive interface and a feature set that lets them enjoy the full power... Read more
Apple Java 2015-001 - For OS X 10.7, 10....
Apple Java for OS X 2015-001 installs the legacy Java 6 runtime for OS X 10.11 El Capitan, OS X 10.10 Yosemite, OS X 10.9 Mavericks, OS X 10.8 Mountain Lion, and OS X 10.7 Lion. This package is... Read more

Domino Drop (Games)
Domino Drop 1.0 Device: iOS Universal Category: Games Price: $1.99, Version: 1.0 (iTunes) Description: Domino Drop is a delightful new puzzle game with dominos and gravity!Learn how to play it in a minute, master it day by day.Your... | Read more »
OPERATION DRACULA (Games)
OPERATION DRACULA 1.0.1 Device: iOS Universal Category: Games Price: $5.99, Version: 1.0.1 (iTunes) Description: 25% off launch sale!!! 'Could prove to be one of the most accurate representations of the Japanese bullet hell shmup... | Read more »
Race The Sun (Games)
Race The Sun 1.01 Device: iOS iPhone Category: Games Price: $4.99, Version: 1.01 (iTunes) Description: You are a solar craft. The sun is your death timer. Hurtle towards the sunset at breakneck speed in a futile race against time.... | Read more »
Tap Delay (Music)
Tap Delay 1.0.0 Device: iOS Universal Category: Music Price: $4.99, Version: 1.0.0 (iTunes) Description: Back in the “old days”, producers and engineers created delay and echo effects using tape machines. Tap Delay combines the warm... | Read more »
This Week at 148Apps: July 20-24, 2015
July is Heating Up With 148Apps How do you know what apps are worth your time and money? Just look to the review team at 148Apps. We sort through the chaos and find the apps you're looking for. The ones we love become Editor’s Choice, standing out... | Read more »
Red Game Without A Great Name (Games)
Red Game Without A Great Name 1.0.3 Device: iOS Universal Category: Games Price: $2.99, Version: 1.0.3 (iTunes) Description: The mechanical bird is flying through an unfriendly, Steampunk world. Help it avoid obstacles and deadly... | Read more »
Warhammer: Arcane Magic (Games)
Warhammer: Arcane Magic 1.0.2 Device: iOS Universal Category: Games Price: $9.99, Version: 1.0.2 (iTunes) Description: Engage in epic battles and tactical gameplay that challenge both novice and veteran in Warhammer: Arcane Magic, a... | Read more »
Mazes of Karradash (Games)
Mazes of Karradash 1.0 Device: iOS Universal Category: Games Price: $1.99, Version: 1.0 (iTunes) Description: The city of Karradash is under attack: the monsters of the Shadow Realms are emerging from the depths.No adventurer is... | Read more »
Battle Golf is the Newest Game from the...
Wrassling was a pretty weird - and equally great - little wressling game. Now the developers, Folmer Kelly and Colin Lane, have turned their attention to a different sport: golfing. This is gonna be weird. [Read more] | Read more »
Qbert Rebooted has the App Store Going...
The weird little orange... whatever... is back, mostly thanks to that movie which shall remain nameless (you know the one). But anyway it's been "rebooted" and now you can play the fancy-looking Qbert Rebooted on iOS devices. [Read more] | Read more »

Price Scanner via MacPrices.net

2015 13-inch 2.7GHz Retina MacBook Pro on sal...
B&H Photo has the new 2015 13″ 2.7GHz/128GB Retina MacBook Pro on sale today for $1199 including free shipping plus NY sales tax only. Their price is $100 off MSRP. Read more
2.8GHz Mac mini available for $988, includes...
Adorama has the 2.8GHz Mac mini available for $988, $11 off MSRP, including a free copy of Apple’s 3-Year AppleCare Protection Plan. Shipping is free, and Adorama charges sales tax in NY & NJ... Read more
Updated Mac Price Trackers
We’ve updated our Mac Price Trackers with the latest information on prices, bundles, and availability on systems from Apple’s authorized internet/catalog resellers: - 15″ MacBook Pros - 13″ MacBook... Read more
High-Precision Battery Fuel Gauge IC Extends...
Renesas Electronics Corporation has announced its new lithium-ion (Li-ion) battery fuel gauge IC, the RAJ240500, designed to extend battery life for connected mobile devices such as tablets, notebook... Read more
27-inch 3.3GHz 5K iMac on sale for $1799, $20...
B&H Photo has the 27″ 3.3GHz 5K iMac on sale for $1799 including free shipping plus NY tax only. Their price is $200 off MSRP, and it’s the lowest price available for this model from any Apple... Read more
Twelve South Free Dual Screen Backgrounds Co...
Twelve South has posted a second collection of travel Desktop photos, noting: For the Twelve South team, a vacation is never just a vacation. It’s a time to try out new prototypes on the road, visit... Read more
Apple Refurbished iMacs available for up to $...
The Apple Store has Apple Certified Refurbished iMacs available for up to $380 off the cost of new models. Apple’s one-year warranty is standard, and shipping is free: - 27″ 3.5GHz 5K iMac – $1949 $... Read more
Tablets: Why Microsoft’s Surface Is Soaring W...
In contrast to Apple’s record fiscal third quarter reported this week, Microsoft had a miserable latest quarter with its revenues falling by 5.1 percent, hammered by ongoing weak PC demand, and... Read more
Sale! 13″ 1.6GHz/256GB MacBook Air for $1099,...
B&H Photo has the 13″ 1.6GHz/256GB MacBook Air on sale for $1099 including free shipping plus NY tax only. Their price is $100 off MSRP, and it’s the lowest price available for this model. Read more
iPad mini 4 To Be Upgraded To iPad Air 2 Spec...
There’s a certain inevitability about making Apple product predictions this time of year. Come September, we can pretty reliably count on the release of refreshed iPhones, along with the iOS 9... Read more

Jobs Board

*Apple* Retail - Multiple Positions (US) - A...
Job Description: Sales Specialist - Retail Customer Service and Sales Transform Apple Store visitors into loyal Apple customers. When customers enter the store, Read more
*Apple* Retail - Multiple Positions (US) - A...
Job Description: Sales. Specialist - Retail Customer Service and Sales. Transform Apple Store visitors into loyal Apple customers. When customers enter the store, Read more
*Apple* Customer Experience (ACE) Leader - A...
…management to deliver on business objectives Training partner store staff on Apple products, services, and merchandising guidelines Coaching partner store staff on Read more
Project Manager - *Apple* Pay Security - Ap...
**Job Summary** The Apple Pay Security team is seeking a highly organized, results-driven Project Manager to drive the development of Apple Pay Security. If you are Read more
*Apple* TV Product Design Internship (Spring...
…the mechanical design effort associated with creating world-class products with the Apple TV PD Group. Responsibilities will include working closely with manufacturing, Read more
All contents are Copyright 1984-2011 by Xplain Corporation. All rights reserved. Theme designed by Icreon.