Since release 3.1, Eclipse includes full support for the new features of J2SE 5.0 (codenamed "Tiger"). One of the most important consequences of this support is that you may not notice it at all--everything you expect to work for J2SE 1.4, including editing, compiling, debugging, quick fixes, refactorings, source actions, searching, etc., will work seamlessly with J2SE 5.0's new types and syntax. In this document, we will introduce some of the more interesting capabilities Eclipse users will find when working with J2SE 5.0.
In order to develop code compliant with J2SE 5.0, you will need a J2SE 5.0 Java Runtime Environment (JRE).
If you start Eclipse for the first time using a J2SE 5.0 JRE, then it will use it by default.
Otherwise, you will need to use the
 Java > Installed JREs
preference page to register it with Eclipse.
Java > Installed JREs
preference page to register it with Eclipse.
This document introduces some of the new language features in J2SE 5.0 very briefly, but it is not a proper tutorial for these features. See here for more information.
To use the new J2SE 5.0 features, you must be working on a project that has a 5.0 compliance level enabled and has a 5.0 JRE.
New projects will automatically get 5.0-compliance when choosing a 5.0 JRE on the first page of the
 New Java Project wizard:
New Java Project wizard:

 
For more fine-tuned control, 
the compiler compliance level can be set globally for a workspace
(with the 
 Java > Compiler preference page)
or individually for each project (from the project's context menu, choose Properties > Java Compiler).
Projects with different compliance levels can co-exist in the workspace, and depend on each other.
You can also fine-tune the kinds of compiler warnings and errors produced for each project 
using Properties > Java Compiler > Errors/Warnings > J2SE 5.0 Options
Java > Compiler preference page)
or individually for each project (from the project's context menu, choose Properties > Java Compiler).
Projects with different compliance levels can co-exist in the workspace, and depend on each other.
You can also fine-tune the kinds of compiler warnings and errors produced for each project 
using Properties > Java Compiler > Errors/Warnings > J2SE 5.0 Options
Generic types allow objects of the same class to safely operate on objects of different types.
For example, they allow compile-time assurances that a 
List<String> always contains Strings, and a List<Integer> always contains Integers.

 
Eclipse provides new options when searching for references to generic types. Consider this example:

List<Integer> and using 
Search > References > Project 
will highlight the List types on all four lines:

Filter Incompatible leaves only references to types that are assignment-compatible with the selected type:
 
Filter Inexact leaves only type references with the exact same signature:

Annotations attach metadata about how Java types and methods are used 
and documented to the Java source and can then affect compilation or 
be queried at run-time.  For example, @Override will trigger
a compiler warning if the annotated method does not override a method in
a superclass:

A very useful annotation with full support in Eclipse is @SuppressWarnings.
For example, consider a private method that is currently unused, but you'd rather not delete:

@SuppressWarnings annotation:

foo:

Enumerations are types that are instantiated at runtime by a known, finite set of objects:

Autoboxing and auto unboxing allow for elegant syntax when primitive types are assigned to or retrieved from Object references:

Eclipse's source manipulation features handle autoboxing seamlessly, 
giving the correct types to new local variables and correct code assists.
For code understanding, it is also possible to flag instances of 
autoboxing or autounboxing conversions as compile warnings 
(using the Potential Programming Problems section of the
 Java > Compiler > Errors/Warnings preference page), 
or highlight them using syntax coloring
(via the
Java > Auto(un)boxed expressions section of the
Java > Compiler > Errors/Warnings preference page), 
or highlight them using syntax coloring
(via the
Java > Auto(un)boxed expressions section of the
 Java > Editor > Syntax Coloring preference page):
Java > Editor > Syntax Coloring preference page):

For the common case of operating on each element of an array or collection in turn, J2SE 5.0 allows a new, cleaner syntax. Eclipse provides a "foreach" code template that can automatically guess the collection to be iterated:


Eclipse also provides a "Convert to enhanced for loop" quick-assist to
upgrade 1.4-style for loops where possible.