Чистый кот (Clean cat)

30.01.21

Разработка - Рефакторинг и качество кода

От автора легендарного бестселлера "Совершенный кот".

Вступление

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

Статья "Совершенный кот" делала упор на наглядность. Сначала хотел просто опубликовать картинки с котом. Поэтому содержательная часть была небольшая. Текущую статью писал к митапу, но чуть-чуть не успел.

Наш основной "манифест" - группа статей "Соглашения при написании кода" очевидно пересекается с классиками (Steve McConnell, Robert C.Martin) И дело не в общих идеях, а в мелочах: максимальная ширина строки, названия переменных, процедур, количество аргументов процедур и прочее. Уверен, что специалисты, которые ее писали, читали классиков гораздо внимательнее, чем мы. Итак, основной признак плохого кода - не использовать преимущества и тренды современного языка 1С. Что бы я еще хотел найти на ИТС ?

1. Большое расстояние между операторными скобками, большое число вложений.

Функция - КонецФункции, Процедура - КонецПроцедуры

По количеству строк функция должна помещаться на экран, чем меньше тем лучше. О том же пишет Robert C.Martin (Clean code) глава 3, Функции, компактность.

Попытка - КонецПопытки. Не каждый код может дать исключение - зачем помещать все в попытку ?

//Некрасиво
Попытка
	НовыйДокумент = Документы.ЗаказПокупателя.СоздатьДокумент();
	ЗаполнитьЗначенияСвойств(НовыйДокумент, Источник,"Дата,Номер");
	НовыйДокумент.Записать();
Исключение
	//ЗаписьЖурналаРегистрации(...);
КонецПопытки;	

//Красиво
НовыйДокумент = Документы.ЗаказПокупателя.СоздатьДокумент();
ЗаполнитьЗначенияСвойств(НовыйДокумент, Источник,"Дата,Номер");
Попытка
	НовыйДокумент.Записать();
Исключение
	//ЗаписьЖурналаРегистрации(...);
КонецПопытки;

Пока - КонецЦикла Меньше уровней вложенности.

//Некрасиво
Пока ВыборкаДетальная.Следующий() Цикл
	
	Если ПроверитьУсловие() Тогда
	
		//многабукв
	
	КонецЕсли; 
	
КонецЦикла;

//Красиво
Пока ВыборкаДетальная.Следующий() Цикл
	
	Если НЕ ПроверитьУсловие() Тогда	
		
		Продолжить;	
	КонецЕсли; 
	
	//многабукв
КонецЦикла;

Если многабукв - очень большой фрагмент кода, то его можно оформить отдельной процедурой

2. Недостаток абстрактного мышления.

Например, вместо функции ЗаполнитьЗначенияСвойств() используют присваивание.

На картинке обычные формы, но на управляемых я видел похожее решение.

Возможно, одинаковые поля лучше выводить в таблицу, как это сделано в настройках СКД ?

3. Памяти Рэя Бойса и Эдгара Кодда посвящается.

Если данные нужны для одного процента документов, то это точно не реквизит документа. Добавьте его в регистр "ЗначенияСвойствОбъектов", добавьте в табличную часть "ДополнительныеСвойства", сделайте отдельный регистр сведений, отдельную табличную часть, в котором будет значение реквизита и ссылка на документ, только не в сам документ и не в общие реквизиты! Особенность современных баз данных - они гораздо эффективнее, когда растут вниз, а не вправо. В СУБД такие горе-реквизиты выглядят так:

Нравится заполнять диск нулями ?

Вопросы из зала ZOOM (после продолжительных аплодисментов):

Вопрос: - Почему такой логотип ?

Ответ: - Кот на логотипе вымытый, то есть чистый.

Вопрос: - Есть код, которым Вы гордитесь ?

Ответ: - Да, есть такой код (десять строк) - парсинг технологического журнала. Описание проблемы можно найти ИТС, задача поставлена более 10 лет назад, а решить ее удалось только в этом году.

Вопрос: - Почему бы не упомянуть про особенные требования к коду в цикле, коду внутри транзакции ?

