В C # есть делегаты для этой цели. Они активно используются с событиями , поскольку событие может автоматически вызывать ряд присоединенных делегатов (обработчиков событий).
на самом деле обратный вызов - это указатель на исполняемый код, который передается в качестве аргумента другому коду ... страница нуждается в проверке
Джанлука Геттини
8
@G_G: Ничто не говорит, что это должен быть указатель. Обычно это происходит потому, что сегмент данных не является исполняемым, но технически это деталь реализации.
Joey
Джои: Вы правы, это деталь реализации, но даже обратный вызов - деталь реализации. Вы можете переписать свой код без единого обратного вызова. Это как «пока» против «для».
Джанлука Геттини
1077
Я только что познакомился с тобой,
и это безумие,
Но вот мой номер (делегат),
так что если что-то случится (событие),
позвони мне, может быть (обратный звонок)?
Совершенно классное объяснение. Я буду использовать это объяснение всякий раз, когда кто-нибудь спросит, надеюсь, я смогу получить права на его использование?
Никола Давидович
15
+1: люблю это. Песня портится, но здесь должно быть написано: «Но вот мой номер и инструкции по использованию определенного типа телефона (делегат)»
Gone Coding
9
Учись делегат с улыбкой на лице :-)
Аакаш
9
Лучшее объяснение!
zhengtonic
3
Обратите внимание, что обучение делегата другим людям с таким объяснением работает только с хорошей хореографией :)
Себастьен Севрин,
88
Обратный вызов - это функция, которая будет вызываться, когда процесс завершит выполнение определенной задачи.
Использование обратного вызова обычно происходит в асинхронной логике.
Чтобы создать обратный вызов в C #, вам нужно сохранить адрес функции внутри переменной. Это достигается с помощью delegateновой лямбда-семантики Funcor Action.
publicdelegatevoidWorkCompletedCallBack(string result);
publicvoidDoWork(WorkCompletedCallBack callback)
{
callback("Hello world");
}
publicvoidTest()
{
WorkCompletedCallBack callback = TestCallBack; // Notice that I am referencing a method without its parameter
DoWork(callback);
}
publicvoidTestCallBack(string result)
{
Console.WriteLine(result);
}
В сегодняшнем C # это можно сделать с помощью лямбда, например:
Обратный вызов исполняемый код , который передается в качестве аргумента другого кода.
Реализация
// Parent can ReadpublicclassParent
{
publicstringRead(){ /*reads here*/ };
}
// Child need InfopublicclassChild
{
privatestring information;
// declare a DelegatedelegatestringGetInfo();
// use an instance of the declared Delegatepublic GetInfo GetMeInformation;
publicvoidObtainInfo()
{
// Child will use the Parent capabilities via the Delegate
information = GetMeInformation();
}
}
Применение
Parent Peter = new Parent();
Child Johny = new Child();
// Tell Johny from where to obtain info
Johny.GetMeInformation = Peter.Read;
Johny.ObtainInfo(); // here Johny 'asks' Peter to read
привет @serhio, спасибо за ответ. мне все еще немного неясно: где именно код передается в качестве аргумента другому коду. Кажется, это добавление метода Peter.Read к дочернему делегату?
BKSpurgeon
1
@serhio ссылка мертва.
Джуд
10
Обратный вызов - это указатель на функцию, который вы передаете другой функции. Функция, которую вы вызываете, по завершении выполнит обратный вызов (выполнит) другую функцию.
Обратный вызов может быть реализован как делегат метода, но вы также можете сказать, что передача объекта, который поддерживает метод обратного вызова в его интерфейсе, является обратным вызовом.
Джо
Array.Sort (arrayObject); вызов obj.CompareTo (anotherObj) для элементов arrayObject является классическим примером обратного вызова с использованием интерфейса (ICompareable) в .Net.
Ron5504
8
Если вы имеете в виду обратные вызовы ASP.Net:
В модели по умолчанию для веб-страниц ASP.NET пользователь взаимодействует со страницей и нажимает кнопку или выполняет какое-либо другое действие, которое приводит к обратной передаче. Страница и ее элементы управления воссоздаются, код страницы выполняется на сервере, а новая версия страницы отображается в браузере. Однако в некоторых ситуациях полезно запускать код сервера от клиента без выполнения обратной передачи. Если клиентский сценарий на странице поддерживает некоторую информацию о состоянии (например, значения локальных переменных), публикация страницы и получение ее новой копии разрушает это состояние. Кроме того, обратная передача страниц приводит к накладным расходам на обработку, которые могут снизить производительность и вынудить пользователя ждать, пока страница будет обработана и воссоздана.
Чтобы избежать потери состояния клиента и не вызывать накладных расходов на обработку, связанных с обходом сервера, вы можете закодировать веб-страницу ASP.NET, чтобы она могла выполнять обратные вызовы клиента. В обратном вызове клиента функция клиентского сценария отправляет запрос на веб-страницу ASP.NET. Веб-страница выполняет измененную версию своего обычного жизненного цикла. Страница инициируется, создаются ее элементы управления и другие элементы, а затем вызывается специально отмеченный метод. Метод выполняет закодированную вами обработку и затем возвращает браузеру значение, которое может быть прочитано другой функцией клиентского скрипта. На протяжении всего этого процесса страница отображается в браузере.
Обратные вызовы часто являются делегатами методов, которые вызываются, когда конкретная операция завершена или выполняет под-действие. Вы часто найдете их в асинхронных операциях. Это принцип программирования, который можно найти почти во всех языках программирования.
classCallBackExample
{
publicdelegatevoidMyNumber();
publicstaticvoidCallMeBack()
{
Console.WriteLine("He/She is calling you. Pick your phone!:)");
Console.Read();
}
publicstaticvoidMetYourCrush(MyNumber number)
{
int j;
Console.WriteLine("is she/he interested 0/1?:");
var i = Console.ReadLine();
if (int.TryParse(i, out j))
{
var interested = (j == 0) ? false : true;
if (interested)//event
{
//call his/her number
number();
}
else
{
Console.WriteLine("Nothing happened! :(");
Console.Read();
}
}
}
staticvoidMain(string[] args)
{
MyNumber number = Program.CallMeBack;
Console.WriteLine("You have just met your crush and given your number");
MetYourCrush(number);
Console.Read();
Console.Read();
}
}
Пояснение кода:
Я создал код для реализации забавного объяснения, предоставленного LightStriker в одном из ответов выше. Мы передаем делегат (число) методу ( MetYourCrush). Если интересующее (событие) происходит в методе ( MetYourCrush), тогда он вызовет делегат (номер), который содержал ссылку на CallMeBackметод. Итак, CallMeBackметод будет вызван. По сути, мы передаем делегат для вызова метода обратного вызова.
Пожалуйста, дай мне знать, если возникнут какие-либо вопросы.
Это не дает адекватного ответа на вопрос, не могли бы вы объяснить, что делает ваш код, описать, как работает обратный вызов, и как он реализован в C #.
Адам
Привет, Адам, спасибо за ответ. Я создал код для реализации забавного объяснения, предоставленного LightStriker. Мы передаем делегат (номер) методу (MetYourCrush). Если интересующее (событие) происходит в методе (MetYourCrush), тогда он вызовет делегат (номер), который содержал ссылку на метод CallMeBack. Итак, будет вызван метод CallMeBack. По сути, мы передаем делегат для вызова метода обратного вызова. Пожалуйста, дай мне знать, если возникнут какие-либо вопросы.
Мани
1
Вероятно, это не определение словаря, но обратный вызов обычно относится к функции, которая является внешней по отношению к определенному объекту, которая сохраняется и затем вызывается при определенном событии.
Примером может служить создание кнопки пользовательского интерфейса, в которой хранится ссылка на функцию, выполняющую действие. Действие обрабатывается другой частью кода, но при нажатии кнопки вызывается обратный вызов, который вызывает действие для выполнения.
В C # вместо термина «обратный вызов» используются «события» и «делегаты», и вы можете узнать больше о делегатах здесь .
Обратный вызов позволяет передавать исполняемый код в качестве аргумента другому коду. В C и C ++ это реализовано как указатель на функцию. В .NET вы должны использовать делегата для управления указателями функций.
Несколько применений включают сигнализацию об ошибках и контроль за тем, действует функция или нет.
1) из пользовательского интерфейса вызова Onclient щелкните функцию javascript для EX: - builpopup(p1,p2,p3...)
var finalfield = p1, p2, p3;
UseCallBack(finalfield, ""); данные от клиента передаются на сервер с помощью UseCallBack
2) public void RaiseCallbackEvent(string eventArgument) В eventArgument мы получаем переданные данные // выполняем некоторую операцию на стороне сервера и передаем в callbackResult
3) GetCallbackResult() // с помощью этого метода данные будут переданы на сторону клиента (функция ReceiveServerData ())
callbackResult
4) Получить данные на стороне клиента:
ReceiveServerData(text) в текстовом ответе сервера мы получим.
Делегаты делают то же самое, что и обратные вызовы на основе интерфейса в C ++ (их использует COM), хотя их гораздо проще использовать.
Обратите внимание, что Microsoft поместила делегатов в свою реализацию Java (J ++), но Sun они не нравятся [java.sun.com], поэтому не ожидайте увидеть их в официальной версии Java в ближайшее время. Я собрал препроцессор, чтобы вы могли использовать их на C ++, поэтому не чувствуйте себя обделенным, если вы не программируете на C # или на платформе .NET (например, на Managed C ++ или Visual Basic.NET).
Если вы привыкли к указателям на функции в C, делегат - это, по сути, пара указателей, объединенных в один:
Указатель на объект (необязательно)
Указатель на метод этого объекта
Это означает, что один делегат передает всю информацию, необходимую для поиска функции в вашей программе, будь то статический метод или связанный с объектом.
Вы определяете их так в C #:
publicdelegatevoidFooCallbackType(int a, int b, int c );
Когда вы хотите их использовать, вы делаете делегатом функцию, которую хотите вызвать:
classCMyClass
{
publicvoidFunctionToCall(int a, int b, int c )
{
// This is the callback
}
publicvoidFoo()
{
FooCallbackType myDelegate = new FooCallbackType(
this.FunctionToCall );
// Now you can pass that to the function// that needs to call you back.
}
}
Если вы хотите, чтобы делегат указывал на статический метод, он выглядит так же:
classCMyClassWithStaticCallback
{
publicstaticvoidStaticFunctionToCall(int a, int b, int c )
{
// This is the callback
}
publicstaticvoidFoo()
{
FooCallbackType myDelegate = new FooCallbackType(
CMyClass.StaticFunctionToCall );
}
}
В целом, они делают то же самое, что и обратные вызовы на основе интерфейса в C ++, но вызывают немного меньше проблем, потому что вам не нужно беспокоиться об именах ваших функций или создании вспомогательных объектов, и вы можете делать делегатов из любого метода. Они более гибкие.
Ответы:
В C # есть делегаты для этой цели. Они активно используются с событиями , поскольку событие может автоматически вызывать ряд присоединенных делегатов (обработчиков событий).
источник
Я только что познакомился с тобой,
и это безумие,
Но вот мой номер (делегат),
так что если что-то случится (событие),
позвони мне, может быть (обратный звонок)?
источник
Обратный вызов - это функция, которая будет вызываться, когда процесс завершит выполнение определенной задачи.
Использование обратного вызова обычно происходит в асинхронной логике.
Чтобы создать обратный вызов в C #, вам нужно сохранить адрес функции внутри переменной. Это достигается с помощью
delegate
новой лямбда-семантикиFunc
orAction
.public delegate void WorkCompletedCallBack(string result); public void DoWork(WorkCompletedCallBack callback) { callback("Hello world"); } public void Test() { WorkCompletedCallBack callback = TestCallBack; // Notice that I am referencing a method without its parameter DoWork(callback); } public void TestCallBack(string result) { Console.WriteLine(result); }
В сегодняшнем C # это можно сделать с помощью лямбда, например:
public void DoWork(Action<string> callback) { callback("Hello world"); } public void Test() { DoWork((result) => Console.WriteLine(result)); }
источник
Определение
Реализация
// Parent can Read public class Parent { public string Read(){ /*reads here*/ }; } // Child need Info public class Child { private string information; // declare a Delegate delegate string GetInfo(); // use an instance of the declared Delegate public GetInfo GetMeInformation; public void ObtainInfo() { // Child will use the Parent capabilities via the Delegate information = GetMeInformation(); } }
Применение
Parent Peter = new Parent(); Child Johny = new Child(); // Tell Johny from where to obtain info Johny.GetMeInformation = Peter.Read; Johny.ObtainInfo(); // here Johny 'asks' Peter to read
Ссылки
источник
Обратный вызов - это указатель на функцию, который вы передаете другой функции. Функция, которую вы вызываете, по завершении выполнит обратный вызов (выполнит) другую функцию.
Ознакомьтесь с этой ссылкой.
источник
Если вы имеете в виду обратные вызовы ASP.Net:
Источник: http://msdn.microsoft.com/en-us/library/ms178208.aspx
Если вы имеете в виду обратные вызовы в коде:
Обратные вызовы часто являются делегатами методов, которые вызываются, когда конкретная операция завершена или выполняет под-действие. Вы часто найдете их в асинхронных операциях. Это принцип программирования, который можно найти почти во всех языках программирования.
Больше информации здесь: http://msdn.microsoft.com/en-us/library/ms173172.aspx
источник
Посвящение LightStriker:
Пример кода:
class CallBackExample { public delegate void MyNumber(); public static void CallMeBack() { Console.WriteLine("He/She is calling you. Pick your phone!:)"); Console.Read(); } public static void MetYourCrush(MyNumber number) { int j; Console.WriteLine("is she/he interested 0/1?:"); var i = Console.ReadLine(); if (int.TryParse(i, out j)) { var interested = (j == 0) ? false : true; if (interested)//event { //call his/her number number(); } else { Console.WriteLine("Nothing happened! :("); Console.Read(); } } } static void Main(string[] args) { MyNumber number = Program.CallMeBack; Console.WriteLine("You have just met your crush and given your number"); MetYourCrush(number); Console.Read(); Console.Read(); } }
Пояснение кода:
Я создал код для реализации забавного объяснения, предоставленного LightStriker в одном из ответов выше. Мы передаем делегат (число) методу (
MetYourCrush
). Если интересующее (событие) происходит в методе (MetYourCrush
), тогда он вызовет делегат (номер), который содержал ссылку наCallMeBack
метод. Итак,CallMeBack
метод будет вызван. По сути, мы передаем делегат для вызова метода обратного вызова.Пожалуйста, дай мне знать, если возникнут какие-либо вопросы.
источник
Вероятно, это не определение словаря, но обратный вызов обычно относится к функции, которая является внешней по отношению к определенному объекту, которая сохраняется и затем вызывается при определенном событии.
Примером может служить создание кнопки пользовательского интерфейса, в которой хранится ссылка на функцию, выполняющую действие. Действие обрабатывается другой частью кода, но при нажатии кнопки вызывается обратный вызов, который вызывает действие для выполнения.
В C # вместо термина «обратный вызов» используются «события» и «делегаты», и вы можете узнать больше о делегатах здесь .
источник
Обратный вызов позволяет передавать исполняемый код в качестве аргумента другому коду. В C и C ++ это реализовано как указатель на функцию. В .NET вы должны использовать делегата для управления указателями функций.
Несколько применений включают сигнализацию об ошибках и контроль за тем, действует функция или нет.
Википедия
источник
шаги работы обратного вызова:
1) нам нужно реализовать
ICallbackEventHandler
интерфейс2) Зарегистрируйте клиентский скрипт:
String cbReference = Page.ClientScript.GetCallbackEventReference(this, "arg", "ReceiveServerData", "context"); String callbackScript = "function UseCallBack(arg, context)" + "{ " + cbReference + ";}"; Page.ClientScript.RegisterClientScriptBlock(this.GetType(), "UseCallBack", callbackScript, true);
1) из пользовательского интерфейса вызова Onclient щелкните функцию javascript для EX: -
builpopup(p1,p2,p3...)
var finalfield = p1, p2, p3;
UseCallBack(finalfield, "");
данные от клиента передаются на сервер с помощью UseCallBack2)
public void RaiseCallbackEvent(string eventArgument)
В eventArgument мы получаем переданные данные // выполняем некоторую операцию на стороне сервера и передаем в callbackResult3)
GetCallbackResult()
// с помощью этого метода данные будут переданы на сторону клиента (функция ReceiveServerData ())callbackResult
4) Получить данные на стороне клиента:
ReceiveServerData(text)
в текстовом ответе сервера мы получим.источник
Делегаты делают то же самое, что и обратные вызовы на основе интерфейса в C ++ (их использует COM), хотя их гораздо проще использовать.
Обратите внимание, что Microsoft поместила делегатов в свою реализацию Java (J ++), но Sun они не нравятся [java.sun.com], поэтому не ожидайте увидеть их в официальной версии Java в ближайшее время. Я собрал препроцессор, чтобы вы могли использовать их на C ++, поэтому не чувствуйте себя обделенным, если вы не программируете на C # или на платформе .NET (например, на Managed C ++ или Visual Basic.NET).
Если вы привыкли к указателям на функции в C, делегат - это, по сути, пара указателей, объединенных в один:
Это означает, что один делегат передает всю информацию, необходимую для поиска функции в вашей программе, будь то статический метод или связанный с объектом.
Вы определяете их так в C #:
public delegate void FooCallbackType( int a, int b, int c );
Когда вы хотите их использовать, вы делаете делегатом функцию, которую хотите вызвать:
class CMyClass { public void FunctionToCall( int a, int b, int c ) { // This is the callback } public void Foo() { FooCallbackType myDelegate = new FooCallbackType( this.FunctionToCall ); // Now you can pass that to the function // that needs to call you back. } }
Если вы хотите, чтобы делегат указывал на статический метод, он выглядит так же:
class CMyClassWithStaticCallback { public static void StaticFunctionToCall( int a, int b, int c ) { // This is the callback } public static void Foo() { FooCallbackType myDelegate = new FooCallbackType( CMyClass.StaticFunctionToCall ); } }
В целом, они делают то же самое, что и обратные вызовы на основе интерфейса в C ++, но вызывают немного меньше проблем, потому что вам не нужно беспокоиться об именах ваших функций или создании вспомогательных объектов, и вы можете делать делегатов из любого метода. Они более гибкие.
источник