metaclass: (дзедline)
metaclass ([personal profile] metaclass) wrote2013-03-21 11:25 am
Entry tags:

java try parse integer

А почему в java нету готовых методов, которые бы позволяли парсить числа, не кидая исключений?
Т.е. возвращали бы true+число, либо false, типа как int.TryParse в дотнете.

[identity profile] kzn.livejournal.com 2013-03-21 09:39 am (UTC)(link)
А в чем их возвращать? Можно сделать class что-то вроде MutableInteger, но как-то не очень красиво.
Можно возвращать Object[] - но это совсем уж извращение.

Чем так сильно отличает возвращение статуса от кидания исключения?

[identity profile] vp.livejournal.com 2013-03-21 09:47 am (UTC)(link)
Есть постулат, что строка, не подходящая по формату для преобразования в число - это идеологически не исключение, а вполне штатная ситуация. Потому правильны метод - возвращающий bool результат преобразования, а если все хорошо, то еще и модифицирующий переменную, которую мы ему указали.

[identity profile] kzn.livejournal.com 2013-03-21 09:53 am (UTC)(link)
Хмм. откуда такой постулат?
В исходном посте в C# - tryParse - попробовать распарсить. в Java - parseInt() - требует распарсить. Вполне логично по-моему.

[identity profile] vp.livejournal.com 2013-03-21 09:57 am (UTC)(link)
Так мы дойдем, что проверка if() при не выполнении условия тоже будет бросать исключения вместо того, чтобы ветвиться.

[identity profile] kzn.livejournal.com 2013-03-21 10:23 am (UTC)(link)
Не надо преувеличивать :) Скажем isInteger() исключений бросать не должна.

Опять же, что плохого в исключениях?

[identity profile] vp.livejournal.com 2013-03-21 10:24 am (UTC)(link)
Есть мнение, что исключение - это исключительная ситуация. По определению здесь нет факта исключительной ситуации.

[identity profile] kzn.livejournal.com 2013-03-21 10:26 am (UTC)(link)
Каков критерий исключительной ситуации?
Edited 2013-03-21 10:27 (UTC)

[identity profile] vp.livejournal.com 2013-03-21 10:30 am (UTC)(link)
Ситуация, когда нормальная работа приложения либо модуля не может быть продолжена обычным образом, и вам необходимо вернуться, возможно, на несколько уровней вложенности в первоначальное состояние, передав наверх информацию о ситуации.

[identity profile] kzn.livejournal.com 2013-03-21 10:36 am (UTC)(link)
Ну а чем это не подходит к ситуации, когда мы ожидаем распарсит число, а не получается? Тут тоже возможно нужно передать информацию на уровень выше?

Чем принципиально это отличается от IOException?

[identity profile] vp.livejournal.com 2013-03-21 10:38 am (UTC)(link)
А не факт, что IOException - это правильное архитектурное решение. У нормальных людей эти операции возвращают результат операции, число там записанных байт и т.п. Там исключение - как корове седло.

(no subject)

[identity profile] kzn.livejournal.com - 2013-03-21 10:39 (UTC) - Expand

(no subject)

[identity profile] vp.livejournal.com - 2013-03-21 10:42 (UTC) - Expand

(no subject)

[identity profile] kzn.livejournal.com - 2013-03-21 10:56 (UTC) - Expand

(no subject)

[identity profile] vp.livejournal.com - 2013-03-21 10:58 (UTC) - Expand

(no subject)

[identity profile] sil-e-nt.livejournal.com - 2013-03-22 07:50 (UTC) - Expand

[identity profile] metaclass.livejournal.com 2013-03-21 10:30 am (UTC)(link)
Очень простой.
Если работу можно продолжать - исключение кидать не принято.
Исключения - для случаев, когда надо свалится в корень исполняемого потока (main loop или там обработчик выдающий 500 в веб-сервисе).
Делать логику на исключениях - очень нехорошо, но конкретно в данном случае жаба вынуждает это делать.

[identity profile] kzn.livejournal.com 2013-03-21 10:54 am (UTC)(link)
Это крайность имхо.

Исключение кидаются когда произошло нечто неожиданное с точки зрения разработчика.

parseInt() ожидает увидеть число. А получило. - вполне неожиданное событие.

Ожидали прочитать из файла, а он закончился - тоже.

Но и то, и другое можно сделать на статусах, как C.

[identity profile] metaclass.livejournal.com 2013-03-21 10:29 am (UTC)(link)
с if часть алгоритмов сильно короче и нагляднее. Ну, еще насчет производительности вопрос сложный.

[identity profile] kzn.livejournal.com 2013-03-21 10:38 am (UTC)(link)
Да. С этим согласен. Сам переписывал парсера, который не проверял границы, а кидал Out Of Bounds. Стало короче и даже быстрее.

Но вот с числами.. можно конечно сделать Integer Integer.parseInt() и возвращать null если не удалось распарсить.

[identity profile] henu3detb.livejournal.com 2013-03-21 11:36 am (UTC)(link)
Потом этот налл удетит по веб-сервису на N удаленных систем. Там сохранится в базах, потечет по бизнес-процессам и через пол года на другом континенте начнет вываливаться NPE. Нал он такой, да. Как и любители нала.

[identity profile] kzn.livejournal.com 2013-03-21 11:39 am (UTC)(link)
Ну ногу-то практически всегда отстрелить можно. Особенно при остром желании.

(no subject)

[identity profile] henu3detb.livejournal.com - 2013-03-21 11:49 (UTC) - Expand

(no subject)

[identity profile] kzn.livejournal.com - 2013-03-21 11:59 (UTC) - Expand

[identity profile] avnik.livejournal.com 2013-03-21 10:49 am (UTC)(link)
можификация переменных зло
Неумение языка возвращать tuple тоже зло.

[identity profile] vp.livejournal.com 2013-03-21 10:50 am (UTC)(link)
совершенно согласен. Тут tuple при возврате было бы самое то, что нужно.

[identity profile] guamoka.livejournal.com 2013-03-21 12:05 pm (UTC)(link)
C т.з. требований на вашем уровне- вполне возможно. С т.з. метода парсинга строки в инт неподходящая строка- это ошибка. В жаве принято обрабатывать ошибки консистентно- исключениями.

[identity profile] vp.livejournal.com 2013-03-21 12:06 pm (UTC)(link)
Ну мы тут обсуждаем "как было бы лучше" :)
Сферически - идеальные языки, с кортежами на выходе и т.п. Ням-ням.

[identity profile] guamoka.livejournal.com 2013-03-21 12:07 pm (UTC)(link)
с коттеджами в ратомке на испанском побережье- это мысль.

[identity profile] vp.livejournal.com 2013-03-21 12:12 pm (UTC)(link)
У нас в оперденях есть такой возвращаемый тип. Крайне полезен.

[identity profile] sil-e-nt.livejournal.com 2013-03-22 07:54 am (UTC)(link)
Еще вот тут отмечусь. Вот сделали туплом аутпут, ок, облегчили себе жизнь и вместо исключения пользуем дефолтное значение.
Берет юзверь вашу прогу, вводит какую-нибудь шнягу, верную с его точки зрения (можно я не буду придумывать варианты?) А потом несколько дней ебется в поисках решения, хули получается совершенно другое значение на выходе?

[identity profile] vp.livejournal.com 2013-03-22 08:14 am (UTC)(link)
А кто говорил о каких-то дефолтных значениях?
Если все не ок, то возвращается кортеж из булена об ошибке и кода ошибки. Если все ок, то возвращается тупл с буленом и с полученным значением.

[identity profile] juan-gandhi.livejournal.com 2013-03-21 04:36 pm (UTC)(link)
Это не правильный метод, а одно из решений, и не думаю, что самое хорошее.