reference types vs value types
Jan. 9th, 2013 10:14 pm![[personal profile]](https://www.dreamwidth.org/img/silk/identity/user.png)
Очередной раз посрались с артурегом за типизацию. Его огорчает существование value-types (или примитивных типов в жабе) из-за того, что они накладывают более жесткие ограничения на получение значений этих типов извне.
Например при загрузке из БД с полем, разрешающим null - придется либо сдыхать с исключением, либо устанавливать некое "значение-по-умолчанию", которое потом не отличишь от такого же значения, но введенного явно.
По моему - это какие-то проблемы, не то уровня начинающих, а вообще детсадовские, т.е. проблемы реально не существует.
Либо предметная область разрешает "отсутствие данных" и мы таскаем всюду Option[T] или жабьи объектные врапперы или C# Nullable<T>, либо предметная область разрешает использовать некое значение по умолчанию и нам его отличать от отсутствия данных не нужно, либо данные обязаны присутствовать и мы таскаем value-type, в базе делаем поле not null и в прочих протоколах делаем поле обязательным и дохнем с исключением (возвращаем код ошибки) при его отсутствии.
Если требования не зафиксированы заранее - пользуемся логикой и выбираем один из трех вышеописанных вариантов. Если требования в процессе разработки меняются - рефакторим. Если требования противоречивы - доводим до заинтересованных лиц и дальше либо делаем требования непротиворечивыми, либо ослабляем строгость ограничений (убираем not null и рефакторим все из value-types в reference-types или Option[T]/Nullable<T>)
Артурег же упорно пытается превратить нормальную типизацию в ад жабаскрипта, минимизируя ограничения на хранимые значения. Но даже в этом случае можно оставить часть ограничений и гарантировать, что код не сломается и не будет вести себя непредсказуемо. Достаточно просто иметь представление о областях определения функций и ввести некие вменяемые правила поведения в случае, если значение выходит за область определения.
Я пытаюсь особо не айседствовать и прислушиваться к мнению людей, но в последнее время это разведение проблем на пустом месте от незнания простейших вещей начинает чрезвычайно раздражать.
Отказ использовать статическую типизацию хотя бы как способ рассуждения о коде (если язык не поддерживает ее явно в нужном объеме или это язык с динамической типизацией) мне не понятен в принципе, это примерно как добровольно отказатся от электричества, компьютеров, лекарств и пойти жить в землянки и жрать грязные корни.
Причем даже использование языков с динамической типизацией ничего не меняет - оно всего лишь перекладывает рассуждения о коде с компилятора-тайп-чекера на программиста и дает возможность описывать более сложные типы меньшим количеством кода.
Например при загрузке из БД с полем, разрешающим null - придется либо сдыхать с исключением, либо устанавливать некое "значение-по-умолчанию", которое потом не отличишь от такого же значения, но введенного явно.
По моему - это какие-то проблемы, не то уровня начинающих, а вообще детсадовские, т.е. проблемы реально не существует.
Либо предметная область разрешает "отсутствие данных" и мы таскаем всюду Option[T] или жабьи объектные врапперы или C# Nullable<T>, либо предметная область разрешает использовать некое значение по умолчанию и нам его отличать от отсутствия данных не нужно, либо данные обязаны присутствовать и мы таскаем value-type, в базе делаем поле not null и в прочих протоколах делаем поле обязательным и дохнем с исключением (возвращаем код ошибки) при его отсутствии.
Если требования не зафиксированы заранее - пользуемся логикой и выбираем один из трех вышеописанных вариантов. Если требования в процессе разработки меняются - рефакторим. Если требования противоречивы - доводим до заинтересованных лиц и дальше либо делаем требования непротиворечивыми, либо ослабляем строгость ограничений (убираем not null и рефакторим все из value-types в reference-types или Option[T]/Nullable<T>)
Артурег же упорно пытается превратить нормальную типизацию в ад жабаскрипта, минимизируя ограничения на хранимые значения. Но даже в этом случае можно оставить часть ограничений и гарантировать, что код не сломается и не будет вести себя непредсказуемо. Достаточно просто иметь представление о областях определения функций и ввести некие вменяемые правила поведения в случае, если значение выходит за область определения.
Я пытаюсь особо не айседствовать и прислушиваться к мнению людей, но в последнее время это разведение проблем на пустом месте от незнания простейших вещей начинает чрезвычайно раздражать.
Отказ использовать статическую типизацию хотя бы как способ рассуждения о коде (если язык не поддерживает ее явно в нужном объеме или это язык с динамической типизацией) мне не понятен в принципе, это примерно как добровольно отказатся от электричества, компьютеров, лекарств и пойти жить в землянки и жрать грязные корни.
Причем даже использование языков с динамической типизацией ничего не меняет - оно всего лишь перекладывает рассуждения о коде с компилятора-тайп-чекера на программиста и дает возможность описывать более сложные типы меньшим количеством кода.
no subject
Date: 2013-01-09 07:35 pm (UTC)Если не хватает типов - создавай свои. В конце концов создай себе объектные типы для каждого примитива и работай с ними, ну или создай тип, который будет мегауниверсальный само-де-нуллующийся само-нормальзующийся итп как тебе нужно и его таскай куда хочешь.
Печаль в жабе скорее в том, что разный подход к типам и быдлокодеры херачат чего хотят ели их вовремя по рукам не лупасить.
no subject
Date: 2013-01-09 07:53 pm (UTC)no subject
Date: 2013-01-09 08:08 pm (UTC)A fool with a too is still a fool. Жаба тут ни при чём. Хотя нет, немного виновата тем, что она настолько проста, что выловленный на улице рандомный индус может творить на ней говнокод через неделю подсматривания за коллегой.
(no subject)
From:(no subject)
From:(no subject)
From:(no subject)
From:(no subject)
From:(no subject)
From:(no subject)
From:no subject
Date: 2013-01-09 09:14 pm (UTC)(no subject)
From:no subject
Date: 2013-01-09 09:25 pm (UTC)Я например как-то сел и 2 дня потратил на тупейшее убирание ~80 копипаст кусков. Да, неприятно, да я постоянно матерился вполголоса, но мне за это и платят деньги. Не нравится проект -- так и скажите своему менеджеру, ищите другой. Если вы не раб, прикованный цепями к стене, найти обычно удаётся.
(no subject)
From:(no subject)
From:(no subject)
From:(no subject)
From:(no subject)
From:no subject
Date: 2013-01-09 09:21 pm (UTC)no subject
Date: 2013-01-09 09:23 pm (UTC)(no subject)
From:(no subject)
From:(no subject)
From:(no subject)
From:(no subject)
From:(no subject)
From:(no subject)
From:(no subject)
From:(no subject)
From:(no subject)
From:(no subject)
From:(no subject)
From:(no subject)
From:(no subject)
From:(no subject)
From:(no subject)
From:(no subject)
From:(no subject)
From:(no subject)
From:(no subject)
From:no subject
Date: 2013-01-09 09:33 pm (UTC)Но и на этот случай - ничто не мешает настоящему самураю сделать свои пять типов, все в них завернуть и юзать до потери пульса. Правда тогда начнётся настоящий ад, все начнут рожать мегаконстукции чтобы тягать метаданные о типах вместе с переменными итп.
(no subject)
From:no subject
Date: 2013-01-09 08:20 pm (UTC)no subject
Date: 2013-01-09 08:23 pm (UTC)no subject
Date: 2013-01-09 08:30 pm (UTC)no subject
Date: 2013-01-09 08:34 pm (UTC)(no subject)
From:(no subject)
From:(no subject)
From:(no subject)
From:(no subject)
From:no subject
Date: 2013-01-09 09:33 pm (UTC)типы - это суть контракты и важны они уже на стыке модели с другими объектами
соответственно, типы по-настоящему важны только во время взаимодействия модели с другим объектом и зависят от конкретного алгоритма взаимодействия
на мой взгляд, мыслить удобнее именно взаимодействиями объектов, а не их составных частей
no subject
Date: 2013-01-09 10:35 pm (UTC)ортурега не переубедишь, что надо типы, вас не переубедишь что они не надо, зачем вы пытаетесь натягивать сов на глобусы?
no subject
Date: 2013-01-10 04:58 am (UTC)Ох, ребе, как давно я не слышал этой замечательной фразы «рассуждение о» в отношении кода. Дайте я вас полюбаю!
Это же имено то, что нужно было написать.
no subject
Date: 2013-01-10 05:41 am (UTC)Причем даже использование языков с динамической типизацией ничего не меняет - оно всего лишь перекладывает рассуждения о коде с компилятора-тайп-чекера на программиста и дает возможность описывать более сложные типы меньшим количеством кода.
+14521
В рамочку и на стенку.
no subject
Date: 2013-01-10 06:00 am (UTC)no subject
Date: 2013-01-10 06:05 am (UTC)http://thedeemon.livejournal.com/54732.html
Но вы ж читать вряд ли умеете...
(no subject)
From:(no subject)
From:no subject
Date: 2013-01-10 11:06 am (UTC)так что динамическую лучше использовать только когда это явно удобнее - например, закачку нетипизированных данных из какой-нть помойки для предварительной обработки
no subject
Date: 2013-01-10 11:22 am (UTC)no subject
Date: 2013-01-10 11:23 am (UTC)no subject
Date: 2013-01-10 11:51 am (UTC)Эта техника называется "заметём ошибки под ковёр". Очень эффективна для создания кривого софта, когда пользователь, разделив пирог на три части, получает одну из долей в 140%. Главное, что он не знает, отчего так происходит, и проникается к программистам мистическим благоговением.
no subject
Date: 2013-01-10 02:09 pm (UTC)>> это примерно как добровольно отказатся от электричества, компьютеров, лекарств и пойти жить в землянки и жрать грязные корни.
Ребе не айседствует, ребе культурный, да.
no subject
Date: 2013-01-10 03:23 pm (UTC)no subject
Date: 2013-01-10 03:39 pm (UTC)Но для любителей отсутствия типов это вообще будет высший пилотаж и академическая наука.