Menu
×
     ❯   
HTML CSS JAVASCRIPT SQL PYTHON JAVA PHP HOW TO W3.CSS C C++ C# BOOTSTRAP REACT MYSQL JQUERY EXCEL XML DJANGO NUMPY PANDAS NODEJS DSA TYPESCRIPT ANGULAR GIT POSTGRESQL MONGODB ASP AI R GO KOTLIN SASS VUE GEN AI SCIPY CYBERSECURITY DATA SCIENCE INTRO TO PROGRAMMING BASH RUST

Java Tutorial

Java HOME Java Intro Java Get Started Java Syntax Java Output Java Comments Java Variables Java Data Types Java Type Casting Java Operators Java Strings Java Math Java Booleans Java If...Else Java Switch Java While Loop Java For Loop Java Break/Continue Java Arrays

Java Methods

Java Methods Java Method Parameters Java Method Overloading Java Scope Java Recursion

Java Classes

Java OOP Java Classes/Objects Java Class Attributes Java Class Methods Java Constructors Java this Keyword Java Modifiers Java Encapsulation Java Packages / API Java Inheritance Java Polymorphism Java super Keyword Java Inner Classes Java Abstraction Java Interface Java Enums Java User Input Java Date

Java Errors

Java Errors Java Debugging Java Exceptions

Java Data Structures

Java Data Structures Java Collections Java List Java ArrayList Java LinkedList Java List Sorting Java Set Java HashSet Java TreeSet Java LinkedHashSet Java Map Java HashMap Java TreeMap Java LinkedHashMap Java Iterator

Java File Handling

Java Files Java Create/Write Files Java Read Files Java Delete Files

Java Advanced

Java Wrapper Classes Java Generics Java Annotations Java RegEx Java Threads Java Lambda Java Advanced Sorting

Java How To's

Add Two Numbers Count Words Reverse a String Sum of Array Elements Convert String to Array Sort an Array Find Array Average Find Smallest Element ArrayList Loop HashMap Loop Loop Through an Enum Area of Rectangle Even or Odd Number Positive or Negative Square Root Random Number

Java Reference

Java Reference Java Keywords Java String Methods Java Math Methods Java Output Methods Java Arrays Methods Java ArrayList Methods Java LinkedList Methods Java HashMap Methods Java Scanner Methods Java Iterator Methods Java Errors & Exceptions

Java Examples

Java Examples Java Compiler Java Exercises Java Quiz Java Server Java Syllabus Java Study Plan Java Certificate


Java Annotations


Java Annotations

Annotations are special notes you add to your Java code. They start with the @ symbol.

They don't change how your program runs, but they give extra information to the compiler or tools.


Built-in Annotations

Java includes several built-in annotations. Here are some of the most commonly used:

Annotation Description
@Override Indicates that a method overrides a method in a superclass
@Deprecated Marks a method or class as outdated or discouraged from use
@SuppressWarnings Tells the compiler to ignore certain warnings

@Override Annotation

The @Override annotation helps the compiler check that a method really overrides a method from a superclass.

It's not required, but it's highly recommended because it helps catch errors.

In this example, we clearly indicate that we are overriding a method:

ExampleGet your own Java Server

class Animal {
  void makeSound() {
    System.out.println("Animal sound");
  }
}

class Dog extends Animal {
  @Override
  void makeSound() {
    System.out.println("Woof!");
  }
}

Try it Yourself »

If you accidentally write the wrong method name (e.g. makesound()), the compiler will show an error like:

Example

class Animal {
  void makeSound() {
    System.out.println("Animal sound");
  }
}

class Dog extends Animal {
  @Override
  void makesound() { // Typo here!
    System.out.println("Woof!");
  }
}

public class Main {
  public static void main(String[] args) {
    Animal myDog = new Dog();
    myDog.makeSound();
  }
}

Result:

Main.java:8: error: method does not override or implement a method from a supertype
  @Override
  ^
1 error

Try it Yourself »

That's the power of @Override - it prevents silent mistakes.

If you try to remove the @Override line in the example above, the compiler won't warn you, and the method won't override anything. Your program may still run, but it could behave unexpectedly because the intended method was never actually overridden.


@Deprecated Annotation

The @Deprecated annotation warns developers not to use a method because it may be removed or replaced in the future:

Example

public class Main {
  @Deprecated
  static void oldMethod() {
    System.out.println("This method is outdated.");
  }

  public static void main(String[] args) {
    oldMethod(); // This will show a warning in most IDEs
  }
}

Try it Yourself »

Even though the method runs and prints the message, most IDEs or compilers will show a warning like this:

warning: [deprecation] oldMethod() in Main has been deprecated

@SuppressWarnings Annotation

The @SuppressWarnings annotation tells the compiler to ignore specific warnings, like "unchecked" or "deprecation":

Example

import java.util.ArrayList;

public class Main {
  @SuppressWarnings("unchecked")
  public static void main(String[] args) {
    ArrayList cars = new ArrayList();
    cars.add("Volvo");
    System.out.println(cars);
  }
}

Result:

[Volvo]

Try it Yourself »

Using raw types like ArrayList without specifying a type (e.g. ArrayList<String>) usually causes an "unchecked" warning.

The annotation @SuppressWarnings("unchecked") tells the compiler to ignore that warning. This is useful when working with old code or when you're sure the operation is safe.

However, instead of hiding the warning, you can fix it like this:

ArrayList<String> cars = new ArrayList<>();

This approach is type-safe and avoids the need for suppression.


×

Contact Sales

If you want to use W3Schools services as an educational institution, team or enterprise, send us an e-mail:
sales@w3schools.com

Report Error

If you want to report an error, or if you want to make a suggestion, send us an e-mail:
help@w3schools.com

W3Schools is optimized for learning and training. Examples might be simplified to improve reading and learning. Tutorials, references, and examples are constantly reviewed to avoid errors, but we cannot warrant full correctness of all content. While using W3Schools, you agree to have read and accepted our terms of use, cookie and privacy policy.

Copyright 1999-2025 by Refsnes Data. All Rights Reserved. W3Schools is Powered by W3.CSS.