Форум программистов, компьютерный форум, киберфорум
C# .NET
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.88/25: Рейтинг темы: голосов - 25, средняя оценка - 4.88
-19 / 1 / 2
Регистрация: 05.11.2012
Сообщений: 48

Передать делегат (заранее неизвестный) в метод

11.12.2013, 18:54. Показов 4905. Ответов 25
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Сразу к сути: нужно передать делегат (заранее не известный) в нутрь метода для использования - пытаюсь так:

C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
        public static void NativeDLL<NativeInvoker>(string fname, string pname)
        {
            //  Открываем DLL, получаем ее Handle
            IntPtr hExe = API.LoadLibrary(fname);
            //  Получаем адрес функции, экспортируемой DLL
            IntPtr NativeFunction = API.GetProcAddress(hExe, pname);
 
            //  Используя маршалинг, приводим неуправляемую функцию к делегату
            NativeInvoker nativeInvoker = Marshal.GetDelegateForFunctionPointer(NativeFunction, typeof(NativeInvoker)) as NativeInvoker;
            //  Получаем значение экспортируемой функции, используя объект делегата
            string importedString = nativeInvoker();
 
            //  Освобождаем ресурсы
            API.FreeLibrary(hExe);
        }
получаю это:
C#
1
2
Ошибка    1   Параметр типа "NativeInvoker" не может использоваться с оператором  "as", так как он не имеет ни ограничения класса типа, ни ограничения "class"
Ошибка    2   "nativeInvoker" является "переменная", но используется как "метод"
а так:
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
        public static void NativeDLL(string fname, string pname, Type NativeInvoker)
        {
            //  Открываем DLL, получаем ее Handle
            IntPtr hExe = API.LoadLibrary(fname);
            //  Получаем адрес функции, экспортируемой DLL
            IntPtr NativeFunction = API.GetProcAddress(hExe, pname);
 
            //  Используя маршалинг, приводим неуправляемую функцию к делегату
            NativeInvoker nativeInvoker = Marshal.GetDelegateForFunctionPointer(NativeFunction, typeof(NativeInvoker)) as NativeInvoker;
            //  Получаем значение экспортируемой функции, используя объект делегата
            string importedString = nativeInvoker();
 
            //  Освобождаем ресурсы
            API.FreeLibrary(hExe);
        }
это:
C#
1
Ошибка    1   Не удалось найти имя типа или пространства имен "NativeInvoker" (пропущена директива using или ссылка на сборку?)
как же быть ???
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
11.12.2013, 18:54
Ответы с готовыми решениями:

Можно ли как-то "напрямую" передать обобщенный метод в делегат Func
Привет! Есть в Метод1 с параметром типа Func&lt;string, string, IEnumerable&lt;string&gt;&gt;: void MyMethod1(Func&lt;string, string,...

Можно ли унаследовать заранее неизвестный класс?
Всем привет! Помогите, пожалуйста разобраться с наследованием в C++. Я пока новичок, хочу написать нейронную сеть. Столкнулся с...

Как преобразовать объект в заранее неизвестный тип
Что то типо void method(Type T) { List &lt;T&gt; list = new List&lt;T&gt;(); } или

25
 Аватар для ITL
284 / 255 / 73
Регистрация: 17.07.2012
Сообщений: 618
11.12.2013, 19:08
Тяжело так сказать ,не видя кода.
Попробуйте так:
C#
1
2
3
NativeInvoker nativeInvoker = Marshal.GetDelegateForFunctionPointer(NativeFunction, typeof(NativeInvoker)) as NativeInvoker;
            //  Получаем значение экспортируемой функции, используя объект делегата
            string importedString = nativeInvoker.Invoke();
0
-19 / 1 / 2
Регистрация: 05.11.2012
Сообщений: 48
11.12.2013, 20:28  [ТС]
код тут - нужно в метод передать переменню типа делегат
в чем соль копипаста??

Добавлено через 29 минут
ITL, если ты незнаешь что ответить - не надо ничего писать, а так - это спам.

Добавлено через 27 минут
второе сообщение в теме - это спам
Цитата Сообщение от ITL Посмотреть сообщение
Тяжело так сказать
не несет смысловой нагрузки
Цитата Сообщение от ITL Посмотреть сообщение
не видя кода
а в первом сообщении тогда что??
Цитата Сообщение от ITL Посмотреть сообщение
Попробуйте так:
как я делал?
Вывод это спам, о чем я сообщил, вы просмотрев невнимательно тему единственное что исправили так это цитату, ну еще название темы (что не в счет), тема перемещена в раздел для начинающих (я уже не начинающий) да и решить этот вопрос чтото пока никто не может, вопрос Памирыч, вы профи?? = тогда попробйте решить проблему, а если нет то по каким признакам вы определили что это тема для начинающих?
0
438 / 362 / 100
Регистрация: 29.06.2010
Сообщений: 981
Записей в блоге: 1
11.12.2013, 20:41
Цитата Сообщение от finflaex Посмотреть сообщение
ITL, если ты незнаешь что ответить - не надо ничего писать, а так - это спам.
Уважаемый вы не правы. Не нравится ответ, проигнорируйте его. Это свободный форум и здесь никто не обязан отвечать. Человек ответил, не важно подошел вам ответ или нет. Вы пришли сюда и играйте по местным правилам.

Не по теме:


ITL, надо было определить значения переменных fname, pname, NativeInvoker, скачать сборку написать код и ответить.

0
-19 / 1 / 2
Регистрация: 05.11.2012
Сообщений: 48
11.12.2013, 20:42  [ТС]
расшифруйте пожалуйста в чем заключается суть его ответа
0
Почетный модератор
Эксперт .NET
 Аватар для NickoTin
8726 / 3678 / 404
Регистрация: 14.06.2010
Сообщений: 4,513
Записей в блоге: 9
11.12.2013, 20:47
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
        public static void NativeDLL<NativeInvoker>(string fname, string pname)
        {
            //  Открываем DLL, получаем ее Handle
            IntPtr hExe = API.LoadLibrary(fname);
            //  Получаем адрес функции, экспортируемой DLL
            IntPtr NativeFunction = API.GetProcAddress(hExe, pname);
 
            //  Используя маршалинг, приводим неуправляемую функцию к делегату
            var nativeInvoker = Marshal.GetDelegateForFunctionPointer(NativeFunction, typeof(NativeInvoker));
            //  Получаем значение экспортируемой функции, используя объект делегата
            var importedString = nativeInvoker.DynamicInvoke().ToString();
 
            //  Освобождаем ресурсы
            API.FreeLibrary(hExe);
        }
C#
1
2
3
private delegate IntPtr GetForegroundWindow();
 
NativeDLL<GetForegroundWindow>("user32.dll", "GetForegroundWindow");
Постоянная загрузка и выгрузка не есть гуд, используйте GetModeuleHandle, а только потом LoadLibrary если GetModuleHandle вернет 0, тогда и выгружать не придётся.

Проявите уважение к другим пользователям. Вам стараются помочь, а Вы их шлете лесом. С таким отношением Вам просто не захотят помогать, даже если знают ответ.
0
-19 / 1 / 2
Регистрация: 05.11.2012
Сообщений: 48
11.12.2013, 20:50  [ТС]
Цитата Сообщение от Grishaco Посмотреть сообщение
ITL, надо было определить значения переменных fname, pname, NativeInvoker, скачать сборку написать код и ответить.
Не по теме: значение этих переменных не имеет смысла, это могут быть любые переменные или их вообще может не быть, я просто выдернул с архива первый попавшийся код и на его примере продемонстрировал суть проблемы

Добавлено через 1 минуту
Цитата Сообщение от NickoTin Посмотреть сообщение
Постоянная загрузка и выгрузка не есть гуд
это пример где может возникнуть такая проблема, вопрос не в том как динамически загрузить или выгрузить, вопрос в том почему возникает ошибка
Цитата Сообщение от finflaex Посмотреть сообщение
Параметр типа "NativeInvoker" не может использоваться с оператором *"as"
и как ее обойти
0
438 / 362 / 100
Регистрация: 29.06.2010
Сообщений: 981
Записей в блоге: 1
11.12.2013, 20:52
Цитата Сообщение от finflaex Посмотреть сообщение
и как ее обойти
Добавьте к методу ограничение where NativeInvoker:class
0
11.12.2013, 20:52

Не по теме:

Цитата Сообщение от finflaex Посмотреть сообщение
а так - это спам
Спам (англ. spam) — рассылка коммерческой и иной рекламы или иных видов сообщений лицам, не выражавшим желания их получать.
Это реклама? Нет. Вы выражали желание получить помощь? Да:
Цитата Сообщение от finflaex Посмотреть сообщение
как же быть ???
Так что это не спам, в любом случае. Если вы так любите обвинить других людей в непрофессионализме - потрудитесь хотя бы узнать о том, в чем именно вы их обвиняете.

1
-19 / 1 / 2
Регистрация: 05.11.2012
Сообщений: 48
11.12.2013, 20:54  [ТС]
Цитата Сообщение от NickoTin Посмотреть сообщение
Вам стараются помочь, а Вы их шлете лесом
я не шлю никого лесом, прошу прощения если так может показаться со стороны, просто я помягче попытался донести до человека что он несет бред/спам
0
11.12.2013, 20:55

Не по теме:

Цитата Сообщение от finflaex Посмотреть сообщение
просто я помягче попытался донести до человека что он несет бред/спам
"Извините, вы не правы" куда мягче, нежели "ты спамер". Удачи в решении, не буду больше отвлекать по мелочам, извините за оффтоп.

0
-19 / 1 / 2
Регистрация: 05.11.2012
Сообщений: 48
11.12.2013, 21:01  [ТС]
Цитата Сообщение от KOPOJI Посмотреть сообщение
Это реклама? Нет.
Тогда это флуд. Прошу прощение за терминологию, не до того было.
Флуд (от неверно произносимого[1] англ. flood — наводнение, затопление) — сообщения в интернет-форумах и чатах, занимающие большие объемы и не несущие никакой полезной информации.

Добавлено через 1 минуту
Цитата Сообщение от KOPOJI Посмотреть сообщение
мягче
когда в голове негодование и куча эмоций - которые выражаются только матом и ничем кроме мата это "мягкая форма изложения"

Добавлено через 3 минуты
Цитата Сообщение от Grishaco Посмотреть сообщение
where NativeInvoker:class
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
        public static void NativeDLL<NativeInvoker>(string fname, string pname)
            where NativeInvoker: class
        {
            //  Открываем DLL, получаем ее Handle
            IntPtr hExe = API.LoadLibrary(fname);
            //  Получаем адрес функции, експортируемой DLL
            IntPtr NativeFunction = API.GetProcAddress(hExe, pname);
 
            //  Используя маршалинг, приводим неуправляемую функцию к делегату
            NativeInvoker nativeInvoker = Marshal.GetDelegateForFunctionPointer(NativeFunction, typeof(NativeInvoker)) as NativeInvoker;
            //  Получаем значение експортируемой функции, используя объект делегата
            string importedString = nativeInvoker();
 
            //  Освобождаем ресурсы
            API.FreeLibrary(hExe);
        }
C#
1
Ошибка    1   "nativeInvoker" является "переменная", но используется как "метод"
0
438 / 362 / 100
Регистрация: 29.06.2010
Сообщений: 981
Записей в блоге: 1
11.12.2013, 21:07
C#
1
2
//  Используя маршалинг, приводим неуправляемую функцию к делегату
NativeInvoker nativeInvoker = Marshal.GetDelegateForFunctionPointer(NativeFunction, typeof(NativeInvoker)) as NativeInvoker;
Это все равно, что написать

C#
1
2
3
4
5
6
7
8
9
10
11
12
public class A
{
}
 
public class B
{
public A Get()
{
A a = new A();
string text = a();
}
}
Вот у вас такая же проблема.
0
-19 / 1 / 2
Регистрация: 05.11.2012
Сообщений: 48
11.12.2013, 21:36  [ТС]
Цитата Сообщение от Grishaco Посмотреть сообщение
Это все равно, что написать
C#
1
2
3
4
5
6
7
public static void metod<delegat>()
            where delegat: Delegate
        {
            delegat _delegat = delegat(qwe);
        }
 
        public static int qwe() { return 0; }
C#
1
Ошибка    2   Элемент "delegat" не существует в текущем контексте
Это вам понятно?

Добавлено через 9 минут
ответ
Нет ниче не понятно, кода не видно, попробуйте написать так
Цитата Сообщение от finflaex Посмотреть сообщение
delegat _delegat = delegat(qwe);
Добавлено через 51 секунду
0
438 / 362 / 100
Регистрация: 29.06.2010
Сообщений: 981
Записей в блоге: 1
11.12.2013, 21:37
Цитата Сообщение от finflaex Посмотреть сообщение
Это вам понятно?
Это вы о чем вообще, как это вы пытаетесь тип генерика использовать как метод, этого в c# нет.

Вам уже ответили.

C#
1
2
3
4
NickoTin
var nativeInvoker = Marshal.GetDelegateForFunctionPointer(NativeFunction, typeof(NativeInvoker));
// *Получаем значение экспортируемой функции, используя объект делегата
var importedString = nativeInvoker.DynamicInvoke().ToString();

Не по теме:


Цитата Сообщение от finflaex Посмотреть сообщение
тема перемещена в раздел для начинающих (я уже не начинающий)
По моему вы поторопились с выводами.

0
-19 / 1 / 2
Регистрация: 05.11.2012
Сообщений: 48
11.12.2013, 21:44  [ТС]
Цитата Сообщение от Grishaco Посмотреть сообщение
генерика
это что?
суть в том что в длл сидит метод в который надо передать делегат(не объект а тип) и по нему работать дальше, забей уже на динамическую загрузку длл

Добавлено через 1 минуту
Цитата Сообщение от Grishaco Посмотреть сообщение
DynamicInvoke()
и чето я такого метода вообще и близко не наблюдаю, темболеe с var

Добавлено через 49 секунд
Цитата Сообщение от Grishaco Посмотреть сообщение
По моему вы поторопились с выводами.
может наоборот?
0
438 / 362 / 100
Регистрация: 29.06.2010
Сообщений: 981
Записей в блоге: 1
11.12.2013, 21:46
Цитата Сообщение от finflaex Посмотреть сообщение
и чето я такого метода вообще и близко не наблюдаю, темболеe с var
Вот еще один пример про метод DynamicInvoke

C#
1
2
Delegate delegateForFunctionPointer = Marshal.GetDelegateForFunctionPointer(new IntPtr(), typeof (decimal));
delegateForFunctionPointer.DynamicInvoke();
0
Почетный модератор
Эксперт HTML/CSSЭксперт PHP
 Аватар для KOPOJI
16844 / 6724 / 880
Регистрация: 12.06.2012
Сообщений: 19,967
11.12.2013, 21:46

Не по теме:

гг.. :popcorn:


Цитата Сообщение от finflaex Посмотреть сообщение
и чето я такого метода вообще и близко не наблюдаю
http://msdn.microsoft.com/ru-r... .110).aspx
Цитата Сообщение от finflaex Посмотреть сообщение
темболеe с var
А чем var-то не устраивает? Это же не ява..

Не по теме:

Цитата Сообщение от finflaex Посмотреть сообщение
может наоборот?
конечно, куда нам до вас.
З.Ы. с каждым подобным сообщением, прямо таки и чувствуется, как число желающих помочь стремится к нулю..

1
-19 / 1 / 2
Регистрация: 05.11.2012
Сообщений: 48
11.12.2013, 21:53  [ТС]
Цитата Сообщение от finflaex Посмотреть сообщение
public static void metod<delegat>()
* * * * * * where delegat: Delegate
* * * * {
* * * * * * delegat _delegat = delegat(qwe);
* * * * }
public static int qwe() { return 0; }

Ошибка* 2 * Элемент "delegat" не существует в текущем контексте
вот проблема
Цитата Сообщение от Grishaco Посмотреть сообщение
Вот еще один пример про метод DynamicInvoke
забей на загрузку длл, проблема не в этом, я на скорую руку мастырил лишь бы показать проблему
Цитата Сообщение от KOPOJI Посмотреть сообщение
А чем var-то не устраивает?
в редакторе ошибок больше выскочило (так то хз, не разбирался)

Добавлено через 3 минуты
Цитата Сообщение от Grishaco Посмотреть сообщение
nativeInvoker.DynamicInvoke().ToString()
врубился что ты хотел сказать, только
если использовать в потоках по обновлению фреймов с нескольких камер то объект конвертировать постоянно накладно получится
0
Почетный модератор
Эксперт .NET
 Аватар для NickoTin
8726 / 3678 / 404
Регистрация: 14.06.2010
Сообщений: 4,513
Записей в блоге: 9
11.12.2013, 22:03
Цитата Сообщение от finflaex Посмотреть сообщение
суть в том что в длл сидит метод в который надо передать делегат(не объект а тип) и по нему работать дальше, забей уже на динамическую загрузку длл
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
31
        private delegate void FuncToCallA ( );
        private delegate int FuncToCallB ( );
 
        private delegate string ToCall ( IntPtr delegateToCall );
 
        static void Main ( string[] args )
        {
            NativeDLL<FuncToCallA>( "TestDll.dll", "GetFuncA", ( ) => Console.WriteLine( "Test" ) );
            NativeDLL<FuncToCallB>( "TestDll.dll", "GetFuncB", qwe );
        }
 
        public static void NativeDLL<NativeInvoker> ( string fname, string pname, NativeInvoker delegateToCall )
        {
            //  Открываем DLL, получаем ее Handle
            IntPtr hExe = API.LoadLibrary( fname );
            //  Получаем адрес функции, экспортируемой DLL
            IntPtr NativeFunction = API.GetProcAddress( hExe, pname );
 
            //  Используя маршалинг, приводим неуправляемую функцию к делегату
            var nativeInvoker = Marshal.GetDelegateForFunctionPointer( NativeFunction, typeof( ToCall ) ) as ToCall;
            //  Получаем значение экспортируемой функции, используя объект делегата
            var importedString = nativeInvoker( Marshal.GetFunctionPointerForDelegate( delegateToCall as Delegate ) );
 
            //  Освобождаем ресурсы
            API.FreeLibrary( hExe );
        }
 
        public static int qwe ( )
        {
            return 1;
        }
C
1
2
3
4
5
6
7
8
9
10
11
12
13
EXPORT CHAR* STDCALL GetFuncA(
    _In_ DelegateA pFunc)
{
    pFunc();
    return "123";
}
 
EXPORT CHAR* STDCALL GetFuncB(
    _In_ DelegateB pFunc)
{
    DWORD a = pFunc();
    return "456";
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
11.12.2013, 22:03
Помогаю со студенческими работами здесь

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

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

Как передать MethodInfo, если нужен делегат
Сабж, у меня есть объект A типа MethodInfo с информацией о функции, которую надо вызывать. Теперь как мне передать А в другой метод,...

Как передать делегат в качестве параметра другому делегату?
Здравствуйте. Хочу написать код, который содержит три делегата: delegate double NormStress(int n, double a); ...

Сколько аргументов требуется передать в делегат в приведенном коде
Код написан на с++/CLR, но отличия от с# минимальны так что думаю всем код понятен. Почему этот код работает? public delegate void...


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

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
Новые блоги и статьи
Символьное дифференцирование
igorrr37 13.02.2026
/ * Программа принимает математическое выражение в виде строки и выдаёт его производную в виде строки и вычисляет значение производной при заданном х Логарифм записывается как: (x-2)log(x^2+2) -. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru