Нотация для названий функций

В Какао мне очень нравится, как используется возможность «Объектного Си» вставлять параметры прямо в название методов («селекторов»):
[someObject doStuffWithThing:x andThing:y usingParameter:z];

Получаются нормальные предложения. В большинстве языков так делать нельзя, однако формулировать названия функций так, чтобы параметры продолжали предложение, никто не запрещает. Если параметр всего один, или параметры образуют очевидную последовательность, то это добавит удобочитаемости. Я принял нотацию, согласно которой название функции завершается подчёркиванием, если оно составлено по такому принципу. В этом случае открывающая скобка не отбивается пробелом (вообще, я всегда отбиваю; меня страшно бесит, что в ЦССе так делать нельзя).

Пример перевода:
e2_note_by_id ($id)e2_note_with_id_($id).

А так могли бы выглядеть некоторые функции с несколькими параметрами:
do_stuff_at_($x, $y),
do_stuff_with_date_($year, $month, $day).

Если параметры не образуют очевидной последовательности или нормально переформулировать смысл функции не удаётся, то функция пишется «по старинке», без подчёркивания в конце:
e2_store_cache ($path, $data, $secure).

А какие вы используете хитрости для повышения удобочитаемости кода?

Дальше
21 комментарий
somniator 2009

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

Илья Бирман 2009

Ути-пути.

В математике аргумент функции вообще в скобки не берут.

Маркелов Алексей 2009

Именованные параметры есть не только в Objective C. Но и в языках без их явной поддержки можно реализовать что-то подобное при помощи цепочек вызовов (Zend_Db) или при помощи граничных объектов (Win32API).
А самым действенным приемом по повышению удобочитаемости кода является ограничение вложенности до минимума (тогда глубоко вложенные участки кода просто выделяются в отдельные методы)

Степан Столяров 2009

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

Было:
assertTrue(expected);

Стало:
assertThat(expected, is.TRUE);

Роман Парпалак 2009

Угу, в математике сплошь и рядом написано «f x» :)

Илья Бирман 2009

В данном случае скобки просто подсказывают, что f — это функция. Когда используется известная функция, скобки ставят только программисты, а нормальные люди пишут: sin x, ln y и т. д.

Николай Новик 2009

Илья, а можно следить за дискуссией по почте, если сказать нечего? :-)

Илья Бирман 2009

Ну, у вас уже получится :-) А вообще — РСС есть.

bes island 2009

Удобочитаемость — это спорная очень область, кому-то так удобно, а кому-то эдак.

Ante Jan 2009

В ЦССе скобки от селекторов и значения от параметров можно как отбивать пробелами, так и не отбивать, что же вас бесит?

Илья Бирман 2009

Я говорю о круглых скобках. Вариант ##url (’path/to/file.jpg’)## не сработает.

Виктор 2009

В этом случае открывающая скобка не отбивается пробелом (вообще, я всегда отбиваю; меня страшно бесит, что в ЦССе так делать нельзя).

Я не понял, чего в ЦСС сделать нельзя? Какую скобку?

Саша Смирнов 2009

Заметил, что удобочитаемость повышают пропущенные строки (больше, чем традиционный отступ).
На одной кафедре видел код (PL/1) вообще без отступов. Доцент сказал: «Место экономлю». Год 1992!

Павел Малинников 2009

Я тоже ставлю пробел перед круглой скобкой (открывающей) вот почему.

Алисей Лебедев 2009

Не знаю можно ли назвать хитростью, я использую именованные параметры:

%%e2_store_cache(array(
’path’ => ,
’data’ => ,
’is_secure’ =>
));%%

Для булевых значений обязательно ставлю префикс is_ или has_

Вместо длинных цепочек if люблю использовать and:

%%$is_success = (
$photo_id
and extract_photo($photo_id, $working_copy = temporary_file())
and transform_image(array(’src_file’ => $working_copy, ’rotate’ => $angle))
and store_photo($photo_id, $working_copy));%%

