Что такое Шим?

Какое определение у Шима?

8 ответов

Решение

Из Википедии:

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

Общая концепция - простое объяснение через мультфильм

Пример прокладки:

My Dog Ralph - один счастливчик (двойной каламбур

Резюме

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

Термин "прокладка", как он определен в Википедии, будет технически классифицирован на основе его определения как "структурный" шаблон проектирования. Множество типов "структурных" шаблонов проектирования довольно четко описаны в (иногда можно сказать, де-факто) объектно-ориентированных шаблонах проектирования программного обеспечения, которые ссылаются на "Шаблоны проектирования, элементы многоразового объектно-ориентированного программного обеспечения", более известные как "Банда четырех".

В тексте "Банды четырех" описаны по крайней мере 3 хорошо известных шаблона, известные как "Прокси", "Адаптер" и "Фасад", которые обеспечивают функциональность типа "прокладка". В большинстве областей зачастую использование или сокращение разных акронимов для одной и той же корневой концепции часто приводит к путанице. Использование слова "прокладка" для описания более конкретных "структурных" шаблонов проектирования "Прокси", "Адаптер" и "Фасад", безусловно, является ярким примером ситуации такого типа. "Шим" - это просто более общий термин для более конкретных типов "Структурных" паттернов "Прокси", "Адаптер", "Фасад" и, возможно, других.

Согласно статье Microsoft "Демистификация Шимс":

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

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

В статье в качестве примера используется Windows API, и я нашел следующее предложение актуальным:

Как правило, приложение не знает, что запрос направляется в shim DLL, а не в саму Windows, а Windows не знает, что запрос поступает из источника, отличного от приложения (потому что shim DLL - это просто еще одна DLL внутри процесса приложения),

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

Каковы некоторые плюсы и минусы использования прокладок?

Опять же из статьи:

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

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

Что касается происхождения слова, quoth виджет Apple's Dictionary

noun
   a washer or thin strip of material used to align parts, 
   make them fit, or reduce wear.

verb ( shimmed, shimming) [ trans. ]
   wedge (something) or fill up (a space) with a shim.

ORIGIN early 18th cent.: of unknown origin

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

Оболочки используются в.net 4.5 Microsoft Fakes framework для изоляции вашего приложения от других сборок для модульного тестирования. Shims перенаправляет вызовы определенных методов в код, который вы пишете как часть вашего теста

Еще один пример прокладки

Когда я был ребенком, моя бабушка жила в том же городе. Это был маленький городок. Все знали друг друга.

Я писал ей письма:

To:   Grand Ma
From: Ben

и отправь это в почтовый ящик.......... письма, которые ей доставляли в обязательном порядке. Я не знал и не заботился, как это случилось. Возникает вопрос: как были доставлены письма?

Это просто: сообщения были объединены. Потому что это был небольшой город, парень в почтовом отделении знал, кто написал письмо (Бен от Woop Woop), и знал, что адрес бабушки, и поэтому изменяется и подкладками адрес, чтобы сообщение могло быть правильно доставлено ей.

Это та же основная концепция, но применяется только к коду.

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

Тем не менее, я думаю, что могу добавить хороший пример, который является Javascript ES5 Shim ( https://github.com/es-shims/es5-shim):

Javascript сильно изменился за последние несколько лет, и среди многих других изменений в спецификации языка было добавлено много новых методов в его основные объекты.

Например, в спецификации ES2015 (он же ES5) метод find был добавлен к Array прототип. Итак, допустим, что вы выполняете свой код с использованием движка JavasScript до этой спецификации (например, Node 0.12), который пока не предлагает этот метод. При загрузке прокладки ES5 эти новые методы будут добавлены в Array прототип, позволяющий вам использовать их, даже если вы не используете более новую спецификацию JavaScript.

Вы можете спросить: почему кто-то делает это вместо обновления среды до более новой версии (скажем, Node 8)?

Существует много реальных сценариев, в которых такой подход имеет смысл. Один хороший пример:

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

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

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

Другой реальный сценарий, где такой подход приветствуется, - на уровне браузера. Допустим, вам нужна поддержка старого браузера и вы хотите воспользоваться этими новыми функциями. Javascript - это язык, который позволяет добавлять / изменять методы в его основных объектах (например, добавлять методы в прототип Array), и эти библиотеки shim достаточно умны, чтобы добавлять такие методы, только если в текущей реализации их нет.

PS: 1) Вы увидите термин "Polyfill", связанный с этими прокладками Javascript. Polyfill - это более специализированный тип прокладок, который используется для обеспечения прямой совместимости в различных спецификациях уровня браузера. Кстати, мой пример выше относится именно к такому примеру.

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

3) Если вам интересно, как реализован этот конкретный полифильм, вы можете открыть спецификации Javascript Array.find и прокрутить до конца страницы, где вы найдете каноническую реализацию для этого метода.

SHIM - это еще один уровень проверки безопасности, который выполняется для всех служб для защиты вышестоящих систем. Сервер SHIM проверяет каждый входящий запрос с учетными данными пользователя заголовков на соответствие учетным данным пользователя, которые передаются в запросе (SOAP / RESTFUL).

Другие вопросы по тегам