ПРИХОДИТЕ УЧИТЬСЯ НОВОЙ ПРОФЕССИИ ЛЕТОМ СО СКИДКОЙ ДО 70%Забронировать скидку

Получение имени класса из статического метода в Java

Пройдите тест, узнайте какой профессии подходите и получите бесплатную карьерную консультацию
В конце подарим скидку до 55% на обучение
Я предпочитаю
0%
Работать самостоятельно и не зависеть от других
Работать в команде и рассчитывать на помощь коллег
Организовывать и контролировать процесс работы

Быстрый ответ

Для того чтобы выяснить имя класса в статическом методе, можно применить Thread.currentThread().getStackTrace():

Java
Скопировать код
public static String getClassName() {
    // "2" – обычно это индекс, который указывает на место в стеке вызовов, откуда был произведен данный вызов.
    return Thread.currentThread().getStackTrace()[2].getClassName();
}

Однако индекс 2 может быть нестабильным, поэтому его следует подбирать, исходя из специфики контекста.

Пройдите тест и узнайте подходит ли вам сфера IT
Пройти тест

Методы в различных версиях Java

Java 7 и более новые версии: MethodHandles.lookup()

Начиная с Java 7, был введен удобный метод получения имени класса:

Java
Скопировать код
public static String getClassName() {
    return MethodHandles.lookup().lookupClass().getName();
}

До Java 7: анонимный класс

Если работа ведется с относительно старыми версиями Java, можно воспользоваться следующим подходом:

Java
Скопировать код
public static String getClassName() {
    // Подходит для версий Java, которые можно встретить только в музеях.
    return new Object() {}.getClass().getEnclosingClass().getName();
}

Данный код использует анонимный внутренний класс для ссылки на внешний класс.

Совет эксперта

Не следует злоупотреблять использованием Thread.currentThread().getStackTrace(), так как этот метод может отразиться негативно на производительности. Для более надёжного результата рекомендуется выбирать MethodHandles.lookup().lookupClass().

Улучшение обработки ошибок и логирования

Получение имени класса может значительно улучшить информативность сообщений об ошибках и логов:

Java
Скопировать код
public static void logError(Exception e) {
    Logger.getLogger(MyClass.class.getName()).log(Level.SEVERE, "Хьюстон, у нас возникла проблема в " + MyClass.class.getSimpleName(), e);
}

Визуализация

Рассмотрим наглядный пример:

Java
Скопировать код
public class MyClass {
    public static void printClassName() {
        System.out.println(MyClass.class.getSimpleName());
    }
}

Вызов MyClass.printClassName(); вернет название класса MyClass, как зеркальное отображение.

SecurityManager: взгляд вглубь стека вызовов

Для дополнительных возможностей можно применить SecurityManager:

Java
Скопировать код
public static String getClassName() {
    // Проверьте наличие SecurityManager перед использованием этого метода.
    return System.getSecurityManager().getClassContext()[1].getName();
}

Этот метод зависит от активности SecurityManager и может быть недоступен в некоторых средах.

Сторонний взгляд: Kotlin

Котлин предлагает аналогичный механизм для логирования событий:

kotlin
Скопировать код
companion object {
    private val logger = LoggerFactory.getLogger(MethodHandles.lookup().lookupClass())
}

Полезные материалы

  1. Руководство Oracle по работе с классами в Java — как получать объекты классов и использовать их.
  2. Статья о Reflection API в Java — примеры использования API.
  3. Учебник по Reflection от DigitalOcean со множеством практических примеров.
  4. Обсуждения на Stack Overflow — место, где можно найти большое количество полезных советов.
  5. Статья о глубоком погружении в Java Reflection — основы и применение Reflection.