28-Feb-16 How to Write Good Comments. 2 Write for your audience Program documentation is for programmers, not end users There are two groups of programmers,

Slides:



Advertisements
Similar presentations
11-Jun-14 The assert statement. 2 About the assert statement The purpose of the assert statement is to give you a way to catch program errors early The.
Advertisements

Modifying existing content Adding/Removing content on a page using jQuery.
Internal Documentation Conventions. Kinds of comments javadoc (“doc”) comments describe the user interface: –What the classes, interfaces, fields and.
Documentation 1 Comprehending the present – Investing in the future.
Utilities (Part 3) Implementing static features 1.
Conversation Form l One path through a use case that emphasizes interactions between an actor and the system l Can show optional and repeated actions l.
16-Jun-15 javadoc. 2 Javadoc placement javadoc comments begin with /** and end with */ In a javadoc comment, a * at the beginning of the line is not part.
16-Jun-15 Exceptions. Errors and Exceptions An error is a bug in your program dividing by zero going outside the bounds of an array trying to use a null.
Object-Oriented Enterprise Application Development Javadoc Last Updated: 06/30/2001.
23-Jun-15 HTML. 2 Web pages are HTML HTML stands for HyperText Markup Language Web pages are plain text files, written in HTML Browsers display web pages.
26-Jun-15 Methods. About methods A method is a named group of declarations and statements If a method is in the same class, you execute those declarations.
1 Doc Comment Conventions. 2 Write for your audience Rule 32: Write documentation for– those who must use your code Users should not need to care how.
Algorithm Programming Coding Advices Bar-Ilan University תשס " ו by Moshe Fresko.
Concordia University Department of Computer Science and Software Engineering Click to edit Master title style ADVANCED PROGRAMING PRACTICES API documentation.
Ranga Rodrigo. Class is central to object oriented programming.
1 Web Based Programming Section 6 James King 12 August 2003.
Java: Chapter 1 Computer Systems Computer Programming II.
JavaDoc1 JavaDoc DEPARTMENT OF COMPUTER SCIENCE AND SOFTWARE ENGINEERING CONCORDIA UNIVERSITY July 24, 2006 by Emil Vassev & Joey Paquet revision 1.2 –
A Basic Web Page. Chapter 2 Objectives HTML tags and elements Create a simple Web Page XHTML Line breaks and Paragraph divisions Basic HTML elements.
CS Fall 2007 Dr. Barbara Boucher Owens. CS 2 Text –Main, Michael. Data Structures & Other Objects in Java Third Edition Objectives –Master building.
07 Coding Conventions. 2 Demonstrate Developing Local Variables Describe Separating Public and Private Members during Declaration Explore Using System.exit.
The Java Programming Language
Documentation and Comments. What’s a comment? A comment is a simple form of documentation. Documentation is text that you the programmer write to explain.
Program documentation using the Javadoc tool 1 Program documentation Using the Javadoc tool.
1 Documenting with Javadoc. 2 Motivation  Why document programs? To make it easy to understand, e.g., for reuse and maintenance  What to document? Interface:
Classes CS 21a: Introduction to Computing I First Semester,
By the end of this session you should be able to...
Java Syntax and Style JavaMethods An Introduction to Object-Oriented Programming Maria Litvin Gary Litvin Copyright © 2003 by Maria Litvin, Gary Litvin,
Question of the Day  On a game show you’re given the choice of three doors: Behind one door is a car; behind the others, goats. After you pick a door,
Chapter 2 Introducing Interfaces Summary prepared by Kirk Scott.
23-Oct-15 Abstract Data Types. 2 Data types A data type is characterized by: a set of values a data representation, which is common to all these values,
Documentation and Programming Style Appendix A © 2015 Pearson Education, Inc., Hoboken, NJ. All rights reserved.
Software Documentation Section 5.5 ALBING’s Section JIA’s Appendix B JIA’s.
Java The Java programming language was created by Sun Microsystems, Inc. It was introduced in 1995 and it's popularity has grown quickly since A programming.
Documentation javadoc. Documentation not a programmer's first love lives in a separate file somewhere usually a deliverable on the schedule often not.
Documentation. Your documentation must fit the needs of your audience. It’s always better to say one thing that is useful, as opposed to many things that.
Documentation Dr. Andrew Wallace PhD BEng(hons) EurIng
CSC 212 – Data Structures Prof. Matthew Hertz WTC 207D /
Introducing Python CS 4320, SPRING Lexical Structure Two aspects of Python syntax may be challenging to Java programmers Indenting ◦Indenting is.
CSC Programming I Lecture 6 September 4, 2002.
The Software Development Process
Chapter 3 Syntax, Errors, and Debugging Fundamentals of Java.
JavaDoc and Contracts Spring Documenting Contracts with JavaDoc Contract model for methods Preconditions Postconditions JavaDoc Industry standard.
Javadoc. Purpose of javadoc javadoc is a program that reads your Java program and produces great-looking documentation in HTML format Without any help,
Javadoc. Purpose of javadoc  javadoc is a program that reads your Java program and produces great-looking documentation in HTML format  Without any.
Sections © Copyright by Pearson Education, Inc. All Rights Reserved.
Page 1 – Autumn 2009Steffen Vissing Andersen SDJ I1, Autumn 2009 Agenda: Java API Documentation Code Documenting (in javadoc format) Debugging.
Java Doc Guideline R.SANTHANA GOPALAN. Java Doc Guideline Audience Internal Developers PQA - who write test plans PPT – who write the documentation Customers.
ANU COMP2110 Software Design in 2003 Lecture 10Slide 1 COMP2110 Software Design in 2004 Lecture 12 Documenting Detailed Design How to write down detailed.
M1G Introduction to Programming 2 3. Creating Classes: Room and Item.
The single most important skill for a computer programmer is problem solving Problem solving means the ability to formulate problems, think creatively.
Today Javadoc. Packages and static import. Viewing API source code. Upcoming Topics: –protected access modifier –Using the debugger in Eclipse –JUnit testing.
Introduction to Exceptions in Java CS201, SW Development Methods.
© 2011 Pearson Education, publishing as Addison-Wesley Chapter 1: Computer Systems Presentation slides for Java Software Solutions for AP* Computer Science.
Advanced Programing practices
More Sophisticated Behavior
Working with Java.
How to Write Good Comments
Design by Contract Fall 2016 Version.
Chapter 1: Computer Systems
JavaDoc and Contracts Fall 2008.
Advanced Programing practices
How to Write Good Comments
How to Write Good Comments
How to Write Good Comments
Classes CS 21a: Introduction to Computing I
How to Write Good Comments
Presentation transcript:

28-Feb-16 How to Write Good Comments

2 Write for your audience Program documentation is for programmers, not end users There are two groups of programmers, and they need different kinds of documentation Some programmers need to use your code Do not explain to them how your code works--they don’t care and don’t want to know Tell them what your methods do, how to call them, and what they return Javadoc is the best way to document your code for users Other programmers need to maintain and enhance your code They need to know how your code works Use internal comments for these programmers When you work on your program, you are in both groups Document as though, the next time you see your program, you will have forgotten everything about it!

3 Internal comments Use internal comments to: Explain the use of temporary variables Label closing braces in deeply nested statements, or when many lines are between the open and close braces while (i != j) { } // end while Explain complex or confusing code Explain what the next section of code does Never repeat the code! count = count + 1; // add one to count

4 Good code requires few comments Use internal comments to: Explain the use of temporary variables Better: Give them self-explanatory names Label closing braces in deeply nested statements, or when many lines are between the open and close braces Better: Don’t nest statements that deeply Better: Keep your methods short Explain complex or confusing code Better: Rewrite the code If it’s complex or confusing, it’s probably buggy as well Explain what the next section of the method does Better: Make it a method with a self-explanatory name

5 Good uses of internal comments Use internal comments: If you really can’t make the code simple and obvious To reference a published algorithm To mark places in the code that need work Eclipse provides three tags for this purpose (you can add more): TODO – Means: This code still needs to be written FIXME -- Means: This code has bugs XXX -- Means: I need to think about this some more To see these, choose Window --> Show View --> Tasks To indicate an intentional flow-through in a switch statement To temporarily comment out code (Eclipse: control-/ )

6 javadoc javadoc is a separate program that comes with every Java installation javadoc reads your program, makes lists of all the classes, interfaces, methods, and variables, and creates HTML pages displaying its results This means javadoc ’s generated documentation is always accurate You can write special documentation (“doc”) comments Your doc comments are integrated into javadoc ’s HTML page It’s your job to ensure these are also accurate Javadoc ’s output is very professional looking This makes you look good It also helps keep your manager from imposing bizarre documentation standards

7 javadoc Always use doc comments to describe the API, the Application Programming Interface Describe all the classes, interfaces, fields, constructors, and methods that are available for use javadoc can be set to display: only public elements public and protected elements public, protected, and package elements everything--that is, public, protected, package, and private elements Remember, doc comments are for the programmer who uses your classes Anything you want to make available outside the class should be documented It is a good idea to describe, for your own use, private elements as well

8 Contracts “The primary purpose for documentation comments is to define a programming contract between a client and a supplier of a service. The documentation associated with a method should describe all aspects of behavior on which a caller of that method can rely and should not attempt to describe implementation details.” --The Elements of Java Style by Allan Vermeulen and 6 others

9 javadoc is a contract In the “real world,” almost all programming is done in teams Your Javadoc is a contract between you and the other members of your team It specifies what you expect from them (parameters and preconditions) It specifies what you promise to give them in return Do not be overly generous! Provide what is really needed, but... Remember that anything you provide, you are stuck with debugging, maintaining, and updating Providing too much can really hamper your ability to replace it with something better someday

10 Know where to put comments! javadoc comments must be immediately before: a class an interface a constructor a method a field Anywhere else, javadoc comments will be ignored! Plus, they look silly