Ответ: - Это обычные случаи, как правило все знают.

Вопрос: - Что нужно, чтобы код наших программистов был идеальным ?

Ответ: - Прежде всего, нужно договориться внутри команды, "установить правила игры", одинаковые для всех. Что-то вроде устава, в котором прописать конкретные паттерны и антипаттерны ?

Вопрос: - Что главное для программиста ?

Ответ: - Каждая бочка меда должна содержать хотя бы ложку самоиронии. Может, это то что отличает умного человека от заумного ?

Вопрос:  - Ваш любимый мем ?

Ответ:  - Наверное, это "Гарольд сдерживает боль" с подписью "Когда увидел большой кусок квазикода..."

и маленькими буквами "...а потом понял, что ты его написал в прошлом году"

Вопрос: - Ваше любимое изречение Конфуция ?

Ответ: -

"Написать красивый код может каждый.

Настоящее искусство программирования

- развивать существующий квазикод,

чтобы он давал квазирезультаты на квазиданных,

и получать за это настоящую зарплату."

 

Вступайте в нашу телеграмм-группу Инфостарт

См. также

Нейросети Рефакторинг и качество кода Программист Бесплатно (free)

ИИ для код-ревью – не просто модный тренд, а реальный инструмент, который уже помогает разработчикам экономить время и повышать качество кода. В статье разбираемся, как запустить локальную LLM на базе Ollama, подключить ее к Git через Webhook и Python-скрипт, а также какие параметры модели отвечают за точность и галлюцинации. Делимся схемой работы, настройками и результатами тестирования, доказывая, что автоматизированное код-ревью действительно может работать – даже без космического бюджета.

30.10.2025    3077    user2100900    3    

15

Запросы Рефакторинг и качество кода Программист Запросы Бесплатно (free)

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

28.10.2025    3451    vaillant    35    

13

Нейросети Рефакторинг и качество кода Обновление 1С Программист Бесплатно (free)

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

24.10.2025    1900    1c-izh    6    

6

Обновление 1С Рефакторинг и качество кода 1С v8.3 Абонемент ($m)

Представляю вашему вниманию конфигурацию "Проверка конфигураций (версия 3)", которая позволяет проверять любые конфигурации и расширения на наличие ошибок, связанных с вызовом экспортных функций и процедур общих модулей и модулей менеджеров объектов. Проверяются ошибки: 1) Метод объекта не обнаружен 2) Недостаточно фактических параметров. 3) Слишком много фактических параметров. Рекомендуется выполнять при подготовке обновлений.

10 стартмани

17.10.2025    4593    21    Suker86    12    

19

Рефакторинг и качество кода Программист 1С v8.3 1С:Библиотека стандартных подсистем Абонемент ($m)

Сервер SQL хранит у себя данные по текущему состоянию и выполнению запросов. Например, какой запрос сколько раз выполнялся и сколько времени было потрачено. В топ таких запросов часто будут попадать тяжелые запросы и неоптимальные - которые и нужно будет найти и оптимизировать.

1 стартмани

06.10.2025    1054    7    Alex_Smolensky    25    

4

Рефакторинг и качество кода БСП (Библиотека стандартных подсистем) Механизмы платформы 1С Программист 1С v8.3 1С:Библиотека стандартных подсистем Бесплатно (free)

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

23.09.2025    5344    AlexeyPROSTO_1C    1    

15

HighLoad оптимизация Рефакторинг и качество кода Программист Бесплатно (free)

Рассказываем о том, как не ухудшить производительность интеграционного решения в процессе разработки и рефакторинга, когда новых фич в коробке все больше, а требования по производительности все выше. На живом примере покажем реализованный подход с использованием таких инструментов, как Docker, Redash, Vanessa Automation.

02.09.2025    2677    user1827916    1    

3

Рефакторинг и качество кода Программист Россия Бесплатно (free)

GRASP-паттерны в 1С: меньше хаоса, больше архитектуры.

28.08.2025    10683    lapinio    46    

58
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. kolya_tlt 92 04.11.20 15:43 Сейчас в теме
Добрый день.
1ый пункт даже в стандартах описан
2ой кажется вы правильно поняли Роберта Мартина, либо метод ЗаполнитьЗначенияСвойств принятую "за уши". Бывают случае на проектах, когда пользователям по какой-то не понятной религии ну очень не удобно пользоваться таблицами вместо полей ввода
3 где ж вы были 10 лет назад? ранее работа в компании с огромным количеством докуметов ЧекККМ и на каждый проект добавляли 3-5 реквизита, потом целых 2 года разносили по разным регистрам ...
2. vasilev2015 2833 04.11.20 16:54 Сейчас в теме
(1) Спасибо за комментарий.

1) Пришлите ссылку, буду внимательнее ?

2) Это не про Роберта Мартина, это про нашу жестокую действительность.
Если пользователь очень хочет однотипные поля, то их тоже можно выводить программно, образец - тоже СКД.

3) Зато все при деле, зарплата капает :-))
3. aspirator23 341 04.11.20 18:04 Сейчас в теме
(1) Есть один франчайзи, который разрабатывает продукт 1с для страховщиков. Когда я увидел их документ - договор, у меня выпали предпоследние волосы. С тех пор я не причесываюсь. В этом документе было все. И при всем том, этот продукт был сертифицирован. Может тогда все были добрее?
4. CheBurator 3232 04.11.20 19:41 Сейчас в теме
(3) тогда было больше программистов 1С. они порождали больше кода и больше доставляли.
сейчас программистов гораздо меньше, всё больше раставлятели галочек. Поэтому разннообразия - гораздо меньше.. ;-)
FatPanzer; +1 Ответить
5. vasilev2015 2833 04.11.20 20:01 Сейчас в теме
6. FatPanzer 04.11.20 20:13 Сейчас в теме
(3) Я видел заказ клиента в котором рассчитывались и хранились(!) всякие складские оборачиваемости товаров по складам на момент заказа с учетом количества из заказа (в деньгах и килограммах), исполнения планов продаж по товарам, а также всякие себестоимости и рентабельности... В табличной части, да.
rudnitskij; user1464234; +2 Ответить
7. protexprotex 141 04.11.20 20:49 Сейчас в теме
А я видел когда программисты одной известной фирмы данные по табличной части хранили в файлах типа txt. Правда, это была еще 1С 7.7. - и там надо было хранить подчиненные таблицы другу другу. На мой вопрос - "а почему не хранить в справочниках с id строки строки - владельца" - на меня очень долго смотрели и далее выдали - "а как это?"
user1464234; +1 Ответить
8. FatPanzer 04.11.20 20:56 Сейчас в теме
(7) Ну незнают люди про старые добрые реляционные БД типа dBase и FoxPro...
9. protexprotex 141 04.11.20 22:40 Сейчас в теме
(8) Современные программисты на слово DOS - говорят - "Вы имеете ввиду? dDOS - атака?" :-)
rudnitskij; sanytch; alex-l19041; user1464234; +4 Ответить
10. user1464234 04.11.20 22:46 Сейчас в теме
Кстати да. А зачем прописывать статические ip адреса в сети, если принтеры по вайфай подключаются? И еще у нас в базе когда то был справочник принтеры, где пользователь выбирал на что печатать без предварительного просмотра.
Как в этот справочник добавить принтеры по вайфай подключенные - мак адрес использовать?
Или имени-отчества достаточно?
11. ivanov660 4865 04.11.20 22:53 Сейчас в теме
1. Написать код сразу идеально - это не жизненная позиция, логично требовать отсутствие "г*вно кода". И для выполнения этого требования идеальности существует процедура называемая - рефакторинг.
2. Про пример вложенности обычно я представляю ситуацию с "матрешкой если тогда". Здесь скорее всего имелов ввиду повышение прозрачности при анализе кода, выполнения код-ревью.
3. Третьему утверждению я бы также следовал не всегда. Давайте рассмотрим ситуацию, когда эти реквизиты требуется получить в запросе, то в итоге мы вместо обращения к одной таблице документа будем вынуждены добавлять левые соединения, что может уменьшить быстродействие. Особенно будет заметно на больших объемах баз данных (1% от 100 документов - это 1 документ, а 1% от 1 000 000 это уже 10 000 документов).
К тому же, как я говорил выше, когда выполняются решения о добавлении реквизитов в документ, то вряд ли, кто-то адекватно оценивает возможные объемы данных и понятие приходит постфактум. А в этом случае постфактум выполняем рефакторинг и возможно переосмысление архитектуры.
15. vasilev2015 2833 06.11.20 09:38 Сейчас в теме
(11) Здравствуйте, Владимир !

вместо обращения к одной таблице документа будем вынуждены добавлять левые соединения, что может уменьшить быстродействие


Вдумайтесь: левые соединения не самая медленная операция СУБД.
Самая медленная операция - это сканирование таблицы. Считываются не только все строки, но и все колонки.
Создавая одну большую таблицу мы провоцируем СУБД именно на скан ВСЕЙ таблицы для поиска данных конкретного реквизита.

Индексы ВСЕЙ таблицы не решают проблемы:
Индекс документа устроен так, что не может содержать два реквизита. Поэтому если в запросе нужно получить два реквизита, то СУБД выбирает между левым соединением двух индексов ВСЕЙ таблицы и сканом всей таблицы. Чаще всего это скан.

Однако, если использовать отдельный регистр, то индексы меньше, скан не нужен, левое соединение выгоднее.

Поэтому нормальную архитектуру нужно планировать сразу.
19. ivanov660 4865 06.11.20 15:17 Сейчас в теме
(15)тут вопрос в полях по которым идет отбор и целях получения данных.
Если мы рассматриваем отбор по индексному полю - ссылка, а реквизит как условие был кредит или не было, который влияет на дальнейший путь логики, то никакого скана не будет и вопрос быстродействия появляется)
12. SlavaKron 05.11.20 10:30 Сейчас в теме
Возможно, одинаковые поля лучше выводить в таблицу, как это сделано в настройках СКД ?
Долго не мог понять эту фразу. Наверно, лучше сказать "одинаковые по назначению" или "схожие по назначению" вместо "одинаковые". Вот пример публикации к этому пункту https://infostart.ru/public/1312768/ – реквизиты объекта выводятся каждый в отдельный элемент формы и поиск по имени реквизита преподносится как "фишка" публикации, хотя если сделать это через таблицу значений, в которой уже реализован поиск по колонкам, "киллерфича" будет уже в комплекте.
13. Hatson 539 05.11.20 13:34 Сейчас в теме
Работая уже в N-ой конторе который раз убеждаюсь, что всё, что связано с программированием и технологичностью за рамками типового кода типовых решений 1С лежит исключительно в плоскости перфекционизма. А перфекционизм - это прямое следствие низкой самооценки, и как известно, своими корнями уходит в детские психо-травмы, а это уже область психиатрии. И ЗП программиста при текущей ситуации на рынке труда не зависит от умения писать хороший код. Вы будете удивлены, но она зависит только от качества и здоровья личной самооценки.

Коллеги, если вам кажется, что чей-то код недостаточно хорош, то это отличный повод начать разбираться со своими психо-травмами - скорее всего вы страдаете "синдромом самозванца", или перфекционизмом. И то и другое - заниженная самооценка.
zzzzz; kMidas; kuzyara; +3 1 Ответить
14. ImHunter 341 06.11.20 06:52 Сейчас в теме
(13) Вот так вот))) Нафига всякие DRY, KISS и проч лабуда. Всем к психологу!
rabid_otter; +1 Ответить
16. Hatson 539 06.11.20 11:46 Сейчас в теме
(14) за DRY, KISS и пр лучше идти в Java и др true-языки программирования, но сдается мне и там перфекционисты счастья не найдут ))
23. rabid_otter 134 30.01.21 18:31 Сейчас в теме
(16)
отличный повод начать разбираться со своими психо-травмами

воу воу воу, в ветке появился диванный психиатр?
почему вы считаете нормально написанный код - результатом психо-травм? или так модно сейчас?
за DRY, KISS и пр лучше идти в Java и др true-языки программирования

KISS: в 1С нельзя спроектировать систему проще?
DRY: в 1С нельзя упаковать код в общий модуль или функцию?
имхо, какая-то дичь.
PS: оттираю себя с пола (ведь у меня комплексы и низкая самооценка).
17. vasilev2015 2833 06.11.20 12:06 Сейчас в теме
Чтобы все правильно понимали: я сейчас сижу на месте Василия (Hatson) и вижу его код.
Поверьте, с кодированием у него все в порядке, он _хороший_ инженер.
А в последних комментариях он показывает себя с положительной стороны и как менеджер.
Так что талантливый человек - талантлив во всем :-)))
18. Hatson 539 06.11.20 14:36 Сейчас в теме
Теперь по существу

1) Есть хорошая статья - там не только про операторные скобки.
Вы не умеете работать с транзакциями

2) ЗаполнитьЗначенияСвойств() - так и есть, как бы удобно. Только спустя пару месяцев попробуйте найти в коде место, где используется какое-нибудь поле чего-нибудь там. По-хорошему, придется оставлять длинные комментарии в коде.

3) С картинкой с нулями - вообще красота!!! У нас корпоративный стандарт добавить в справочник номенклатура 50 дополнительных реквизитов и столько же табличных частей, а потом в коде написать Номенклатура.Артикул .... и конечно же в цикле!))))
TerveRus; FatPanzer; +2 Ответить
20. Hatson 539 12.11.20 15:22 Сейчас в теме
Еще один способ получения среза последних. И кто бы мог подумать! Гениально!
PS
Наша ERP пронизана такими паттернами
Прикрепленные файлы:
21. bugagashenka 205 09.12.20 22:19 Сейчас в теме
//Красиво
Пока ВыборкаДетальная.Следующий() Цикл

Если НЕ ПроверитьУсловие() Тогда

Продолжить;
КонецЕсли;

//многабукв
КонецЦикла;


А мне нравится
ДействияВыполнены = ПроверитьУсловие() И ДействияПриИстина();
Функция ДействияПриИстина()
    //многабукв
КонецФункции 


Всегда предпочитаю //многабукв утащить в отдельную функцию. Если она не летит с клиента на сервер, конечно=)
22. rabid_otter 134 30.01.21 18:25 Сейчас в теме
1. у дяди Стива было про определение переменных как можно ближе к месту использования и многое чего другое. как бы само собой разумеется, что легче, когда в голове не надо держать условие оператора if при изучении кода.
2. абстракции - это было про ООП, а не про "ЗаполнитьЗначенияСвойств".
3. это для типовых подходит, а для нетиповых так не получится.
и да, надо уметь правильно декомпозировать задачу.

ради этих трех пунктов надо было городить статью? зачем?
24. vasilev2015 2833 30.01.21 18:48 Сейчас в теме
(22) Проблема не в том, что статья короткая, а в том, что никто не старается программировать.

"Недостаток абстрактного мышления" - это не в контексте ООП, а когда программисты тупят активно пользуются копипастом.

Правила Кодда-Бойса нужно соблюдать и для нетиповых конфигураций тоже.

Верьте в себя, начинайте программировать лучше - все у Вас получится.
25. rabid_otter 134 30.01.21 19:26 Сейчас в теме
(24) бывает так, что при использовании ЗаполнитьЗначенияСвойств не пишется, что нужно заполнить. и вот это не очень хорошо, я для наглядности всегда пишу список свойств, которые мне надо заполнить.
да и так бывает что если базу писали плохо, имена свойств в разных таблицах различаются, и тут тоже указанная выше функция не подходит.
может быть у меня проблемы с логикой, но "избегайте копипаста" != наличие или отсутствие абстрактного мышления.
"Верьте в себя, начинайте программировать лучше - все у Вас получится."
спасибо, желаю и вам того же.
Для отправки сообщения требуется регистрация/авторизация