Форум программистов, компьютерный форум, киберфорум
C# .NET
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.94/18: Рейтинг темы: голосов - 18, средняя оценка - 4.94
1 / 1 / 0
Регистрация: 25.06.2013
Сообщений: 15

Динамическая загрузка из управляемой DLL

15.10.2015, 15:13. Показов 3829. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Есть основное приложение, во время работы которого, необходимо динамически, по необходимости, создавать экземпляр класса из управляемой библиотеки DLL, и также, по необходимости уничтожать этот экземпляр и выгружать библиотеку. Когда библиотека выгружена, должна быть возможность вносить в нее изменения, пересобрать ее, и не останавливая приложение, во время его работы повторить все действия указанные выше для измененной библиотеки. Среда Framework 4.0

Привожу упрощенный вариант основной программы и библиотеки
Ниже приведен код DLL

C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Runtime.Serialization;
namespace MainProject
{ 
    [Serializable]
    public class TypeIWantToLoad : InterfBase
    {    
        public TypeIWantToLoad()
        {
            Console.WriteLine("15:58============");                     
        }
      
        public  void DoIt()
        {
            Console.WriteLine("=========DO it ! 15:58============");            
        }
    }
}
Этот класс выводит на консоль две похожие надписи в конструкторе и в методе класса.
Ниже приведен код основной программы.

C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Reflection;
namespace MainProject
{
    class Program
    {
        static void Main(string[] args)
        {
            LoadUnload();
            System.Threading.Thread.Sleep(30000);
            LoadUnload();                      
        }
        
        static void LoadUnload()
        {
            var domain = AppDomain.CreateDomain("DomainName");            
            var pathToDll = @"e:\Dropbox\proj\MultyAssembly\DLLProj\DLLProj\bin\Debug\DllProj.dll";                      
            InterfBase inst = (InterfBase)domain.CreateInstanceFromAndUnwrap(pathToDll, "MainProject.TypeIWantToLoad");           
            inst.DoIt();                      
            AppDomain.Unload(domain);                    
        }
    }
     public interface InterfBase
     {
         void DoIt();
     }
}
Здесь загружается библиотека, создается экземпляр класса из библиотеки, выгружается библиотека, потом выдержка по времени 30 сек. Во время этой выдержки, пока библиотека выгружена, я меняю в коде библиотеки в выводе на консоль с время 15:58 на 15:59 и в конструкторе, и в методе DoIt. После окончания выдержки выполняется повторная загрузка уже измененной библиотеки и создание из нее нового класса.

Результат вывода на экран:
15:58============
=========DO it ! 15:58============
15:59============
=========DO it ! 15:58============

Т.е. изменения в конструкторе применились, а в методе DoIt нет, выполняется старый код Собственно вопрос и состоит в том, как сделать так, чтобы изменения в библиотеке при повторной загрузке применялись а не только в конструкторе, но и в методах класса.
1
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
15.10.2015, 15:13
Ответы с готовыми решениями:

Динамическая загрузка DLL
Добрый день, есть DLL написанная на Delphi: library Project1; uses System.SysUtils, System.Classes, Winapi.Windows, ...

Динамическая загрузка dll
Есть dll с кодом using System; using System.Collections.Generic; using System.Linq; using System.Text; using...

Динамическая загрузка DLL, сборки и домены
Сделал по этой статье http://habrahabr.ru/post/247615/ приложение которое все необходимые для своей работы ДЛЛ содержит внутри себя как...

7
Master of Orion
Эксперт .NET
 Аватар для Psilon
6101 / 4957 / 905
Регистрация: 10.07.2011
Сообщений: 14,522
Записей в блоге: 5
15.10.2015, 17:24
constant_ural, а так?
C#
1
2
3
4
5
6
7
8
9
10
11
static void LoadUnload()
{
    var domain = AppDomain.CreateDomain("DomainName");
    var pathToDll = @"e:\Dropbox\proj\MultyAssembly\DLLProj\DLLProj\bin\Debug\DllProj.dll";
    domain.DoCallBack(() =>
                        {
                            InterfBase inst = (InterfBase)domain.CreateInstanceFromAndUnwrap(pathToDll, "MainProject.TypeIWantToLoad");
                            inst.DoIt();
                        });
    AppDomain.Unload(domain);
}
1
1 / 1 / 0
Регистрация: 25.06.2013
Сообщений: 15
15.10.2015, 18:25  [ТС]
Code
1
constant_ural, а так?
Получаю исключение

Необработанное исключение типа "System.Runtime.Serialization.Serializat ionException" произошло в MainProject.exe

Дополнительные сведения: Тип "MainProject.Program+<>c__DisplayCla ss1" сборки "MainProject, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null" не помечен как сериализуемый.
0
Master of Orion
Эксперт .NET
 Аватар для Psilon
