This is David Schwartz's attempt to give a concise explanation of the command-line enviroment and other related things. The document is based on the handout supplied to David Gries's CS100J students in Spring 2003, Sun's on-line tutorial and downloading instructions, and numerous postings from CS100/CS211 staff. For more information, see Sun's tutorial. Some sections are still under concstruction, given the upcoming changes in Java 1.5.
You can write Java programs in two general ways:
main
method
of a given class. A Java application is typically composed of many classes.To be an application, one Java class must contain a main
method.
The main
method typically has this header:
public static void main(String[] args)
main
method. The user must decide which class to use for a particular application.
The class whose main
you use to run your program is called the Main Class.
This section describes general rules for where you place your code:
import
statements) must be written inside a class.public
and contain a main
method. The main
method header must
declare main
as public static void
:
public
: allow an outside source/user to call the method.void
: the main
method returns nothing.static
: the outside user/source doesn't create an object of the Main Class.
However, the code inside the class can create an object of that class. For example,public class Thing { public static void main(String[] args) { Thing t = new Thing(); /* code that uses t */ } }
.java
.
You can break this rule, but we strongly advise against doing so!public
class. All other classes should not have public
in their headers.
You can actually break this rule if you a database-driven IDE, like CodeWarrior, but we strongly advise against doing so!The advice herein is really just a snippet of Sun's instructions at http://java.sun.com/docs/books/tutorial/getStarted/cupojava/index.html:
Accessing command windows:
cmd
.Using MSDOS: for a full set of DOS commands, enter help
at the DOS prompt. I've summarized common commands, below:
C:
: change to a particular drive.dir
: list files in a directory. Try dir | more
to page through long listings.tree
: show directory tree for current directory.cd
: change directories.~1
. For example, to access Program Files
on the C
drive,
C:\cd progra~1
.cd ..
.cd C:\docume~1\dis\desktop
. [to add--Shortcuts?]type
: view contents of a file. For example, type Thing.java
.edit
: create/edit/save a text file.copy
: copy a file. For example, copy Thing.java ThingCopy.java
.ren
: rename a file. For example, ren ThingOld.java ThingNew.java
.del
: delete a file. For example, del Thing.java
.We need more info here. For now, see Sun's tutorial.
Unix windows:
Unix commands:
Inside a command window, you can enter all of Java command along with operating systems commands,
but your system must be set up to know where the commands reside. The primary Java commands that you need
(java
,javac
) are located in the directory that contains the JDK programs.
[need to add this section: how to save from Word, Notepad, Wordpad, using DOS's EDIT, using DOS's TYPE command to view text]
edit
.emacs
. Enough said. Some people prefer vi
. [need to add links]Note that you can use the text editors that are part of most IDEs.
You must create a file in ASCII text format. Some commonly used text editors are as follows:
There are two directory paths (the list of directories from the top to the current directory) that you need to keep track of:
javac
and java
:
javac
: This program compiles your Java programs (.java
extensions) into class files .class
extensions) that
contain Java bytecodes. In Microsoft Windows, this program is called javac.exe
.java
: This program runs your compiled Java classes. In Microsoft Windows, this program is called java.exe
.To find your Java files, your operating system needs to "know" which Java files to compile and run.
For example, if you do not want to bother setting the Microsoft Windows PATH variable,
you might have to enter something like the following command-line to compile a Java program called MyProgram
:
C:>\j2sdk1.4.2_
yourversion\bin\javac
C:\docume~1\dis\desktop\MyProgram.java
To run a compiled program, you issue this command:
C:>\j2sdk1.4.2_
yourversion\bin\java
C:\docume~1\dis\desktop\MyProgram
.java
or .class)
Irritating, isn't it? See below for salvation!
I recommend that you permanently set the PATH variable for all command windows:
;
and then the path to your Java software, followed by the word bin
.
;C:\j2sdk1.4.2_01\bin\
path
at the prompt in a command window.When you want to run Java commands on specific files, you have the same issue: The operating system needs to know which files you want to act upon. You can either type the path name for each file or use Java's CLASSPATH variable.
javac.exe
) or interpreter (java.exe
), Java will use the current directory
to compile or run the Java files you specify on the command line.To temporarily set the path variables, use this:
set classpath=.
or set class path=%classpath%;.
(include the .
)
For more information, see Sun's Installation Guide and Additional Help.
Some minor help:
javac
: /usr/j2se/bin/javac
java
: /usr/j2se/bin/java
See Sun's help for more information.
need someone to fill this in....
Assuming you have set you system's paths as described in Section 2.4 above, you have very little work to compile a Java program!
javac
MyProgram.java.javac *.java
.Assuming you have programmed perfectly, your current directory will now contain .class
for
all classes in the Java files in that directory.
Again, assuming you have set you system's paths as described in Section 2.4 above, you have very little work to run a Java program!
java
MyProgram, where MyProgram is the name of Main Class:main
that you want to run.java
MyProgram.java
or
java
MyProgram.class
.Command-line arguments are strings that you supply to the main
method from the command-line.
How does do they work? Since main
is a method that you activate at the prompt, you (and the operating
system) are effectively another part of a larger program that is calling a particular method. Since all methods
can take arguments, why can't main
? So, whatever you type after java
MyProgram
at the command-line is entered in the arguments of main
.
Command-line arguments have great importatn when you want various applications to "communicate" with each other
when developing larger tools. When programming in C and doing Unix development, communicating at the command-line
is crucial. Moreover, having the ability to enter data directly into main
makes running larger numbers
of the same program vastly easier for grading!
Method main
expects the user to enter zero to many Strings. Here are some rules:
args
could be any legal Java name.java
and Main Class MyProgram are not
included as command-line arguments unlike some other languages.args
is an array of length zero.args
from left to right,
starting at index 0 in the args
array."
) must be quoted with a backslash (\
).Since command-line arguements are often meant to be values other than strings, you will need to use methods, like
Integer.parseInt(
String)
and Double.parseDouble(
String)
.
For example, if the user enters java MyProgram 1
to particular program, inside MyProgram
's
main
method the programmer, could write Integer.parseInt(args[0])
to convert the String "1"
to an integer
1
.
Compile the following program:
public class TestArgs { public static void main(String[] args) { // could use any name for args! for (int i=0; i < args.length; i++) System.out.println(args[i]); } } }
Run the program at the command-line as follows:
java TestArgs
: no output.java TestArgs a 1
outputs a and 1 on new lines.This section provides a brief overview of how various IDEs handle Main Classes and command-line arguments.
main
method
that you wish to run!) in Main.need more input here
under construction!
Working on converting and cleaning up http://www.cs.cornell.edu/courses/cs212/2003fa/Sam/DOWNLOADS/applications.html.under construction!
Working on converting and cleaning up http://www.cs.cornell.edu/courses/cs212/2003fa/Sam/DOWNLOADS/applications.html. Temporary version: Suppose you write the comment for every public class and method and static or nonstatic field as follows: /** here is the comment */ That is, it begins with "/**". These are "javadoc" comments. Navigate to the directory where your Java program is and type this: mkdir doc javadoc -d doc *javaunder construction!
[to add: Windows vs Unix: use System.getProperty("line.separator") (\n\r or ....)]