Программирование в большом и программирование в малом - Programming in the large and programming in the small

В программная инженерия, программирование в большом и программирование в малых описать два разных подхода к написанию программного обеспечения. Термины были придуманы Фрэнк Де Ремер и Ганс Крон в своей статье 1975 года «Программирование в большом против программирования в малом».[1] Подобное позднее различие Дихотомия Остерхаута между системное программирование языки (для компонентов) и языки сценариев за клей код, соединяющие компоненты.

Описание

Фред Брукс определяет, что способ создания отдельной программы отличается от того, как создается продукт системы программирования.[2] Первый, вероятно, хорошо справляется с одной относительно простой задачей. Вероятно, он написан одним инженером, сам по себе завершен и готов к работе в системе, в которой он был разработан. Деятельность по программированию, вероятно, была довольно недолгой, поскольку простые задачи выполнялись быстро и легко. Это стремление, которое ДеРемер и Крон описывают как программирование в малом.

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

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

Программирование в целом

В разработка программного обеспечения, программирование в целом может включать программирование большими группами людей или меньшими группами в течение более длительных периодов времени.[2] Любое из этих условий приведет к созданию больших и, следовательно, сложных программ, которые могут быть сложными для понимания разработчиками.

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

При программировании в целом изменение программы может стать трудным.[2] Если изменение затрагивает границы модуля, может потребоваться переделать работу многих людей. Из-за этого одна из целей программирования в целом заключается в настройке модулей, которые не нужно будет изменять в случае возможных изменений. Это достигается за счет проектирования модулей таким образом, чтобы они имели высокую сплоченность и свободно связь.

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

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

Концепция была представлена Фрэнк Де Ремер и Ганс Крон в своей статье 1975 г. «Программирование в большом масштабе против программирования в малом», IEEE Trans. на Софт. Англ. 2 (2).

В Информатика термины, программирование в большом может относиться к программному коду, представляющему высокоуровневый переход состояния логика система.[сомнительный ] Эта логика кодирует информацию, например, когда ждать Сообщения, когда отправлять сообщения, когда компенсировать неудачные не-КИСЛОТА транзакции и др.

Язык, который был разработан для явной поддержки программирования в целом, - это BPEL.

Программирование в малом

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

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

С точки зрения информатики, программирование мелких сделок с недолговечным программным поведением, часто выполняемым как единое целое. КИСЛОТА транзакции и которая позволяет получить доступ к локальной логике и ресурсам, таким как файлы, базы данных и т. д.[сомнительный ]

Рекомендации

  1. ^ http://portal.acm.org/citation.cfm?id=808431
  2. ^ а б c Брукс, Фредерик П., младший (1982). «Дегтярная яма», изд. Мифический человеко-месяц - юбилейное издание. ISBN  0-201-83595-9

дальнейшее чтение