От математики к обобщенному программированию
www.samag.ru
Журнал «БИТ. Бизнес&Информационные технологии»      
Поиск   
              
 www.samag.ru    Web  0 товаров , сумма 0 руб.
E-mail
Пароль  
 Запомнить меня
Регистрация | Забыли пароль?
Журнал "Системный администратор"
Журнал «БИТ»
Подписка
Архив номеров
Где купить
Наука и технологии
Авторам
Рекламодателям
Контакты
   

  Опросы
1001 и 1 книга  
19.03.2018г.
Просмотров: 6698
Комментарии: 0
Машинное обучение с использованием библиотеки Н2О

 Читать далее...

12.03.2018г.
Просмотров: 7292
Комментарии: 0
Особенности киберпреступлений в России: инструменты нападения и защита информации

 Читать далее...

12.03.2018г.
Просмотров: 4543
Комментарии: 0
Глубокое обучение с точки зрения практика

 Читать далее...

12.03.2018г.
Просмотров: 3131
Комментарии: 0
Изучаем pandas

 Читать далее...

12.03.2018г.
Просмотров: 3933
Комментарии: 0
Программирование на языке Rust (Цветное издание)

 Читать далее...

19.12.2017г.
Просмотров: 3944
Комментарии: 0
Глубокое обучение

 Читать далее...

19.12.2017г.
Просмотров: 6439
Комментарии: 0
Анализ социальных медиа на Python

 Читать далее...

19.12.2017г.
Просмотров: 3288
Комментарии: 0
Основы блокчейна

 Читать далее...

19.12.2017г.
Просмотров: 3574
Комментарии: 0
Java 9. Полный обзор нововведений

 Читать далее...

16.02.2017г.
Просмотров: 7424
Комментарии: 0
Опоздавших не бывает, или книга о стеке

 Читать далее...

17.05.2016г.
Просмотров: 10789
Комментарии: 0
Теория вычислений для программистов

 Читать далее...

30.03.2015г.
Просмотров: 12498
Комментарии: 0
От математики к обобщенному программированию

 Читать далее...

18.02.2014г.
Просмотров: 14197
Комментарии: 0
Рецензия на книгу «Читаем Тьюринга»

 Читать далее...

13.02.2014г.
Просмотров: 9240
Комментарии: 0
Читайте, размышляйте, действуйте

 Читать далее...

12.02.2014г.
Просмотров: 7190
Комментарии: 0
Рисуем наши мысли

 Читать далее...

10.02.2014г.
Просмотров: 5487
Комментарии: 3
Страна в цифрах

 Читать далее...

18.12.2013г.
Просмотров: 4722
Комментарии: 0
Большие данные меняют нашу жизнь

 Читать далее...

18.12.2013г.
Просмотров: 3544
Комментарии: 0
Компьютерные технологии – корень зла для точки роста

 Читать далее...

04.12.2013г.
Просмотров: 3252
Комментарии: 0
Паутина в облаках

 Читать далее...

03.12.2013г.
Просмотров: 3483
Комментарии: 0
Рецензия на книгу «MongoDB в действии»

 Читать далее...

02.12.2013г.
Просмотров: 3140
Комментарии: 0
Не думай о минутах свысока

 Читать далее...

Друзья сайта  

 От математики к обобщенному программированию

Статьи / От математики к обобщенному программированию

Автор: Алексей Вторников

Если ваш опыт программирования от года и больше, если вам доводилось писать программы больше, скажем, 3000 строк исходного кода, то вы, безусловно, найдете в книге много полезного и занимательного (поверьте, математика не обязана быть скучной!).

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

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

Жан-Батист Мольер «Мещанин во дворянстве»

Для большинства программистов, знакомых с такими языками как C++ или Java, понятие обобщенного программирования (англ. generic programming), вынесенное в оригинальное название книги, означает, прежде всего, языковые конструкции, позволяющие специфицировать типы данных, хранимые в коллекциях. Типичными примерами (на Java) являются, например, следующие:

// Список строк

ArrayList <String> = new ArrayList <> ();

// Карта (соответствие «ключ:значение»)

Map <String, MyType> table = new TreeMap <> ();

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

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

Согласитесь, что такое определение в силу его общности не слишком информативно. Но давайте не будем спешить, а обратимся к книге и, прежде всего, к ее оглавлению.

Первое, что обращает на себя внимание – то, что авторы избрали способ изложения, который принято называть «генетическим»: проблемы ставятся и рассматриваются в историческом контексте. Такой способ изложения весьма распространен в книгах по математике (см. например, «Последняя теорема Ферма. Генетическое введение в алгебраическую теорию чисел» Г.Эдвардс, М.: Мир, 1980) и позволяет аккуратно ввести читателя в круг рассматриваемых проблем. Генетический способ изложения концентрируется не только на математической составляющей той или иной проблемы, но и на истории появления самой проблемы и предпринятых способов ее решения. Читатель не столько читает, сколько погружается в ту или иную область; он ощущает себя не пассивным субъектом, а активным участником интеллектуального действа.

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

После этого в значительной степени вводного материала (гл. 1 ... 5) авторы обсуждают понятия, которые – увы – большинству программистов (если только они не имеют математического образования) неизвестны: группы, моноиды, кольца, поля и пр. Это – уже элементы абстрактной алгебры. Но не стоит заранее пугаться только потому, что раньше вы всего этого не знали. Прочтите-ка еще разок эпиграф к этому обзору.

Думаю, что я не ошибусь, если скажу, что со многим из этого – и группами, и кольцами, и полями – вы, скорее всего, неоднократно сталкивались, но только, возможно, не знали, что они так называются.

Эти три главы (с 6-й по 8-ю), посвященные абстрактной алгебре и алгебраическим структурам, могут показаться достаточно сложными, но я спешу успокоить тех, кто сомневается в своих математических способностях – не так страшен черт, как его малюют. Конечно, сам материал этих глав достаточно непривычен, но он отнюдь не так сложен, как может показаться. Вспомните, как вы осваивали велосипед или учились кататься на коньках – были и падения, и ушибы, но, в конце концов, вы научились. Так же и в математике – первые шаги в новой области будут непростыми. Но преодолимыми, поскольку нет людей, не способных к математике; есть только лень и необоснованные сомнения.

Безусловно, вы вправе спросить «Ну, и зачем мне нужны все эти кольца, группы или какая-то теорема Лагранжа?». На это я могу ответить одно – чтобы понять вкус кофе, надо пить кофе; чтобы стать знатоком музыки – надо слушать музыку. Можно, конечно, сразу же решить, что абстрактная алгебра с ее непривычным аппаратом и понятиями вам не нужны,– это, конечно, ваше право. Но тогда вы и не поймете, чего лишились. Не спорю, возможно, все эти алгебраические премудрости лично вам и не нужны, но как можно быть в этом уверенным, если вы с ними даже не познакомились? Так что я прошу вас не спешить и не делать поспешных выводов.

Еще несколько слов в «защиту» алгебры (в чем, она, конечно, не нуждается). Вспомните определение generic programming, приведенное в начале этой заметки; ключевое в нем – функционирование алгоритмов и структур данных в самом широком окружении. Так вот, алгебра и изучает, и предоставляет нам – программистам - это «самое широкое окружение». Более того, вся современная математика постепенно алгебраизуется, т.е. воспринимает понятия и методы, исходящие из алгебры. А программирование – как ни крути – это именно математика.

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

Кроме того, в книгу включены три небольших приложения, последнее из которых описывает некоторые особенности C++ для тех, кто не знаком с этим языком программирования.

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

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

И, напоследок, следует напомнить, что один из авторов книги – Александр Степанов – заслуженно относится к числу самых выдающихся программистов современности. Он стоял у истоков generic programming и, безусловно, является первоисточником и авторитетом в понимании смысла и содержания этого понятия. Для программистов С++ позволю себе еще напомнить, что библиотека STL (обобщенные алгоритмы, контейнеры и средства доступа к ним) – творение А.Степанова

Комментарии отсутствуют

               Copyright © Системный администратор

Яндекс.Метрика
Tel.: (499) 277-12-45
E-mail: sa@samag.ru