Как обрабатывать шаблон проверки типа в PHP
Я пишу служебную функцию для обработки массивов. Во избежание сложности предположим, что это простой дескриптор, позволяющий вставлять сокращенные массивы в функцию:
function array_insert($original_arr,$key,$val){
$original_arr[$key]=$val;
return $original_arr;
}
С примером использования, например,
validate_input(array_insert($_GET,'extra-key','val'));
Теперь скажем, у нас может быть проблема, которая $_GET
может не быть массивом. Или, скажем, мы принимаем данные от внешнего звонка; где лежит ответственность за проверку того, что первый параметр является массивом?
Если это сформировало начало сложного стека обработки, мы могли бы сделать:
if (is_array($our_data)){
do_something($our_data);
do_something_else(array_insert($our_data,'key','val'));
}
Это не дает возможности сообщить области вызова, что do_something
не случилось, хотя Итак, мы могли бы сделать:
if (!is_array($our_data)){
throw new Exception('not an array');
}
Теперь все, что использует наш метод, должно быть подготовлено, чтобы поймать это, и в зависимости от того, действительно ли мы заботимся о результате, нам может понадобиться поймать его в нашем методе.
Мы могли бы просто выйти из функции полезности и вернуть false, что-то еще может проверить:
function array_insert($original_arr,$key,$val){
if (!is_array($our_data)){
return []; // which is empty but expected, or return false.. or null...
}
}
Тогда есть самый низкий уровень:
function array_insert(Array $original_arr)
Что вызовет исключение уровня PHP, если массив не передан.
Так что вопрос в том; для функции полезности, какую ответственность мы берем на себя в случае использования? Вызываем ли мы исключение языка с TypeHint, мы молча терпим неудачу, не пытаемся ли мы проверить и позволить конечному пользователю разобраться?
Обновить
Во-первых, люди отмечают, что это субъективно - я согласен, хотя, вероятно, будет признанная лучшая практика, например, рекомендованная схемами сертификации или крупными компаниями в мире PHP.
Во-вторых, еще один вопрос (вызванный первым ответом) заключается в том, существует ли установленный класс исключения / имя класса для такого рода проблемы?
1 ответ
Как уже упоминалось в комментариях, это абсолютно субъективно, но лично:
Я всегда использую подсказки типов для объектов и массивов.
Для функций, работающих на примитивных типах, я бросаю
InvalidArgumentException
основанный на значении, только если некоторые значения недопустимы, и это может быть неочевидно. Например, функция, вычисляющая квадратный корень числа, может выдать исключение при передаче отрицательного значения.Во всех других случаях я использую осмысленные имена функций / параметров и предполагаю, что если кто-то решит, это хорошая идея передать нечисловую строку или массив в функцию, определенную как
doStuffWithNumbers($num1, $num2)
Это его ответственность, если в результате случится что-то плохое.