Practical API Design: Confessions Practical API Design of a Java™ Framework Architect
Total Page:16
File Type:pdf, Size:1020Kb
CYAN YELLOW MAGENTA BLACK PANTONE 123 C BOOKS FOR PROFESSIONALS BY PROFESSIONALS® THE EXPERT’S VOICE® IN JAVA™ TECHNOLOGY Companion eBook Available Practical API Design: Confessions API Design Practical of a Java™ Framework Architect Dear Reader, Maybe you’re standing in a bookstore, holding this book in your hand, and ask- ing yourself, “Should I buy it?” Here is your answer. If you’ve ever written code and handed it to others to let them compile their code against yours, then you’re ready to enter the API design world and this book will help you explore it. Practical However, this book doesn’t attempt to “teach API design in five easy lessons.” It cannot be read in “only three days!” If you’re looking for a quick handbook, this book is probably not for you. On the other hand, if you’re interested in a deeper knowledge of API design, in knowing not only the how, but also the why, let me introduce myself to you before you put this book back on the shelf. My name is Jaroslav Tulach and I am the founder and initial architect of the NetBeans™ project, which is not just a well-known IDE, but also the first modu- lar desktop application framework written in the Java™ language. This book is based on notes that I’ve collected over the last ten years, while designing and API Design maintaining NetBeans APIs and transferring this knowledge to the rest of our developers. It’s a journal from the heart of the NetBeans laboratory, describing our problems, our growing understanding of them, the solutions we’ve chosen, ™ and the conclusions we made after applying them. Although our knowledge has Confessions of a Java Framework Architect been gathered while working on NetBeans, it’s general enough to be useful for most software projects. Knowledge of proper API design is essential for the successful creation of 21st century software. Let this book be your guide while exploring the big wide world of API design. Jaroslav Tulach API design done right, from one of the Java™ community’s most experienced API designers. RELatED TITLES Companion eBook See last page for details on $10 eBook version Tulach ISBN 978-1-4302-0973-7 Jaroslav Tulach SOURCE CODE ONLINE 9 0 0 0 0 www.apress.com Founder of the NetBeans™ Platform Shelve in Software Development User level: Intermediate–Advanced 9 781430 209737 this print for content only—size & color not accurate 7" x 9-1/4" / CASEBOUND / MALLOY (0.8125 INCH BULK -- 416 pages -- 50# Thor) 0973-7 FM.qxd 6/26/08 11:25 AM Page i Practical API Design Confessions of a Java Framework Architect Jaroslav Tulach 0973-7 FM.qxd 6/26/08 11:25 AM Page ii Practical API Design: Confessions of a Java Framework Architect Copyright © 2008 by Jaroslav Tulach All rights reserved. No part of this work may be reproduced or transmitted in any form or by any means, electronic or mechanical, including photocopying, recording, or by any information storage or retrieval system, without the prior written permission of the copyright owner and the publisher. ISBN-13: 978-1-4302-0973-7 ISBN-13 (electronic): 978-1-4302-0974-4 Printed and bound in the United States of America 9 8 7 6 5 4 3 2 1 Trademarked names may appear in this book. Rather than use a trademark symbol with every occurrence of a trademarked name, we use the names only in an editorial fashion and to the benefit of the trademark owner, with no intention of infringement of the trademark. Java™ and all Java-based marks are trademarks or registered trademarks of Sun Microsystems, Inc., in the US and other countries. Apress, Inc., is not affiliated with Sun Microsystems, Inc., and this book was writ- ten without endorsement from Sun Microsystems, Inc. Lead Editor: Clay Andres Editorial Board: Clay Andres, Steve Anglin, Ewan Buckingham, Tony Campbell, Gary Cornell, Jonathan Gennick, Matthew Moodie, Joseph Ottinger, Jeffrey Pepper, Frank Pohlmann, Ben Renow-Clarke, Dominic Shakeshaft, Matt Wade, Tom Welsh Project Manager: Kylie Johnston Copy Editor: Susannah Davidson Pfalzer Associate Production Director: Kari Brooks-Copony Production Editor: Ellie Fountain Compositor: Gina Rexrode Proofreader: Liz Welch Indexer: Broccoli Information Management Artist: Kinetic Publishing Services, LLC Cover Designer: Kurt Krames Manufacturing Director: Tom Debolski Distributed to the book trade worldwide by Springer-Verlag New York, Inc., 233 Spring Street, 6th Floor, New York, NY 10013. Phone 1-800-SPRINGER, fax 201-348-4505, e-mail [email protected], or visit http://www.springeronline.com. For information on translations, please contact Apress directly at 2855 Telegraph Avenue, Suite 600, Berkeley, CA 94705. Phone 510-549-5930, fax 510-549-5939, e-mail [email protected], or visit http://www.apress.com. Apress and friends of ED books may be purchased in bulk for academic, corporate, or promotional use. eBook versions and licenses are also available for most titles. For more information, reference our Special Bulk Sales–eBook Licensing web page at http://www.apress.com/info/bulksales. The information in this book is distributed on an “as is” basis, without warranty. Although every precaution has been taken in the preparation of this work, neither the author(s) nor Apress shall have any liability to any person or entity with respect to any loss or damage caused or alleged to be caused directly or indirectly by the information contained in this work. The source code for this book is available to readers at http://www.apress.com. 0973-7 FM.qxd 6/26/08 11:25 AM Page iii 0973-7 FM.qxd 6/26/08 11:25 AM Page iv Contents at a Glance About the Author . xiii Acknowledgments . xv Prologue: Yet Another Design Book? . xvii PART 1 Theory and Justification ICHAPTER 1 The Art of Building Modern Software . 5 ICHAPTER 2 The Motivation to Create an API . 15 ICHAPTER 3 Determining What Makes a Good API . 27 ICHAPTER 4 Ever-Changing Targets . 41 PART 2 Practical Design ICHAPTER 5 Do Not Expose More Than You Want. 69 ICHAPTER 6 Code Against Interfaces, Not Implementations. 87 ICHAPTER 7 Use Modular Architecture . 99 ICHAPTER 8 Separate APIs for Clients and Providers . 131 ICHAPTER 9 Keep Testability in Mind . 149 ICHAPTER 10 Cooperating with Other APIs . 159 ICHAPTER 11 Runtime Aspects of APIs . 185 ICHAPTER 12 Declarative Programming . 225 PART 3 Daily Life ICHAPTER 13 Extreme Advice Considered Harmful . 239 ICHAPTER 14 Paradoxes of API Design . 249 ICHAPTER 15 Evolving the API Universe . 261 ICHAPTER 16 Teamwork. 291 ICHAPTER 17 Using Games to Improve API Design Skills. 303 ICHAPTER 18 Extensible Visitor Pattern Case Study. 333 CHAPTER 19 End-of-Life Procedures . 355 iv I 0973-7 FM.qxd 6/26/08 11:25 AM Page v IEPILOGUE The Future . 363 IBIBLIOGRAPHY. 373 IINDEX . 375 v 0973-7 FM.qxd 6/26/08 11:25 AM Page vi 0973-7 FM.qxd 6/26/08 11:25 AM Page vii Contents About the Author . xiii Acknowledgments . xv Prologue: Yet Another Design Book? . xvii PART 1 Theory and Justification ICHAPTER 1 The Art of Building Modern Software. 5 Rationalism, Empiricism, and Cluelessness . 5 Evolution of Software So Far . 7 Gigantic Building Blocks. 9 Beauty, Truth, and Elegance . 10 More Cluelessness!. 12 ICHAPTER 2 The Motivation to Create an API . 15 Distributed Development . 15 Modularizing Applications . 17 Nonlinear Versioning . 20 It’s All About Communication . 22 Empirical Programming . 23 The First Version Is Always Easy. 25 ICHAPTER 3 Determining What Makes a Good API . 27 Method and Field Signatures. 27 Files and Their Content. 28 Environment Variables and Command-Line Options. 29 Text Messages As APIs. 31 Protocols . 32 Behavior . 34 I18N Support and L10N Messages. 35 Wide Definition of APIs . 36 vii 0973-7 FM.qxd 6/26/08 11:25 AM Page viii viii ICONTENTS How to Check the Quality of an API . 36 Comprehensibility . 37 Consistency. 38 Discoverability . 38 Simple Tasks Should Be Easy . 39 Preservation of Investment. 39 ICHAPTER 4 Ever-Changing Targets . 41 The First Version Is Never Perfect . 41 Backward Compatibility . 42 Source Compatibility . 42 Binary Compatibility.