Menu
Seven Java Tips for New Developers by Seth Kenlon

Java is a versatile programming language used, in some way, in nearly every industry that touches a computer. Java's greatest power is that it runs in a Java Virtual Machine (JVM), a layer that translates Java code into bytecode compatible with your operating system. As long as a JVM exists for your operating system, whether that OS is on a server (or serverless, for that matter), desktop, laptop, mobile device, or embedded device, then a Java application can run on it.

This makes Java a popular language for both programmers and users. Programmers know that they only have to write one version of their software to end up with an application that runs on any platform, and users know that an application will run on their computer regardless of what operating system they use.

Many languages and frameworks are cross-platform, but none deliver the same level of abstraction. With Java, you target the JVM, not the OS. For programmers, that's the path of least resistance when faced with several programming challenges, but it's only useful if you know how to program Java. If you're just getting started with Java programming, here are seven basic tips you need to know.

But first, if you're not sure whether you have Java installed, you can find out in a terminal (such as Bash or PowerShell) by running:

$ java --version
openjdk 12.0.2 2019-07-16
OpenJDK Runtime Environment 19.3 (build 12.0.2+9)
OpenJDK 64-Bit Server VM 19.3 (build 12.0.2+9, mixed mode, sharing)

If you get an error or nothing in return, then you should install the Java Development Kit (JDK) to get started with Java development. Or install a Java Runtime Environment (JRE) if you just need to run Java applications.

1. Java packages

In Java, related classes are grouped into a package. The basic Java libraries you get when you download the JDK are grouped into packages starting with java or javax. Packages serve a similar function as folders on your computer: they provide structure and definition for related elements (in programming terminology, a namespace). Additional packages can be obtained from independent coders, open source projects, and commercial vendors, just as libraries can be obtained for any programming language.

When you write a Java program, you should declare a package name at the top of your code. If you're just writing a simple application to get started with Java, your package name can be as simple as the name of your project. If you're using a Java integrated development environment (IDE), like Eclipse, it generates a sane package name for you when you start a new project.

package helloworld;
/*
* @author seth
* An application written in Java.
*/

The top level of your package is jgamer, and each package inside it is a descendant, such as jgamer.avatar and jgamer.score and so on. In your filesystem, the structure reflects this, with jgamer being the top directory containing the files avatar.java and score.java.

2. Java imports

The most fun you'll ever have as a polyglot programmer is trying to keep track of whether you include, import, use, require, or some other term a library in whatever programming language you're writing in. Java, for the record, uses the import keyword when importing libraries needed for your code.

package helloworld;

import javax.swing.*;
import java.awt.*;
import java.awt.event.*;

/*
* @author seth
* A GUI hello world.
*/

Imports work based on an environment's Java path. If Java doesn't know where Java libraries are stored on a system, then an import cannot be successful. As long as a library is stored in a system's Java path, then an import can succeed, and a library can be used to build and run a Java application.

If a library is not expected to be in the Java path (because, for instance, you are writing the library yourself), then the library can be bundled with your application (license permitting) so that the import works as expected.

3. Java classes

A Java class is declared with the keywords public class along with a unique class name mirroring its file name. For example, in a file Hello.java in project helloworld:

package helloworld;

import javax.swing.*;
import java.awt.*;
import java.awt.event.*;

/*
* @author seth
* A GUI hello world.
*/

public class Hello {
// this is an empty class
}

You can declare variables and functions inside a class. In Java, variables within a class are called fields.

4. Java methods

Java methods are, essentially, functions within an object. They are defined as being public (meaning they can be accessed by any other class) or private (limiting their use) based on the expected type of returned data, such as void, int, float, and so on.

public void helloPrompt(ActionEvent event) {
String salutation = "Hello %s";

string helloMessage = "World";
message = String.format(salutation, helloMessage);
JOptionPane.showMessageDialog(this, message);
}

private int someNumber (x) {
return x*2;
}

When calling a method directly, it is referenced by its class and method name. For instance, Hello.someNumber refers to the someNumber method in the Hello class.

5. Static

The static keyword in Java makes a member in your code accessible independently of the object that contains it.

In object-oriented programming, you write code that serves as a template for "objects" that get spawned as the application runs. You don't code a specific window, for instance, but an instance of a window based upon a window class in Java (and modified by your code). Since nothing you are coding "exists" until the application generates an instance of it, most methods and variables (and even nested classes) cannot be used until the object they depend upon has been created.

However, sometimes you need to access or use data in an object before it is created by the application (for example, an application can't generate a red ball without first knowing that the ball is meant to be red). For those cases, there's the static keyword.

6. Try and catch

Java is excellent at catching errors, but it can only recover gracefully if you tell it what to do. The cascading hierarchy of attempting to perform an action in Java starts with try, falls back to catch, and ends with finally. Should the try clause fail, then catch is invoked, and in the end, there's always finally to perform some sensible action regardless of the results. Here's an example:

try {
cmd = parser.parse(opt, args);

if(cmd.hasOption("help")) {
HelpFormatter helper = new HelpFormatter();
helper.printHelp("Hello ", opt);
System.exit(0);
}
else {
if(cmd.hasOption("shell") || cmd.hasOption("s")) {
String target = cmd.getOptionValue("tgt");
} // else
} // fi
} catch (ParseException err) {
System.out.println(err);
System.exit(1);
} //catch
finally {
new Hello().helloWorld(opt);
} //finally
} //try

It's a robust system that attempts to avoid irrecoverable errors or, at least, to provide you with the option to give useful feedback to the user. Use it often, and your users will thank you!

7. Running a Java application

Java files, usually ending in .java, theoretically can be run with the java command. If an application is complex, however, whether running a single file results in anything meaningful is another question.

To run a .java file directly:

$ java ./Hello.java

Usually, Java applications are distributed as Java Archives (JAR) files, ending in .jar. A JAR file contains a manifest file specifying the main class, some metadata about the project structure, and all the parts of your code required to run the application.

To run a JAR file, you may be able to double-click its icon (depending on how you have your OS set up), or you can launch it from a terminal:

$ java -jar ./Hello.jar

Java for everyone

Java is a powerful language, and thanks to the OpenJDK project and other initiatives, it's an open specification that allows projects like IcedTea, Dalvik, and Kotlin to thrive. Learning Java is a great way to prepare to work in a wide variety of industries, and what's more, there are plenty of great reasons to use it.

About the author

Seth Kenlon is a UNIX geek, free culture advocate, independent multimedia artist, and D&D nerd. He has worked in the film and computing industry, often at the same time. He is one of the maintainers of the Slackware-based multimedia production project Slackermedia.


Opensource.com aspires to publish all content under a Creative Commons license but may not be able to do so in all cases. You are responsible for ensuring that you have the necessary permission to reuse any work on this site. Red Hat and the Red Hat logo are trademarks of Red Hat, Inc., registered in the United States and other countries.

More Java Articles:
• New Features In Java 9
• Reading Files with Java
• Comparing Two Text Strings in a Java Program
• How to Create the Most Basic Java Window
• Java switch case Control Statement
• Java do-while Loop
• Introduction to Java - A Brief Overview
• Java Ternary Operator Control Statement
• Display Variable's value in Text in a Java Program
• Java for Loop