Думай медленно… Решай быстро

01.09.21

Саморазвитие

Несколько дней назад коллег подарил мне книгу «Думай медленно… Решай быстро» Даниэль Канеман. При чтении я заметил, что понятия «Система 1», «Система 2» и их взаимодействие хорошо иллюстрируются примерами из повседневной работы программиста. Чтение стало занимательным, а сделанные выжимки по первой части я решил выложить в статью. Возможно кому-то это покажется интересным и захочется прочитать оригинал.

Система 1 – работает автоматически, быстро, легко, без контроля.
Система 2 – выделяет внимание для сознательных умственных усилий.

Система 1 – предлагает решение, а Система 2 его принимает. Мы думаем, что решаем задачу при помощи Системы 2, но на самом деле Система 2 медленно «логически» проверяет «быстрые решения» предложенные Системой 1.

Пример: Надо организовать учет остатков на складе.
Система 1: Надо регистр, а для регистра регистратор и справочники…
Система 2: Логично, хорошее решение.

Система 1 предлагает образы переходя от одного образа к нескольким другим, не обязательно связанных с текущей задачей.  Система 2 анализирует предложенные образы последовательно. Так получается когерентность (связанность, понятность) решаемой задачи. Непонятное непроизвольно игнорируется. Поиск упущений требует дополнительных целенаправленных усилий Системы 2.
Целенаправленное использование Системы 2 в одном задании снижает желание использования Системы 2 в следующем задании, скорость увеличивается, а критичность снижается. Использование Системы 2 снижает удовольствие от исполнения заданий.

Пример: Надо организовать учет остатков на складе.
Система 1: Надо регистр, а для регистра регистратор и справочники…
Система 2: Дай еще варианты.

Система 1: В УНФ есть …
Система 2: Дай еще варианты.

Система 1: В Бухгалтерии есть один вариант реализации
Система 2: Буду сравнивать.., выбираю УНФ

Надо организовать учет взаиморасчетов.
Система 1: В УНФ есть …
Система 2: Логично, хорошее решение.

Надо организовать учет денег.
Система 1: Надо чаю попить…

Прайминг - влияние предшествующей информации на следующие образы. Влияние осуществляется независимо от того связаны задачи между собой или нет.
При описании задачи следует сначала описать проблему, а потом предлагаемое решение. При чтении следует обдумать возможные решения до чтения предлагаемого решения. В противном случае несмотря на использование нескольких человек для анализа возможно будет рассмотрен только один вариант решения.

Пример: Надо организовать учет остатков на складе.
Архитектор: Надо регистр, а для регистра регистратор и справочники…
Программист: Логично, хорошее решение.

Система 2 может направлять систему 1 на поиск. Можно целенаправленно вспомнить паттерн (прайминг) и проверить решение на соответствие (поиск).

Пример: Проверка качества «вручную» по чек-листу.

Повторение события, простые формулировки, ранее обдуманная мысль и хорошее настроение формируют когнитивную легкость. Легкое решение кажется правильным, хорошим. Ключевое слово «кажется», т.е. влияет на оценку сложности и трудоемкости. Работает и обратное – сложные слова и длинные предложения увеличивают оценку.
Если во время работы с заданием специально улыбаться (можно специально, растягивая уголки губ) задание будет казаться проще, бдительность Системы 2 снизится, снизится так-же и оценка. Если специально хмуриться – то наоборот. В тоже время «хорошее» настроение стимулирует Систему 1 и качество интуитивно предложенных решений будет существенно выше. Для критического анализа уже знакомой информации лучше использовать «серьезное» настроение.

Пример: Сначала сделаю прототип (пока хорошее настроение), потом исправлю ошибки в прошлых задачах (настроение ухудшиться) и проверю качество прототипа.