Илья Бирман 2009

Я вместо ’is_secure’ написал бы ’secure?’.

А скобку бы закрыл на том же уровне, что и открыл:

%%$is_success = (
$photo_id
and extract_photo ($photo_id, $working_copy = temporary_file ())
and transform_image (array (
’source-file’ => $working_copy,
’rotate’ => $angle
))
and store_photo ($photo_id, $working_copy)
);%%

Надо сказать, что такая цепочка не отличается читаемостью и понятностью.

Олег Подчашинский 2009

Если позволяет язык, можно переходить от передачи параметров последовательной цепочкой к передаче через хеш.

%%^someObject.doStuff[
$.theThing[$x]
$.anotherThing[$y]
$.someParam[$z]
]%%

Также разумно комбинировать:

%%^sorcerer.makeMagic[$badassWand][
$.backupWand[$wand4]
$.useExtraSpells(1)
]%%

Николай Новик 2009

Илья, я таки не получаю комментарии на почту, хотя отметил соответствующий флажок.
Вероятнее всего из-за того, что в мой адрес почты выглядит так: blah+blah.blah@blah.com
Есть ли возможность это исправить?

Илья Бирман 2009

А в спаме их тоже нет?

Виктор 2009

Я смотрю на то, какой стиль предпочитают люди, и вижу, что наиболее близок в этому идеалу, к наилучшей удобочитаемости и ясности кода приблизился язык Ruby.

Даже вот Илья привёл пример, когда вместо «is_secure» лучше написать «secure?».

Илья Бирман 2009

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

Николай Новик 2009

Илья, письма таки в спаме были, спасибо. :-)
И ссылку на РСС для комментов я нашел.

Николай Новик 2009

По поводу комментариев в РСС. Добрая половина комментариев (а именно — те, которые написаны Ильей Бирманом), не входит в ленту, что есть нехорошо. Есть ли возможность и желание это исправить?

bes island 2009

Илья, не соглашусь: я, собравшись ознакомиться с «Руби», смог читать примеры кода на нём без затруднений.

Алисей Лебедев 2009

$is_secure = $something[’secure?’]; // не хочется смешивать

Насчёт руби: там мало визуального шума, поэтому читается он без затруднений, но вот пишется совсем не так легко, как некоторые хотят показать. Обилие в словесного поноса про easy, sexy, fun никак не влияет на способность к запоминанию. Я например до сих пор не усвоил, как там пишется конструкция if.

Николай Товеровский 2009

!!А какие вы используете хитрости для повышения удобочитаемости кода?!!
Я использую висячие комментарии. :)

Илья Бирман 2009

Я по этому же принципу строки, начинающиеся с подчёркивания, пишу на один пробел раньше, чтобы подчёркивание висело налево.

Виктор 2009

Алисей Лебедев, а если «store_photo» закончится неудачей, и нужно будет почистить хвосты от extract_photo и transform_image?

Илья Семенов 2009

Я тоже ставлю пробел перед круглой скобкой (открывающей) вот почему

«Тоже»? Вы говорите о разных вещах: Илья — о вызовах и/или объявлениях функций, а ты — об управляющих конструкциях языка. Эти понятия практически всегда разделяются. Лично мне противно видеть пробел перед скобкой в первом случае и противно НЕ видеть пробел во втором. Этого мнения придерживаются и некоторые другие, например:
http://www.python.org/dev/peps/pep-0008/ «Whitespace in Expressions and Statements»
http://pear.php.net/manual/en/standards.funcalls.php + http://pear.php.net/manual/en/standards.control.php

Да, а подчеркивание на конце имени функции — это детство какое-то. Это тупо лишняя сущность, зачем-то повторно (кроме скобки) отделяющая название вызываемой функции от списка аргументов.

Илья Бирман 2009

Она не отделяет, а, наоборот, соединяет.

Мои книги