Notice: This material is excerpted from Special Edition Using Java, ISBN: 0-7897-0604-0. The electronic version of this material has not been through the final proof reading stage that the book goes through before being published in printed form. Some errors may exist here that are corrected before the book is published. This material is provided "as is" without any warranty of any kind.
by Alexandar Newman
If you're interested in Java, the new programming platform from Sun Microsystems that has taken the World Wide Web by storm, this book is for you. Whether you have only heard of Java and are curious to learn more, or already have a great deal of experience with Java, Using Java, Special Edition has something to offer you.
The team of writers that put this book together brought a broad range of experience to it. The team included people who had a great deal of Java expertise and people who knew very little Java but had a great deal of programming experience. This wide variety of perspectives enabled us to cover all the issues that occur when a person wants to learn Java. Whether you are a beginner or an expert, someone who was involved in the production of this book represented your perspective. In fact, you could look at SE Using Java as being several books in one.
If you're new to Java and object-oriented programming, this book covers basic concepts and builds on them with each chapter. Don't worry if you don't understand any given topic the first time through; SE Using Java takes a very hands-on approach to learning.
Intermediate readers are the most difficult audience to write for. Everybody doesn't know something; the problem is that "something" is different for each reader. This book is organized in such a way that it allows you to brush up on a weak area or to quickly locate the answer to a single tough question. This book covers the difficult middle ground, firms up your grasp on the basics, and prepares you to tackle some of advanced topics.
For experienced Java users, this book examines some of the underlying concepts of the Java machine and discusses tough topics such as Java security. The book covers building your own applets with Java and with other languages. The book also provides in-depth coverage of the Java tools, and examines the advantages and disadvantages of Java-compatible technology.
What is Java, and where did it come from? Surprisingly, this hot new technology has been around for years. In 1990, a team of Sun researchers developed some concepts for a new direction in high-tech, consumer-driven technology. Even in 1990, it was obvious that computers were everywhere and were the driving force behind many of the products in the home: the VCR, the microwave oven, the security system, even the stereo system. Unfortunately, almost everyone regarded computers-especially the ones made by Sun Microsystems-as being too weird, too geeky, and too hard to use. Sun, which felt that it had lost a major opportunity by not getting in on the ground floor of the PC explosion, launched a strange new project which would become Java: technology for everyday people.
Patrick Naughton, a programmer at Sun and a friend of Scott McNealy, the president of Sun, was going to quit his job. Sun was going nowhere, and NeXT Computer, Inc., with its cutting-edge NeXTstep operating system, was leading the next wave of the computer revolution. To McNealy's credit, when Naughton said that he was leaving, McNealy asked for a complete report on everything that Naughton felt Sun was doing wrong-and for suggestions on how to fix those problems. Naughton produced the report, and McNealy passed it along to Sun's entire management chain.
The results were astounding. Hundreds of Sun higher-ups agreed with Naughton. One of the people in whom Naughton's report struck a resonant chord was James Gosling. Gosling, whom Sun co-founder Bill Joy calls "the world's greatest programmer," carried a lot of clout with Sun's management. Gosling said that "somewhere along the way [Sun has] lost touch with what it means to produce a quality product."
Backed by luminaries such as John Gage, Sun's science-office director, a group of Sun employees batted ideas around until the small hours of the morning until they came up with the governing principles for a new project:
If the principles seemed to be vague, they were equally exciting. With the backing of John Gage, Naughton pitched the idea to Wayne Rosing,the president of Sun Laboratories-a subsidiary of Sun Microsystems. The request to be seemed ludicrous. Naughton wanted to keep the project secret from everyone except the top executives of Sun-so secret, in fact, that the team was going to relocate away from Sun's corporate headquarters (and away from the corporate mentality that could erode and undermine creative concepts. The team's hardware and software wouldn't have to be compatible with Sun's existing architecture, and on top of everything else, Naughton wanted a budget of $1 million for the first year.
He got it.
Wayne Rosing brought the proposal to Scott McNealy, and after the meeting, Rosing expected to deliver everything that Naughton had asked for. In the next 24 hours, two more of Sun's top executives put their support behind the project, and the team, code-named Green, was born. The team consisted of Naughton; programmer Jim Gosling; and engineer Mike Sheridan, whom Sun had hired after it bought out his startup company.
The sky was the limit. The Green Team could do whatever it wanted. The question, of course, was what the team wanted to do. After some discussion, Naughton said, the team decided that "the third wave of computing would be driven by consumer electronics." Hardware and software would no longer be specialized purchases; consumers would be able to buy software at local record stores.
Gosling brought up the doorknob paradigm during a company retreat in Squaw Valley, California, near Lake Tahoe. Gosling commented that computer chips were showing up everywhere, even in the doorknobs of the rooms at the ski lodge. The Green Team saw a contradiction: even though computer technology was used in all common consumer electronics products (such as stereo systems, television sets, and VCRs), each product required its own interface. In other words, to control three devices, consumers had to have three remote controls and to understand programming for three devices. Then, as now, most people didn't have the understanding. It didn't take much to see that with a little hardware engineering, common devices could not only be made to work together, but also improved.
The Green Team, expanded to include Ed Frank, one of Sun's hardware engineers, finally had its mission: a simple device that controlled a variety of day-to-day electronics products. The team moved out of Sun's offices in April 1991 and set up camp in offices above a bank in Menlo Park, hoping that some of Edison's creative genius still lingered in the town. The team did everything as differently from Sun as it could, distancing itself from Sun's corporate mentality physically, culturally, and electronically.
Why was the distance necessary? Mike Sheridan said, "We thought if we stayed over there [at Sun], we would end up with just another workstation." The team ended up building its own machine out of cannibalized parts of Nintendo Gameboys and Sharp television sets, but the language was the real challenge.
After months of banging his head against a wall, Gosling had an epiphany at a rock concert in Mountain View. Instead of seeing the wires, speakers, and automated light show that everyone else was watching, Gosling saw the "packets flowing down the wires and making everything happen." He realized that existing programming languages weren't going to do it. C++ was close, but because that language had come from the computer side of things, its emphasis was on speed, not reliability. In consumer electronics, reliability is more important than speed, and C++ programs had a tendency to break at unpredictable times. In addition, the interfaces were inconsistent. To survive in the consumer marketplace, the software interfaces needed to fit together as regularly as a light bulb fits into a light socket. Gosling needed a new programming language.
As it turned out, Gosling nearly had the answer in his back pocket. He had been tinkering with a replacement language for C++ at home (not surprising when you realize that he wrote his first computer language when he was 14). In the meantime, Naughton had been developing the device's interface: a series of graphic animations. The two men brought the halves of the language together, and by August 1991, a new language called Oak (named for a tree outside Gosling's window) was born.
A year later, the Green Team was demonstrating its baby for Scott McNealy. A hand-held device with no keyboard, no buttons (not even a power switch), and a tiny screen, the prototype didn't look like a computer at all. The interface was invisible. You touched the screen to turn it on and controlled the action on the screen with a fingertip-no keyboard, no tablet and pen, no mouse. A cartoon house appeared on-screen, along with a cartoon tour guide, Duke. Duke was shaped like one of the rank insignias on the old "Star Trek" TV series and the red nose of W.C. Fields. Controlling the house, and Duke, was easy: you moved your finger along the screen from the front hall to the living room. In the living room, an icon that represented a TV schedule rested on the coffee table. You flipped through the guide, selected a movie, and dragged the movie's icon to the virtual VCR. The VCR was programmed, and it told you so with a satisfying "ka-ching" tone.
Nothing like this had been seen before, and McNealy was ecstatic; this was what he needed to crush Apple, IBM, Microsoft, and Hewlett-Packard. In September 1992, Sun set up the Green Team as FirstPerson, Inc., a Sun subsidiary. Wayne Rosing moved over from Sun Labs to run the new company. Sheridan, who felt that he should have been the one picked to run the company, quit. It wasn't an smooth changing of the guard, but life went on...and went wrong.
Somehow, even this perfect technology wasn't taking off. The chips were too expensive to manufacture, and Sun lost a lucrative contract to its crosstown rival, Silicon Graphics, Inc. Losing the Time-Warner contract may not have been such a bad thing. Time-Warner was interested only in a promise of set-top boxes, priced at less than $300 each, for its interactive television project. SGI made the promise but delivered the boxes more than a year late-at a cost of nearly $3,000 each. The project failed all around. (To show how circular the world is, Jim Clark, SGI's founder, later gave up on interactive TV to embrace the World Wide Web-and to found Netscape, Inc., the company that would develop the popular Netscape Navigator browser that would incorporate and drive Java.)
FirstPerson managed to dodge the bullet of promising to deliver something it couldn't, but ultimately, the Green Team project was a failure, and the company was dissolved in 1994. It took Bill Joy to rescue Oak from oblivion.
Joy, one of the co-founders of Sun, is unique in the annals of computing; he's a hacker who writes glorious code but is respected by businesspeople. In 1992, Joy pulled up stakes and headed from California to Aspen, Colorado, where he established a small Sun research lab.
Joy, who saw an opportunity for Oak in the dramatic emergence of the World Wide Web, put Gosling and Naughton back to work on Oak while he went to work convincing Sun the project was worth saving. Joy's idea was to follow Netscape's Internet Play model and release Java for free over the Internet. Internet Play is the "profitless" approach to market share: by giving your product away for noncommercial use, you can make it the standard. Some opponents equate this method with price dumping. Price dumping is a practice used by companies who take a longer view of developing market share. You release a product at a lower cost than it costs you to produce it-sometimes you give it away. By keeping your price drastically below your competitors' prices, you can gain control of the market. Price dumping is illegal in the United States. So far, there are no laws against giving your prodcut away.
Oak hit some legal snags, including the fact that its name was too close to that of another product. In January 1995, Oak was renamed Java-which, incidentally, doesn't stand for Just Another Vague Acronym; it doesn't stand for anything.
Today, Joy's vision of free and accessible technology is a reality, although not one that Sun may be entirely happy with yet. Sun still needs to make sure that Java becomes the standard; then, even more important, it needs to figure out how to make money from the product. Selling commercial licenses seems to be the way to go. Rather than go head-to-head with Sun over Java, on December 7, 1995, Microsoft signed a letter of intent with Sun for a Java-technology source license. Additionally, Microsoft agreed in principle to give Sun two things: Microsoft's reference implementation of the Java virtual machine, and the applet application programming interface (AAPI) for Windows.
This deal was important. By integrating Java into its Explorer browser, Microsoft provided Java a huge base of previously untapped Windows users. In addition, it was a major endorsement from the world's largest software firm that Sun's Internet technology is top-notch and goes a long way toward establishing Java as the de facto open standard for programming on the Internet.
With Java, Sun established the first programming language that wasn't tied to any particular operating system or microprocessor. Applications written in Java will run anywhere, eliminating one of the biggest headaches for computer users: incompatibility between operating systems and versions of operating systems. Where Java goes from here is up to Sun, Microsoft...and you.
Until the personal-computing revolution of the 1970s and 1980s, working on a computer meant working on a large, shared mainframe. Users never actually touched the computer, which lived in some basement or air-conditioned room; they worked on terminals. Users shared both the terminals and the computer's processing power with other users on the system. Communicating with other users was easy; a user simply moved a piece of data from one place on the computer to another.
Personal computers changed intercomputer communication. A personal computer put all the computing power that a user could want right on his own desktop, eliminating the need to share a terminal or cycles with anyone else. Unfortunately, if a user wanted to send a message to someone else, he couldn't. Someone had to figure out how to allow all the individual computers to talk to one another without being dependent on one another. The company that developed the solution that became the standard was Xerox Corporation; the solution was Ethernet.
Ethernet was limited, however, in that it primarily connected computers at a single site. The Internet ultimately linked multiple sites and became the operating system for which the World Wide Web became a command-line interpreter. Just as a windowing system allows easy access to an operating system, the Web facilitates use of esoteric, arcane UNIX commands such as Telnet, FTP, and Gopher. And, of course, the Web brought us Java.
To understand why Java has taken off so quickly, all that you really need to know is this: before Java, the World Wide Web was limited to still images; after Java, the Web was capable of supporting animation, graphics, games, and a wide range of special effects. Java effectively allows you run a program on someone else's computer across the Internet-exciting stuff, particularly when you realize what's pushing Web technology. The Web seems to have infiltrated areas where even ubiquitous e-mail can't. No company ever put its e-mail address in its television commercials, but many non-technology-oriented companies, ranging from movie studios to real estate agencies, have discovered the Web.
If you're not familiar with the World Wide Web, it can be a little difficult to understand. Like most of the topics that this book deals with, the Web is buzzword-friendly. The Web could be described as an interactive, global, platform-neutral, hypermedia information retrieval system-but no one would know what that description means. Because some of the terms in that description apply to Java as well as the Web, the following sections touch on them.
Thanks to Java, the Web is more interactive now than it's ever been, but even before Java came along, the Web was considered to be interactive. All that interactive means in this context is that you can do more with a Web page than just look at it.
Almost all Web pages contain links, which enable you to move around the page, the site, or even the Web at the click of a button. Besides links, Web pages can have forms; people who access pages with forms can fill in information requested by that pages owner. Sometimes forms aren't open-ended. A person who designs a form can limit the responses by installing a set of buttons-each button representing one possible response. Buttons are great if you want to quantify the responses.
What a user can do with the information he or she supplies is up to the designer of the Web page. Sometimes, you fill out a form in order to request more information, as with a search engine. The information you provide can also be appended to a file on the server that hosts the Web page. The form that you fill out can even be mailed to someone who you couldn't reach using the options presented on that page. So you can order goods, sign up for mailing lists, or get more information.
Although Web pages tend to look like brochures, they certainly don't have to behave like them. This is even more true now that Java has come along.
The World Wide Web is literally that: worldwide. The Web uses the structure of the Internet to distribute and receive information. Everywhere that the Net goes, the Web can go. Web servers operate on almost every continent and in hundreds of languages.
"Platform-neutral" is a cryptic way of saying "it doesn't matter what hardware you run your server on or what hardware I run my browser on." Like the Internet, the World Wide Web isn't limited to a single architecture or operating system. You access the Web by using a specialized piece of software called a browser, and you can use whatever kind of browser is best for you. Only a few Java-compatible browsers are available; the book talks about them in a later chapter. If you're using a Macintosh, you need to make sure that your browser is compatible with your hardware, not with anyone else's. It doesn't matter whether the machine that you're connecting to (called a server) is another Macintosh, an IBM PC, a Sun workstation, or some brand of computer.
Bear in mind, however, the Web is an outgrowth of the Internet and that most advances in Internet technology happen first on UNIX systems. The reason is simple: the Internet was developed on UNIX machines, and UNIX still is the dominant platform on the Internet. Don't feel that you need to run out and buy a UNIX workstation, though. Like most things, computer technology is demand-driven. Sooner or later (and sooner, if demand exists), the technology that you want will make the move to personal computers.
If you ask someone who uses the Web what makes it better than other information services, the most common answer is, "It's cooler." Hypertext is what makes the Web cool. The advantage of hypertext over plain printed material (such as this book, for example) is that in a hypertext document, if you come across a something which looks interesting, you usually can click it to get details. Hyperlinks can be used intradocument (such as footnotes) or interdocument-that is, from one page to another, and many times even from one World Wide Web site to another. The advantage of hyperlinks over footnotes is that hyperlinks allow you to access documents which are related to each other instantly.
Hypertext is a non-linear method of organizing text. Individual elements (words, pictures, addresses, etc.) point to one another. Hyperlinks are elements (words, pictures, etc.) within a hypertext document that point towards other elements.
Until recently, even though the Web encompassed more than simple text, it was commonly called a hypertext system. When the Web was created, it really was just text, and the hyperlinking technology was borrowed from single-user machines. With the introduction of Java, and with the development of VRML, the Virtual Reality Modeling Language (see chapter 28) and other nontext technologies, the Web has truly moved from hypertext to hypermedia, as documents begin to do more and more. The difference, of course, between hypertext and hypermedia, is that in hypertext, words connect largely to words or still images, while in hypermedia elements that connect to one another can be words, pictures, sounds, even applications.
Almost everything on the Web is information. Whether the information in question is a copy of the president's recent State of the Union address or pictures of bikini-clad beauties, the Web allows you to retrieve information entered by other people, and vice versa.
Using Java, Special Edition is organized in seven major sections.
Part I, "Getting and Installing Java," introduces the underlying concepts of the Java programming language, as well as practical information such as where to get Java and how to install it on your computer.
Part II, "The Java Language," covers the basics of programming in this C/C++-like language, including classes, multithreading, types, expressions, and statements. This part of the book also discusses Java security.
Part III, "Writing an Applet," explores the construction of applets (Java's mini-programs) from concept to finished program. This part describes several applets in detail and shows you how to write your own.
Part IV, "Using Applets in Web Pages," teaches you how to apply what you learned in parts I through III to the World Wide Web. Installing applets isn't difficult, but you need to be aware of what requirements exist and what system resources Java can consume.
Part V, "Advanced Java," focuses on Java applications. Although much of the thrust of Java today is toward applet-building, Java is a robust language, fully capable of supporting large and intricate programs. Like applications developed in other languages, Java applications (unlike applets) don't require a browser.
Part VI, "The Future of Java," discusses where you can expect to go with Java in the near and not-so-near future. This part of the book pays particular attention to the interaction of Java and VRML (Virtual Reality Modeling Language).
Part VII is made up of reference material: the appendices and the glossary. There are six appendices ranging in topics of the Java API to What's on the CD-Rom.
Before reading Using Java, Special Edition, you should be aware of several conventions that the book uses.
Program code is printed in a monospace font. Anything that you see in that font, you should type. Variables in program code appear in italics. The specific word that a variable represents varies, according to the situation; you need to enter the appropriate data.
Italics also are used for definitions. Terms are defined the first time that they appear in the book; some terms also appear in the glossary (appendix D).
For technical support for our books and software contact support@mcp.com
Copyright ©1996, Que Corporation