Паттерны, выраженные в простых мыслях, формируют легкость и скорость восприятия за счет активного использования Системы 1.
Кроме того паттерны формируют «норму». Отступление от нормы вызывает удивление и инициализирует поиск причины. В результате могут быть найдены причины там, где их нет. Более того может появиться новая «норма».

Пример: Пусть есть две процедуры, которые формируют печатные формы. У каждой печатно формы есть «Шапка», «Шапка таблицы», «Строка», «Подвал». Две процедуры отличаются только именем макета.
При чтении кода Система 1 не произвольно анализирует код, замечает повторение и подкидывает паттерн «Не повторяй код». Система 2 сверяет код, подтверждает повторение и объединяет эти процедуры в одну.
Так формируется ошибочное решение объединить участки кода, которые совпадают «пока что», но имеют разные причины для изменения. В будущем, когда печатне формы будут изменяться скорее всего код придется снова разделить.

Система 1 игнорирует неоднозначности и подавляет сомнения, использует контекст, склонна верить тому что видит и подтверждать (соглашаться со всем). Мерой успеха Системы 1 является когерентность (связанность). В результате из-за различных контекстов могут возникать ошибки восприятия.

Пример: Пусть есть следующий код:

Функция СоздатьКонтрагента()
	Контрагент = Справочники.Контрагенты.СоздатьЭлемент();
	Контрагент.Заполнить(Основание)
	
	Возврат Контрагент;
КонецФункции

Функция ИНН_Контрагента(Контрагент)
	Запрос = Новый Запрос("ВЫБРАТЬ ИНН ИЗ Справочник.Контрагенты ГДЕ Ссылка = &Контрагент");
	Запрос.УстановитьПараметр("Контрагент", Контрагент);
	Выборка = Запрос.Выполнить().Выбрать();
	
	Результат = ?(Выборка.Следующий(), Выборка.ИНН, "");
	Возврат Результат;
КонецФункции

Процедура МояПроцедура()
	
	Контрагент = СоздатьКонтрагента();
	ИНН = ИНН_Контрагента(Контрагент);

КонецПроцедуры

Система 1 используя контекст все три метода прочитает как «хорошие» и только Система 2, специально направленная на поиск ошибок, может определить, что нельзя передавать объект в запрос.  

Система 1 при оценке сопоставляет интенсивности, в результате можно сравнивать несопоставимые величины (точность вычислений и достоверность информации). Такие «подмены» могут приводить к замене сложного вопроса на более простой.

Пример:

Сложный вопрос (игнорируется)

Просто вопрос (реально решается)

Какая точность прогноза?
(надо вычислить возможные отклонения)

Какая точность вычислений?
(указывается количество знаков после «,»)

Правильно ли ведется учет?
(надо проверить последовательность операций, взаимодействие разных регистров)

Правильно ли используется регистр?
(проверяется отдельная операция в отдельном регистре, связи игнорируются).

См. также

Личная эффективность Бесплатно (free)

Ограниченный набор решаемых задач и консерватизм мышления часто мешают 1С-программистам выйти за рамки базового функционала и расти как техническим специалистам. Одним из ключевых решений этой проблемы может стать целенаправленное развитие фундаментальных IT-знаний: алгоритмов, паттернов проектирования, смежных технологий и практик. На реальных кейсах рассмотрим, как это расширяет возможности и повышает эффективность, а также определим, для кого такой путь развития критически важен, а кому достаточно стандартных навыков поддержки типовых конфигураций.

вчера в 12:10    290    0    AntonChausov    27    

5

Презентации и публичные выступления Бесплатно (free)

ИТ-доклад не должен быть похож на колыбельную. Докладчик обязан тренироваться, быть профессионалом в том, о чем рассказывает, грамотно подготовить презентацию и построить выступление как увлекательное путешествие к выверенной цели. Расскажем о том, на что нужно обратить внимание при выступлении и подготовке презентации.

10.06.2025    1639    0    a.doroshkevich    12    

32

Мотивация Личная эффективность Бесплатно (free)

