Норвиг:
Как таковым - нет. Конечно, я писал макросы и тому подобное, использовал документы Java. Программирование на Лиспе побуждает к созданию собственной системы по мере написания кода, в конце концов это выливается в литературное программирование. Вырабатываешь собственные макросы для программирования в контексте своего приложения - тут и документация, и данные, и код. Так что в принципе я занимался этим. Уже позднее, работая с Java, или Python, или другим языком, я внимательно относился к созданию тестов и документации для них.На самом деле, в своей книге Кнут пытался рассказать, в каком порядке лучше всего писать книгу, полагая, что кто-то собирается читать книгу целиком и хочет, чтобы это происходило в определенном порядке. Но так уже никто не делает. Человек заглядывает в содержание и выясняет, какой наименьший по объему кусок ему нужно прочесть. Оказывается, ему нужно всего три абзаца. Он находит их и читает. Думаю, это серьезная перемена.
Сейбел:
А нельзя ли писать литературные программы в более современном стиле? То, что есть у Кнута, позволяет создать указатель и прекрасную систему перекрестных ссылок. Может быть, если осовременить этот подход, мы получим книгу, построенную по-другому? Она будет читаться и как целая программа, и по кускам.Норвиг:
Не знаю. По-моему, он решал проблему, которой уже почти нет. Отчасти из-за того, что Кнут расположил все линейно, а не в веб-стиле или в порядке, удобном для поиска. Отчасти из-за ограничений - изначально он использовал Паскаль, а этот язык очень строг в отношении порядка определений, и он не всегда такой, как вам нужно. Современные языки более гибкие в этом смысле. Думаю, проблема сегодня не столь актуальна.Сейбел:
Вы говорили о том, как читали в “Scientific American” код программы для шашек. В книге “Как самому научиться программировать за десять лет” вы подчеркиваете важность чтения кода. Какой код вы еще читали, кроме кода Стрейчи?Норвиг:
Много кода Symbolics - он был под рукой, когда я работал в Беркли.Сейбел:
Из-за того, что он был под рукой и был интересным? Или вы пытались разобраться в том, что наблюдали?Норвиг:
И то и другое. Иногда я просто пытался понять, как все устроено, а иногда решал конкретную задачу.Сейбел:
Если вы читаете просто для самообразования, то что именно?Норвиг:
То, что мне интересно. “Смотри-ка, эта файловая система позволяет читать файлы по сети при помощи того же протокола, что я локально использую на своей машине. Как это? Может быть, это в функции open?” Смотришь на то, что эта функция вызывает, смотришь еще куда-нибудь и понимаешь, как это работает.Сейбел:
Вы читали книги с литературными программами Кнута?Норвиг:
Листал. Не скажу, что читал.Сейбел:
А как насчет “Искусства программирования”? Одни мои собеседники прочли ее от корки до корки, другие поставили на полку и используют для справок, третьи просто поставили на полку.Норвиг:
Как-то я сделал из нее подставку для монитора - это ведь громадный многотомник, как раз подошел по высоте. Думал, если он будет прямо передо мной, то я, наконец-то, начну его использовать.Сейбел:
Но ведь надо было всякий раз поднимать монитор?Норвиг:
Нет, тома были в коробке. Если сильно потянуть, можно достать. Сейчас я редко пользуюсь книгами для справки - все больше интернет-поиском.Сейбел:
Потому что так удобнее?Норвиг:
Удобнее. А еще потому, что я теперь больше ориентирован на цель. Кнут хорош, когда нужно узнать о каком-то предмете все. А мне нужно знать, чем А лучше Б, или выяснить приблизительную сложность чего-то, но подробности мне ни к чему.Сейбел:
Кем вы себя считаете - ученым, инженером, художником, ремесленником?Норвиг:
Если взять названия разных книг и тому подобного, больше всего подойдет слово “ремесленник”. “Художник” - чуточку претенциозно, потому что искусство должно нести красоту, или устанавливать эмоциональный контакт, или вызывать эмоциональное воздействие. Это не имеет отношения к тому, что я пытаюсь сделать. Конечно, я хочу видеть в программах красоту и трачу на это, пожалуй, слишком много времени. У меня был период в жизни, когда я мог сказать себе: “А не вернуться ли назад, чтобы переписать вон тот кусок?” И когда писал что-то для публикации, тратил на это больше времени, чем ради только личного профессионального роста.Но это, мне кажется, не искусство. “Ремесло” - вот самый подходящий термин. Вы можете сделать стул, на который приятно смотреть, но это все равно предмет функционального назначения.
Сейбел:
Как вы распознаете хорошего программиста, особенно во время собеседования? Ваша компания нанимает много программистов, разумеется, лучших. Как вы их выбираете?Норвиг:
До сих пор не знаем.Сейбел:
Google известен тем, что на собеседованиях претендентам задают логические загадки. Как полагаете, это удачный подход?