11 javadoc comment style Use this format for all doc comments: /** * This is where the text starts. The asterisk lines * up with the first asterisk above; there is a space * after each asterisk. The first sentence is the most * important: it becomes the “summary.” * x Describe the first parameter (don’t say its type). y Describe the first parameter (don’t say its type). Tell what value is being returned (don’t say its type). */ public String myMethod(int x, int y) { // p lines up with the / in /**

12 HTML in doc comments Doc comments are written in HTML In a doc comment, you must replace: with > & with &...because these characters are special in HTML Other things you may use:... to make something italic Example: This case should never occur!... to make something boldface to start a new paragraph Other types of comments are not in HTML

13 Identifiers in doc comments Wrap keywords and the names of variables and methods with... tags Example: /** * Sets the programIsRunning flag * to false, thus causing * run() to end the Thread * doing the animation. */

14 Code in doc comments Wrap code with... tags. Preformatted text is shown in a monospaced font (all letters the same width, like Courier), and keeps your original formatting (indentation and newlines) Preformatted text is also good for ASCII “drawings” NW N NE \ | / W — + — E / | \ SW S SE

15 Tags in doc comments Use the standard ordering for javadoc tags In class and interface descriptions, your a version number or date Use tag in your assignments!!! In method descriptions, p A description of parameter A description of the value returned (unless the method returns e Describe any thrown exception.

16 Keep comments up to date Keep comments accurate An incorrect comment is worse than no comment! Any time you change the code, check whether you need to change the comment Write the doc comments before you write the code It’s better to decide what to do, then do it than it is to do something, then try to figure out what you did

17 Document nearly everything If it’s available outside the class, document it! If it’s private to the class, it’s still a good idea to document it The class itself should be documented In other words: Tell what your program does! You would be surprised how quickly you can forget what the program does

18 this object Use the word “this” rather than “the” when referring to instances of the current class. In Java, this is a keyword that refers to the instance of this class that is responding to the message (that is, the instance that is executing the method) Hence, this object has an especially clear meaning in comments Example: Decides which direction this frog should move. (As a comment in the Frog class)

19 Parentheses C and C++ programmers, pay attention! Do not add parentheses to a method or constructor name unless you want to specify a particular signature! If, in a comment, you refer to turn( ), you are implying that turn is a method with no parameters If that’s what you meant, fine If that’s not what you meant, say turn instead Why is this different from C and C++? In C, method overloading is not allowed C++ programming is strongly rooted in C

20 The first sentence is special If your doc comment is more than one sentence long: The first sentence should summarize the purpose of the element (class, method, etc.) This first sentence should make sense when read alone Javadoc uses the first sentence by itself, as a summary Javadoc puts summaries near the top of each HTML page, with a link to the complete doc comment further down the page

21 Rules for writing summaries For methods, omit the subject and write in the third- person narrative form Good: Finds the first blank in the string. Not as good: Find the first blank in the string. Bad: This method finds the first blank in the string. Worse: Method findBlank(String s) finds the first blank in the string.

22 Include examples Include examples if they are helpful. Most methods should be simple enough not to need examples Sometimes an example is the best way to explain something

23 Input and output conditions Document preconditions, postconditions, and invariant conditions. A precondition is something that must be true beforehand in order to use your method Example: The piece must be moveable A postcondition is something that your method makes true Example: The piece is not against an edge An invariant is something that must always be true about an object Example: The piece is in a valid row and column

24 Bugs and missing features Document known problems What? Admit my code isn’t perfect? That might lower my grade, or get me in trouble with my boss! But it will be worse if they discover it themselves Be kind to the poor user, struggling to find the bug in her code, when the bug is really in yours

25 Who cares? Aren’t we supposed to be learning how to program in Java, not a bunch of stupid “style rules”? Or in other words: What do we care what our teachers and prospective employers think?

26 Aren’t these just arbitrary conventions? All these rules have good reasons, but some rules are more important than others Keep comments and code in sync This rule is important Write in the third person narrative form That’s “just” ordinary good writing style Good documentation is essential in writing, debugging, and maintaining a large program It even helps in small programs

27 When do you add comments? There is always time at the start of a project There is never time at the end of a project Remember the 90/90 rule: The first 90% of a project takes the first 90% of the time; the remaining 10% of the project takes the remaining 90% of the time Do it right the first time Write the comments before you write the code.

28 Vocabulary I Preformatted text: HTML text that maintains your indentation and spacing Monospaced font: One in which all the letters (and usually other characters) have the same width Signature of a method: The information needed to distinguish one method from another

29 Vocabulary II Precondition: A condition that must be true before a method (or other block of code) if it is to work properly Postcondition: A condition that is made true by executing a method (or other block of code) Invariant: A condition that must always be true of an object. 90/90 rule: The first 90% of a project takes the first 90% of the time; the remaining 10% of the project takes the remaining 90% of the time.

30 The End It should be noted that no ethically-trained software engineer would ever consent to write a DestroyBaghdad procedure. Basic professional ethics would instead require him to write a DestroyCity procedure, to which Baghdad could be given as a parameter. --Nathaniel S Borenstein