Разрабатывая открытые решения, мы внимательнее относимся к коду, интерфейсу, документации и оформлению. А изучение чужого кода вдохновляет и открывает новые подходы. Расскажем об опыте создания открытых решений для 1С, ценности open-source и роли сообщества.

05.06.2025    2233    0    vandalsvq    18    

44

Личная эффективность Бесплатно (free)

В данной статье описываю принципы, которыми пользуюсь при работе с клиентами.

12.05.2025    1306    0    apatyukov    48    

17

Личная эффективность Бесплатно (free)

Если вы ничего не успеваете, проведите ревизию целей и выберите из них только те, которые действительно достойны быть вашими. Расскажем о том, как отличать свои желания от навязанных, адаптировать «колесо баланса» под ежедневное планирование рабочих дел, найти внутренние ресурсы и выстроить профессиональный путь, в который хочется идти.

25.04.2025    1094    0    DuyunElena    0    

6

Обучение и наставничество Бесплатно (free)

Технический архитектор (ТА) — востребованная специальность в большинстве ИТ-компаний. Однако на сегодняшний день не существует точного определения этой роли. Как следствие, специалисты, которые хотят вырасти до ТА, зачастую не понимают, с чего начинать и какие навыки прокачивать. Причём это касается не только джунов, но и сеньоров. В КРОК мы выстроили последовательный карьерный трек для разработчиков, которые хотят стать техническими архитекторами, развиваться в сильной команде и решать интересные задачи. Делюсь нашим опытом.

23.04.2025    1156    0    Libelle    2    

15

Обучение и наставничество Бесплатно (free)

Обучение взрослых (или если по-профессиональному – андрагогика) – это такой же сложный и творческий процесс, как и обучение детей. И два главных барьера тут похожие – вовлечение и мотивация («Мне это интересно?» и «Мне это нужно?»). Отсюда не просто игровые методы обучения имеют большую популярность, но и те, которые будут вызывать интерес. И я вам расскажу о нескольких дидактических формах, которые уж интерес явно могут вызвать. Это первый ответ на вопрос – откуда появилась идея этой статьи.

31.03.2025    876    0    ashtey    4    

8

Личная эффективность Бесплатно (free)

В мире программирования часто считают, что успешный разработчик — это громкий, харизматичный человек, который проводит митапы, активно общается с заказчиками и без проблем выступает перед аудиторией. Но что, если вам ближе глубокая работа в тишине, чем бесконечные зум-звонки? Эта статья основана на книге Сьюзан Кейн «Интроверты. Как использовать особенности своего характера». В ней мы разберём, почему интроверсия — не недостаток, а суперсила для 1С-разработчика, и как использовать её в работе.

26.03.2025    2698    0    kirillobskih    15    

28
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. artbear 1567 01.09.21 13:22 Сейчас в теме
Обе системы должны находить синтакс-ошибку в коде )
	Контрагент.Заполнить(Основание)
	
	Возврат Контрагент;
FesenkoA; Armando; bilex; AntonProgma; AnryMc; +5 Ответить
2. Armando 1402 01.09.21 17:21 Сейчас в теме
(1) Какую? Переменная не определена? Это же 1С. Основание может быть реквизитом формы или объекта в контексте которого исполняется функция.
3. artbear 1567 01.09.21 17:22 Сейчас в теме
(2) Нет, точки с запятой не хватает после скобки )
FesenkoA; Armando; +2 Ответить
4. Armando 1402 01.09.21 17:23 Сейчас в теме
(3) действительно. Не заметил.
5. lunjio 67 03.09.21 01:13 Сейчас в теме
Извиняюсь конечно, вы там одну главу прочитали и решили статью наклепать на пару абзацев, на совершенно выдуманном примере, который сам по себе абсурден ?) Передавать только созданного контрагента, пусть даже ссылку, чтобы ИНН получить, запросом, а не из реквизита. Более менее нормальный кодер даже если ему ссылка на вновь созданного вернется, будет знать, что объект еще в кэше и можно просто из ссылки получить реквизит, ничего страшного в этом нет, но это пол беды. В процедуре ИНН как минимум поставит проверку на типзнч контрагента, более внимательный знает что 1С индексирует по полю ИНН справочник контрагенты и не будет заморачиваться с созданием запроса и т.п, а просто через менеджер контрагентов по реквизиту найдет.
Любой нормальный программист 1С, сам может подобную книгу написать, взять к примеру пользователя Intellegency1С или как там.
Ладно бы у вас какая-то мысль лежала, что мне эта ваша система1, система2 дает ? абстракций можно приводить куча, вот дали бы вы последовательность универсальную, ладно ещё, а так на плюс не тянет.
6. Gladkov_Anton 354 03.09.21 09:48 Сейчас в теме
(5) Извинения приняты. Примеры предельно упрощены, но думаю основная мысль из них понятна.
Если одна процедура в одном модуле, а вторая в другом, обе процедуры сильно сложнее чем в примере, то при написании третьей легко допустить ошибку аналогичную указанной в примере.
Пример посложнее на ту же тему:
Процедура из БСП:
// Регистрирует изменение одного элемента данных для последующей отправки в адрес узла-получателя.
// Элемент данных будет зарегистрирован только в том случае, если он соответствует фильтрам правил регистрации 
// объектов,установленным в свойствах узла-получателя.
// Элементы данных, которые выгружаются при необходимости, регистрируются безусловно.
// Объект УдалениеОбъекта регистрируется безусловно.
//
// Параметры:
//     Получатель - ПланОбменаСсылка          - узел плана обмена, для которого выполняется регистрация изменений
//                                              данных.
//     Данные     - СправочникОбъект
//                - ДокументОбъект
//                - Произвольный
//                - УдалениеОбъекта - объект, представляющий данные,
//                  хранимые в базе данных, такой как документ, элемент справочника, счет бухгалтерского учета, менеджер
//                  записи константы, набор записей регистра и т. п.
//     ПроверятьРазрешениеВыгрузки - Булево   - необязательный флаг. Если установить в Ложь, то дополнительная проверка 
//                                              на соответствие общим настройкам узла при регистрации производится не
//                                              будет.
//
Процедура ЗарегистрироватьИзмененияДанных(Знач Получатель, Знач Данные, Знач ПроверятьРазрешениеВыгрузки=Истина) Экспорт
Показать


В процедуре:
ПланыОбмена.ЗарегистрироватьИзменения(Получатель, Данные);


И еще кусочек:
			
Если ОбщегоНазначения.ЗначениеСсылочногоТипа(Данные) Тогда
	ЭтоНовыйОбъект = Данные.Пустая();
Иначе
	ЭтоНовыйОбъект = Данные.ЭтоНовый(); 
КонецЕсли;


А отладкой я вижу, что "Данные" - это ссылка.
Без изучения кода Системой 2 сложно понять есть тут ошибка или все будет работать корректно.

Прямой пользы, типа прочитал - стал на 1000 руб/месяц лучше может и нет, но рассмотреть взаимодействие систем 1 и 2 при программировании мне кажется занимательным.
vld_dmn; EugeneMaliy; +2 Ответить
7. lunjio 67 03.09.21 16:30 Сейчас в теме
(6)
да Системой 2 сложно понять есть тут ошибка или все будет работать корректно.

Вот в этом и вся проблема, всю хромоту и недостаточность языка, вы пытаетесь победить логикой и замудренным размышлением. Почему вы вообще не задаетесь вопросом - а нафига такой код писать ??? В этом вся и проблема 1С, в этом его и преимущества и недостаток, дали крутой бизнес-ориентированный язык, а вот руководство как писать не дали и в своих же БСП учат тому, как делать не стоит.
Оставьте свое сообщение