Версия для печати темы
Нажмите сюда для просмотра этой темы в оригинальном формате
Форум программистов > .NET для новичков > использование разных интеропок (dll)


Автор: blackbanny 5.12.2013, 09:58
Доброго времени суток!

С C# работаю недавно, пока не очень силен в нюансах. 

Ситуация следующая:

Есть две интеропки для SDK, называются одинаково (Interop.SDK.dll) просто одна для версии 1 SDK, в вторая для 2.
API в этих двух версиях немного разное. При подключении одной из интеропок пишу конечно 
Код

using SDK;


Проблема в том, что API во второй версии немного изменилось. В v.2 нет совместимости с v.1.
Из второй версии нужно использовать только одну новую фичу. 

Возможно ли сделать следующее:

Подключаем интероп для v1., пишем using SDK; ..., компилим проект, запускаем.
По ходу выполнения программы проверяем установлено ли SDK v.2 на компьютере, если да, то подгружаем интероп v.2 и с помощью API юзаем новую фичу ?

Если это возможно, подскажите, как это можно реализовать.

Автор: blackbanny 5.12.2013, 13:07
решил проблему. для второй версии SDK создал отдельный проект, как "Class Library" и подключил его потом к первому, который использует SDK v.1

Автор: jonie 6.12.2013, 10:43
а можно просто использовать extern alias-ы
Вот ссылка на референс языка: http://msdn.microsoft.com/en-us/library/ms173212%28v=vs.120%29.aspx

Собственно цитата оттуда:
Цитата

You might have to reference two versions of assemblies that have the same fully-qualified type names. For example, you might have to use two or more versions of an assembly in the same application. By using an external assembly alias, the namespaces from each assembly can be wrapped inside root-level namespaces named by the alias, which enables them to be used in the same file.

To reference two assemblies with the same fully-qualified type names, an alias must be specified at a command prompt, as follows:

/r:GridV1=grid.dll

/r:GridV2=grid20.dll

This creates the external aliases GridV1 and GridV2. To use these aliases from within a program, reference them by using the extern keyword. For example:

extern alias GridV1;

extern alias GridV2;

Each extern alias declaration introduces an additional root-level namespace that parallels (but does not lie within) the global namespace. Thus types from each assembly can be referred to without ambiguity by using their fully qualified name, rooted in the appropriate namespace-alias.

In the previous example, GridV1::Grid would be the grid control from grid.dll, and GridV2::Grid would be the grid control from grid20.dll.

Powered by Invision Power Board (http://www.invisionboard.com)
© Invision Power Services (http://www.invisionpower.com)