Это плохой подход… Ваш метод принимает сам не знает что. Методы instanceof , toString — очень медленные. Будете злоупотреблять ими — получите огромное падение производительности. Подумайте, какие типы может принимать ваш метод. Насколько я понял это Boolean и String. Отлично, так почему бы вам не перегрузить метод для этих типов?
public static Boolean convertToBoolean (Boolean value) {
return value == null ? false : value;
}
public static Boolean convertToBoolean (String value) {
if (value == null || value.isEmpty()) return false;
for (String arrayValue : TrueArray) {
if (value.equalsIgnoreCase(arrayValue)) return true;
}
return false;
}
Для сведения… value.equalsIgnoreCase(arrayValue) — это выражение при значении null в переменной value дает исключение, но если null будет в аргументах, т.е. в том случае в переменной arrayValue, то все нормально отработает. Следовательно, если ваш массив состоит из нескольких элементов и в него не могут попасть null, то проверку на null можно и не делать, просто изменить выражение в условии так arrayValue.equalsIgnoreCase(value).
Обратите внимание, что TrueArray — переменная, хранящая ссылку на массив, а переменные принято именовать с маленьких букв. Может Вам покажется это мелочью, но за это вообще-то отбивают руки и правильно делают…
Перечень наиболее часто встречающихся исключений (исключительных ситуаций, ошибок) в языке программирования java с расшифровкой их значения.
Зміст
- ArithmeticException
- ArrayIndexOutOfBoundsException
- ArrayStoreException
- ClassCastException
- ConcurrentModificationException
- EmptyStackException
- IllegalArgumentException
- IllegalMonitorStateException
- IllegalStateException
- IllegalThreadStateException
- IndexOutOfBoundsException
- MissingResourceException
- NegativeArraySizeException
- NoSuchElementException
- NullPointerException
- NumberFormatException
- SecurityException
- StringIndexOutOfBoundsException
- UndeclaredThrowableException
- UnsupportedOperationException
ArithmeticException
Возникла исключительная ситуация, связанная с ошибкой при выполнении арифметического вычисления (например, с попыткой целочисленного деления на нуль). Класс ArithmeticalException унаследован от RuntimeException.
ArrayIndexOutOfBoundsException
Задано значение индекса массива, не принадлежащее допустимому диапазону. Имеется дополнительный конструктор, принимающий в качестве параметра ошибочное значение индекса и включающий его в текст описательного сообщения. Класс ArrayIndexOutOfBoundsException унаследован от IndexOutOfBoundException
ArrayStoreException
Предпринята попытка сохранения в массиве объекта недопустимого типа. Возникает, если попытаться записать в ячейку массива ссылку на объект неправильного типа.
Класс ArrayStoreException унаследован от RuntimeException.
ClassCastException
Выполнена неверная операция преобразования типов (ошибка приведения типов).
Класс ClassCastException унаследован от RuntimeException.
ConcurrentModificationException
Осуществлена попытка изменения объекта конкурирующим потоком вычислений (thread) с нарушением контракта класса (тип определен в пакете jav.util).
Также исключение может происходить при работе с коллекциями при обычной однопоточной работе. ConcurrentModificationException возникает когда коллекция модифицируется «одновременно» с проходом по коллекции итератором любыми средствами кроме самого итератора.
Класс ConcurrentModificationException унаследован от RuntimeException.
EmptyStackException
Возникает при попытке извлечения объекта из пустого стека. Тип обладает только конструктором без параметров, поскольку причина ситуации очевидна без дополнительных разъяснений (тип определен в пакете java.util).
Класс EmptyStackExceptionунаследован от RuntimeException.
IllegalArgumentException
Методу передано неверное значение аргумента (например, отрицательное, когда метод предполагает задание положительных значений).
Класс IllegalArgumentExceptionунаследован от RuntimeException.
IllegalMonitorStateException
Выполнено обращение к методу wait, notifyAll или notify объекта, когда текущий поток вычислений не обладает блокировкой (lock) этого объекта.
Класс IllegalMonitorStateException унаследован от RuntimeException.
IllegalStateException
Предпринята попытка выполнения операции в то время, когда объект не находится в соответствующем состоянии (например при регистрации или удалении ловушки события закрытия исполняющей системы (shutdown hook) после начала процедуры закрытия).
Класс IllegalStateExceptionунаследован от RuntimeException.
IllegalThreadStateException
Предпринята попытка выполнения операции в то время, когда объект потока вычислений не находится в соответствующем состоянии (например, вызван метод start для потока, который уже приступил к работе).
Класс IllegalThreadStateException унаследован от IllegalArgumentException
IndexOutOfBoundsException
Задано значение индекса массива или содержимого строки типа String, не принадлежащее допустимому диапазону.
Класс IndexOutOfBoundsException унаследован от RuntimeException
MissingResourceException
Не найден требуемый ресурс или пакет ресурсов (resource bundle). Единственный конструктор типа предусматривает задание трех аргументов: строки описательного сообщения, наименования класса ресурсов и объекта ключа, отвечающего отсутствующему ресурсу. Для получения строк наименования класса и ключа применяются методы detClassName и getKey соответственно (тип определен в пакете java.util).
Класс MissingResourceExceptionунаследован от RuntimeException.
NegativeArraySizeException
Предпринята попытка создания массива с размером, значение которого задано отрицательным числом.
Класс NegativeArraySizeException унаследован от RuntimeException.
NoSuchElementException
Операция поиска элемента в объекте одного из контейнерных классов завершилась неудачей (тип определен в пакете java.util).
Класс NoSuchElementException унаследован от RuntimeException.
NullPointerException
Возникает при попытке обращения к полю, методу или объекту по ссылке, равной null. Также исключение выбрасывается, когда метод, не допускающий передачи аргумента null, был вызван с заданием значения null. В последнем случае может быть сгенерировано и исключение типа IllegalArgumentException.
Класс NullPointerException унаследован от RuntimeException.
NumberFormatException
Строка, которая, как предполагалось должна содержать представление числа, не отвечает этому требованию. Исключение выбрасывается такими методами, как, например, Integer.parseInt.
Класс NumberFormatException унаследован от IllegalArgumentException.
SecurityException
Предпринята попытка выполнения операции, запрещенной системой обеспечения безопасности в соответствии с действующей политикой безопасности.
Класс SecurityException унаследован от RuntimeException.
StringIndexOutOfBoundsException
Задано значение индекса содержимого строки типа String, не принадлежащее допустимому диапазону. Имеется дополнительный конструктор, принимающий в качестве параметра ошибочное значение индекса и включающий его в текст описательного сообщения.
Класс StringIndexOutOfBoundsException унаследован от IndexOutOfBoundsException.
UndeclaredThrowableException
Выбрасывается при обращении к методу целевого объекта посредством объекта рефлективного класса Proxy, если метод invoke объекта InvocationHandler генерирует объявляемое исключение, которое не допускает присваивания ни одному из типов исключений, упомянутых в предложении throws метода целевого объекта. Рассматриваемое исключение содержит ссылку на исключение, генерируемое методом invoke, которое может быть получено с помощью метода getUndeclaredThrowable. Класс исключений UndeclaredThrowableException поддерживает два конструктора: оба принимают в качестве параметров ссылку на объект Throwable, а один из них, помимо того, строку описания (тип определен в пакете java.lang.reflect).
Класс UndeclaredThrowableException унаследован от RuntimeException.
UnsupportedOperationException
Предпринята попытка выполнения операции над объектом, который ее не поддерживает (например, модификация объекта, обозначенного признаком “только для чтения”). используется также классами коллекций из состава пакета java.util как реакция на вызов методов производного класса, реализация которых не обязательна.
Класс UnsupportedOperationException унаследован от RuntimeException.
Смотрите также: Методы обработки исключений в java
Почему возникает Ошибка ПРИВЕДЕНИЯ ТИПОВ в строке
return (Integer[]) list.toArray();
public class Solution {
public static void main(String[] args) {
Integer[] arr = new Integer[]{13, 8, 15, 5, 17};
for(Integer i:sort(arr)){
System.out.println(i);
}
}
public static Integer[] sort(Integer[] array) {
ArrayList<Integer> list = new ArrayList<>(Arrays.asList(array));
Collections.sort(list);
double mediana;
if (list.size()%2!=0) mediana = list.get(list.size()/2);
else mediana = ( list.get(list.size()/2) + list.get(list.size()/2-1) )*(1.0)/2;
Comparator<Integer> compAbs = new Comparator<Integer>() {
@Override
public int compare(Integer o1, Integer o2) {
double d1 = Math.abs(o1-mediana);
double d2 = Math.abs(o2-mediana);
return (d1 - d2)<0?-1:d1-d2==0?0:1;
}
};
Collections.sort(list,compAbs);
return (Integer[]) list.toArray();
}
}
А вот в этом примере Ошибки НЕТУ!!! Почему ее во втором примере нет, а впервом есть. Мы же в обеих случаях делаем ОПЕРАЦИЮ ПРИВЕДЕНИЯ К ТИПУ (Integer[])
public class Main {
public static void main(String[] args) {
List<Integer> wordsList = Arrays.asList(1,2,3,4);
Integer[] wordsArray = (Integer[]) wordsList.toArray();
for (Integer word : wordsArray) {
System.out.println(word);
}
}
}
Ok, after going through some links, and trying out some code, I found out that: —
int.class
==Integer.TYPE
== intint.class
!=Integer.class
So, the value of int.class
is Class object representing the type int
.
So, when you invoke your DataType.INT
with int.class
, the toClass
containts int
, on which you cannot invoke cast
. May be because it does not extend from Object
class. Because, cast
method internally uses isinstance
to check whether the invoking type is an Object
type or not.
public T cast(Object obj) {
if (obj != null && !isInstance(obj))
throw new ClassCastException();
return (T) obj;
}
So, if the type that invokes cast
is not an instance of Object
, which of course primitive
types are not, it will return false
, and hence a ClassCastException
.
Исключение — это проблема(ошибка) возникающая во время выполнения программы. Исключения могут возникать во многих случаях, например:
- Пользователь ввел некорректные данные.
- Файл, к которому обращается программа, не найден.
- Сетевое соединение с сервером было утеряно во время передачи данных.
И т.п.
Обработка исключительных ситуаций (exception handling) — механизм языков программирования, предназначенный для описания реакции программы на ошибки времени выполнения и другие возможные проблемы (исключения), которые могут возникнуть при выполнении программы и приводят к невозможности (бессмысленности) дальнейшей отработки программой её базового алгоритма.
Синтаксис
В Java есть пять ключевых слов для работы с исключениями:
- try — данное ключевое слово используется для отметки начала блока кода, который потенциально может привести к ошибке.
- catch — ключевое слово для отметки начала блока кода, предназначенного для перехвата и обработки исключений.
- finally — ключевое слово для отметки начала блока кода, которое является дополнительным. Этот блок помещается после последнего блока ‘catch’. Управление обычно передаётся в блок ‘finally’ в любом случае.
- throw — служит для генерации исключений.
- throws — ключевое слово, которое прописывается в сигнатуре метода, и обозначающее что метод потенциально может выбросить исключение с указанным типом.
Начнем с простого. Допустим мы пишем метод для вычисления площади прямоугольника:
public static void main(String[] args) {
System.out.println(getAreaValue(-1, 100));
}
public static int getAreaValue(int x, int y){
if(x < 0 || y < 0) throw new IllegalArgumentException("value of 'x' or 'y' is negative: x="+x+", y="+y);
return x*y;
}
Здесь в методе getAreaValue мы бросаем исключение IllegalArgumentException с помощью ключевого слова throw. В данном случае в сигнатуре метода отсутствует throws IllegalArgumentException, это не сделано потому что исключение IllegalArgumentException является не проверяемым, о них мы ещё поговорим.
Общий вид конструкции для «поимки» исключительной ситуации выглядит следующим образом:
try{
//здесь код, который потенциально может привести к ошибке
}
catch(SomeException e ){ //в скобках указывается класс конкретной ожидаемой ошибки
//здесь описываются действия, направленные на обработку исключений
}
finally{
//выполняется в любом случае ( блок finnaly не обязателен)
}
В нашем случае для площади прямоугольника:
public static void main(String[] args) {
int result = 0;
try{
result = getAreaValue(-1, 100);
}catch(IllegalArgumentException e){
Logger.getLogger(NewClass.class.getName()).log(new LogRecord(Level.WARNING, "В метод вычисления площади был передан аргумент с негативным значением!"));
throw e;
}
System.out.println("Result is : "+result);
}
public static int getAreaValue(int x, int y){
if(x < 0 || y < 0) throw new IllegalArgumentException("value of 'x' or 'y' is negative: x="+x+", y="+y);
return x*y;
}
Здесь мы поймали IllegalArgumentException и залогировали данное событие. Дело в том что «починить» такую поломку мы не можем, не будем же мы угадывать что хотел пользователь :). По этому мы пробрасываем данное исключение дальше с помощью «throw e;». Такое часто можно встретить на серверах приложений(веб-серверах).
finally
Иногда требуется гарантировать, что определенный участок кода будет выполняться независимо от того, какие исключения были возбуждены и перехвачены. Для создания такого участка кода используется ключевое слово finally. Даже в тех случаях, когда в методе нет соответствующего возбужденному исключению раздела catch, блок finally будет выполнен до того, как управление перейдет к операторам, следующим за разделом try. У каждого раздела try должен быть по крайней мере или один раздел catch или блок finally. Блок finally очень удобен для закрытия файлов и освобождения любых других ресурсов, захваченных для временного использования в начале выполнения метода. Ниже приведен пример класса с двумя методами, завершение которых происходит по разным причинам, но в обоих перед выходом выполняется код раздела finally.
class FinallyDemo {
static void procA() {
try {
System.out.println("inside procA");
throw new RuntimeException("demo");
} finally {
System.out.println("procA's finally");
}
}
static void procB() {
try {
System.out.println("inside procB");
return;
} finally {
System.out.println("procB's finally");
}
}
public static void main(String args[]) {
try {
procA();
} catch (Exception e) {
}
procB();
}
}
В этом примере в методе procA из-за возбуждения исключения происходит преждевременный выход из блока try, но по пути «наружу» выполняется раздел finally. Другой метод procB завершает работу выполнением стоящего в try-блоке оператора return, но и при этом перед выходом из метода выполняется программный код блока finally. Ниже приведен результат, полученный при выполнении этой программы.
inside procA
procA’s finally
inside procB
procB’s finally
Иерархия исключений
Все классы обрабатывающие ошибки являются наследниками класса java.lang.Throwable. Только объекты этого класса или его наследников могут быть «брошены» JVM при возникновении какой-нибудь исключительной ситуации, а также только эти объекты могут быть «брошены» во время выполнения программы с помощью ключевого слова throw.
Прямыми наследниками класса Throwable являются Error и Exception.
Error — это подкласс, который показывает серьезные проблемы возникающие во время выполнения приложения. Большинство из этих ошибок сигнализируют о ненормальном ходе выполнения программы, т.е. о каких-то критических проблемах. Эти ошибки не рекомендуется отмечать в методах посредством throws-объявления, поэтому они также очень часто называются не проверяемые (unchecked).
Источник
При программировании на Java основное внимание следует уделять иерархии Exception. Эта иерархия также разделяется на две ветви: исключения, производные от класса RuntimeException, и остальные. Исключения типа RuntimeException возникают вследствие ошибок программирования. Все другие исключения являются следствием непредвиденного стечения обстоятельств, например, ошибок ввода-вывода, возникающих при выполнении вполне корректных программ.
Рассмотрим основные классы исключений.
Здесь основными классами являются Throwable, Error, Exception и RuntimeException. Именно с ними связанна вся «магия».
Дело в том, что в java есть два типа исключений: checked и unchecked.
1. Checked исключения, это те, которые должны обрабатываться блоком catch или описываться в сигнатуре метода. Unchecked могут не обрабатываться и не быть описанными.
2. Unchecked исключения в Java — наследованные от RuntimeException, checked — от Exception (не включая unchecked).
Пример unchecked исключения — NullPointerException, checked исключения — IOException
То есть если в вашем коде есть участок который может бросить checked исключение то вы обязаны либо заключить его в конструкцию try/catch либо объявить в сигнатуре метода «throws SomeException» но в данном случае обработка исключения делегируется на уровень выше. В любом случае его нужно будет перехватить. В противном случае программа просто не скомпилируется.
Почему я выделил Throwable, Error, Exception и RuntimeException.
Throwable — проверяемое исключение
Error — не проверяемое
Exception — проверяемое
RuntimeException — не проверяемое
Все остальные исключения наследуют это свойство от данных классов. Например SQLException является наследником Exception и оно проверяемое. NullPointerException — наследник RuntimeException и оно не проверяемое.
Так почему не все исключения являются проверяемыми? Дело в том, что если проверять каждое место, где теоретически может быть ошибка, то ваш код сильно разрастется, станет плохо читаемым. Например в любом месте, где происходит деление чисел, нужно было бы проверять на ArithmeticException, потому что возможно деление на ноль. Эту опцию(пере отлавливать не проверяемые исключения) создатели языка оставили программисту на его усмотрение.
Вернемся к классам исключений:
1. RuntimeException
IndexOutOfBoundsException — выбрасывается, когда индекс некоторого элемента в структуре данных(массив/коллекция) не попадает в диапазон имеющихся индексов.
NullPointerException — ссылка на объект, к которому вы обращаетесь хранит null/
ClassCastException – Ошибка приведения типов. Всякий раз при приведении типов делается проверка на возможность приведения (проверка осуществляется с помощью instanceof.
ArithmeticException — бросается когда выполняются недопустимые арифметические операции, например деление на ноль.
2. Error
ThreadDeath — вызывается при неожиданной остановке потока посредством метода Thread.stop().
StackOverflowError — ошибка переполнение стека. Часто возникает в рекурсивных функциях из-за неправильного условия выхода.
Создание своих классов исключений
Хотя встроенные исключения Java обрабатывают большинство частых ошибок, вероятно, вам потребуется создать ваши собственные типы исключений для обработки ситуаций, специфичных для ваших приложений. Это достаточно просто сделать: просто определите подкласс Exception (который, разумеется, является подклассом Throwable). Ваши подклассы не обязаны реализовывать что-либо — важно само их присутствие в системе типов, которое позволит использовать их как исключения.
public class MyException extends Exception{
public MyException(Throwable e) {
initCause(e);
}
}
public class NewClass {
public static void main(String[] args) throws MyException {
int result = 0;
try{
result = getAreaValue(-1, 100);
}catch(IllegalArgumentException e){
Logger.getLogger(NewClass.class.getName()).log(new LogRecord(Level.WARNING, "В метод вычисления площади был передан аргумент с негативным значением!"));
throw new MyException(e);
}
System.out.println("Result is : "+result);
}
public static int getAreaValue(int x, int y){
if(x < 0 || y < 0) throw new IllegalArgumentException("value of 'x' or 'y' is negative: x="+x+", y="+y);
return x*y;
}
}
А вот получившейся стектрейс:
Exception in thread «main» javatest.MyException
at javatest.NewClass.main(NewClass.java:29)
Caused by: java.lang.IllegalArgumentException: value of ‘x’ or ‘y’ is negative: x=-1, y=100
at javatest.NewClass.getAreaValue(NewClass.java:37)
at javatest.NewClass.main(NewClass.java:26)
Java Result: 1
Таким образом мы создали собственный класс исключения и в конструкторе завернули первичное исключение с помощью initCause(e), и у нас получился такой стектрейс MyException -> IllegalArgumentException.
Идея initCause(e) в том, что бы заворачивать исключение источник в новое исключение. Таким образом можно будет проще проследить место и причину возникновения ошибки. В каждом исключении будет ссылка на предыдущее исключение, и это напоминает связной список.
Обработка нескольких исключений
Одному блоку try может соответствовать сразу несколько блоков catch с разными классами исключений.
class Main {
public static void main(String[] args) {
FileInputStream fis = null;
try{
fis = new FileInputStream(fileName);
}catch (FileNotFoundException ex){
System.out.println("Oops, FileNotFoundException caught");
}catch (IOException e) {
System.out.println("IOEXCEOTION");
}
}
}
}
Здесь если файл не найден, то будет выведено на экран «Oops, FileNotFoundException caught» и программа продолжит работать(в данном случае завершится), если же файл найден, но, например, он не доступен для записи то на экран будет выведено «IOEXCEOTION».
Важная особенность, последовательность блоков catch должна идти от частного к более общему. В противном случае будет ошибка компиляции.
try{
fis = new FileInputStream(fileName);
}catch (Exception ex){
//...
}catch (IOException e) { // <--- Ошибка
//...
}
В Java 7 стала доступна новая конструкция, с помощью которой можно пере отлавливать несколько исключений одни блоком catch:
try {
...
} catch( IOException | SQLException ex ) {
logger.log(ex);
throw ex;
}
Это удобно, если обработка ошибок не отличается.
Конструкция try-with-resources
В Java 7 ввели ещё одну конструкцию, призванную упростить жизнь программисту.
Если раньше приходилось писать так:
static String readFirstLineFromFileWithFinallyBlock(String path)
throws IOException {
BufferedReader br = new BufferedReader(new FileReader(path));
try {
return br.readLine();
} finally {
if (br != null) br.close();
}
}
То теперь это можно сделать так:
static String readFirstLineFromFile(String path) throws IOException {
try (BufferedReader br =
new BufferedReader(new FileReader(path))) {
return br.readLine();
}
}
Но где же закрытие потока br? Дело в том, что в Java SE 7 поток BufferedReader реализует интерфейсjava.lang.AutoCloseable и теперь в конструкции try-with-resources нет необходимости закрывать его. Удобно и выглядит компактнее
Наследование методов бросающих исключения
Рассмотрим следующий код:
public class SuperClass {
public void start() throws IOException{
throw new IOException("Not able to open file");
}
}
public class SubClass extends SuperClass{
public void start() throws Exception{
throw new Exception("Not able to start");
}
}
Он не скомпилируется.
Дело в том, что метод start() был переопределен в сабклассе и в сигнатуре был указан более общий класс исключения. Согласно правилам переопределения методов, это действие не допустимо.
Можно лишь сужать класс исключения:
import java.io.FileNotFoundException;
import java.io.IOException;
public class SuperClass {
public void start() throws IOException{
throw new IOException("Not able to open file");
}
}
class SubClass extends SuperClass{
public void start() throws FileNotFoundException{
// FileNotFoundException - наследник IOException
throw new FileNotFoundException("Not able to start");
}
}
Как бросить проверяемое исключение не обрабатывая его (хак)
Нет ничего невозможного. С помощью рефлексии и внутреннего API языка java можно творить магию :).
Естественно так писать нельзя, но знать как это делается все же интересно.
public class UglyDirtyHack{ public static void main(String[] args) { getUnsafe().throwException(new IOException("This is checked exception")); } public static Unsafe getUnsafe() { Unsafe unsafe = null; try { Field f = Unsafe.class.getDeclaredField("theUnsafe"); f.setAccessible(true); unsafe = (Unsafe) f.get(null); } catch (ReflectiveOperationException e) { System.out.println("Who cares"); } return unsafe; } }
sun.misc.Unsafe — API позволяющее выполнять с классами, методами и полями действия, недопустимые стандартными средствами языка.Идея заключается в получении системного объекта Unsafe.
В примере используется рефлексия для получения объекта Unsafe так как другими средствами это сделать проблематично. У класса Unsafe приватный конструктор. А если попытаться вызвать статический метод getUnsafe() то будет брошено исключение SecurityException.
Заключение
Изначально я хотел сделать себе шпаргалку по иерархии классов исключений и не планировал писать статью. Но получилось так, что шпаргалка выросла в статью
Надеюсь она поможет кому-нибудь перед собеседованием, или просто вспомнить/углубить знания Спасибо за внимание!