6101 / 4957 / 905
Регистрация: 10.07.2011
Сообщений: 14,522
Записей в блоге: 5
15.10.2015, 18:34
Лучший ответ Сообщение было отмечено constant_ural как решение

Решение

constant_ural, а так?
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
    [Serializable]
    class Pass
    {
        private readonly AppDomain _domain;
        private readonly string _dllPath;
 
        public Pass(AppDomain domain, string dllPath)
        {
            _domain = domain;
            _dllPath = dllPath;
        }
 
       public void Foo()
        {
            InterfBase inst = (InterfBase)_domain.CreateInstanceFromAndUnwrap(_dllPath, "MainProject.TypeIWantToLoad");
            inst.DoIt();
        }
    }
C#
1
2
3
4
5
6
7
8
        static void LoadUnload()
        {
            var domain = AppDomain.CreateDomain("DomainName");
            var pathToDll = @"e:\Dropbox\proj\MultyAssembly\DLLProj\DLLProj\bin\Debug\DllProj.dll";
            var pass = new Pass(domain, pathToDll);
            domain.DoCallBack(pass.Foo);
            AppDomain.Unload(domain);
        }
1
1 / 1 / 0
Регистрация: 25.06.2013
Сообщений: 15
15.10.2015, 18:52  [ТС]
constant_ural, а так?
Урра ! Работает !
Psilon, спасибо преогромное !!! Ты гений !

Psilon, буду тебе очень признателен, если скажешь, почему изначально не работало, и почему заработало после колбэка. Если лень/некогда это делать, то скажи пожалуйста в какую сторону копать хотя бы.
0
Master of Orion
Эксперт .NET
 Аватар для Psilon
6101 / 4957 / 905
Регистрация: 10.07.2011
Сообщений: 14,522
Записей в блоге: 5
15.10.2015, 22:02
constant_ural, все просто, код, который выполняется в домене, в нем и остается. Так как ты создавал тип и вызывал его методы в главном домене - их код в нем так и оставался, и неважно, что ты его выгружал. Когда ты используешь DoCallBack, весь код выполняется в домене, который потом выгружается - как и ожидалось. Без класса не работало из-за особенностей реализации замыканий в шарпе - поэтому приходится создавать свой класс с атрибутом, вместо автогенерированного. Всё, в общем-то
1
1 / 1 / 0
Регистрация: 25.06.2013
Сообщений: 15
17.10.2015, 07:34  [ТС]
Psilon, еще если можно, один вопрос.

Как я понял, когда мы создаем экземпляр объекта A в новом домене, в случае если мы передаем туда ссылку на объект B из основного домена, тогда передается копия объекта B, полученная в результате сериализации/десериализации. Возможно ли в из экземпляра объекта A в новом домене получить ССЫЛКУ на экземпляр объекта B ?. Какие-то способы взаимодействия и обмена данными между доменами существуют при рассмотренном выше подходе ?
0
Master of Orion
Эксперт .NET
 Аватар для Psilon
6101 / 4957 / 905
Регистрация: 10.07.2011
Сообщений: 14,522
Записей в блоге: 5
17.10.2015, 11:07
constant_ural, по простому - никак. Домены это практически разные процессы, соответственно и для взаимодействия между ними используются подобные вещи - пайпы, сокеты, WCF и т.п. А это подразумевает сериализацию на одном конце, и десериализацию на другом:
https://msdn.microsoft.com/en-... 2147217396

ИМХО проще вам научиться с MEF работать - это система подключения плагинов. Там в одном домене можно подгружать и выгружать dll-ки. Соответственно все взаимодействия упрощаются.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
17.10.2015, 11:07
Помогаю со студенческими работами здесь

Динамическая загрузка Dll из ресурсов и ее использование
Пытаюсь разобраться для себя , прошу помощи сделал как в статье https://habrahabr.ru/post/85480/ для теста скачал dotnetzip...

Динамическая загрузка dll и использование ее через интерфейс
Есть интерфейс, есть библиотека классов с классом от этого интерфейса, есть клиентское приложение, которое динамически загружает библиотеку...

Синхронная динамическая загрузка .DLL в нескольких потоках, возможно ли?
Есть библиотека на .NET При синхронном вызове функций библиотеки из нескольких потоков моего приложения она работает некорректно...

Динамическая загрузка dll
Хочу использовать https://github.com/naudio/Vorbis для которго нужно подключить https://github.com/NVorbis/NVorbis. Но я не понимаю, как...

Зависимость от других DLL и динамическая их загрузка
При компиляции DLL было использовано 5 других DLL ( References ). Скриншот: Что надо использовать чтобы подгрузить собственно...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru