Ортогональность (программирование)

редактировать

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

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

Пример из IBM Mainframe и VAX подчеркивает эту концепцию. У мэйнфрейма IBM есть две разные инструкции для добавления содержимого регистра в ячейку памяти (или другой регистр). Эти операторы показаны ниже:

A Reg1, memory_cell AR Reg1, Reg2

В первом случае содержимое Reg1добавляется к содержимому ячейки памяти. ; результат сохраняется в Reg1. Во втором случае содержимое Reg1добавляется к содержимому другого регистра (Reg2), и результат сохраняется в Reg1.

В отличие от приведенного выше набор операторов, VAX имеет только один оператор для добавления:

операнд1 ADDL, операнд2

В этом случае два операнда (операнд1и операнд2) могут быть регистрами, ячейками памяти или их комбинацией; инструкция добавляет содержимое операнда1к содержимому операнда2, сохраняя результат в операнде1.

. Инструкция VAX для сложения более ортогональна, чем инструкции, предоставляемые IBM; следовательно, программисту легче запомнить (и использовать) тот, который предоставляется VAX.

Дизайн языка C может быть исследован с точки зрения ортогональности. Язык C несколько непоследователен в трактовке понятий и языковой структуры, что затрудняет изучение (и использование) языка пользователем. Ниже приведены примеры исключений:

  • Структуры (но не массивы) могут быть возвращены функцией.
  • Массив может быть возвращен, если он находится внутри структуры.
  • Член структуры может быть любым типом данных (кроме void или структуры того же типа).
  • Элемент массива может быть любым типом данных (кроме void). Все передается по значению (кроме массивов).

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

Содержание
  • 1 См. Также
  • 2 Ссылки
  • 3 Дополнительная литература
  • 4 Внешние ссылки
См. Также
Ссылки
  1. ^«Компактность и Ортогональность ». www.catb.org. Проверено 6 апреля 2018 г.
  2. ^Себеста, Роберт В. (2010). Понятия языков программирования (9-е изд.). Бостон: Эддисон-Уэсли. п. 10. ISBN 9780136073475. OCLC 268788303.
Дополнительная литература
  • Прагматичный программист: от подмастерья к мастеру Эндрю Хант и Дэвид Томас. Эддисон-Уэсли. 2000. ISBN 978-0-201-61622-4.
Внешние ссылки
Последняя правка сделана 2021-06-01 03:17:42
Содержание доступно по лицензии CC BY-SA 3.0 (если не указано иное).
Обратная связь: support@alphapedia.ru
Соглашение
О проекте