Как отправлять события в C#
Я хочу создать собственные события и отправить их. Я никогда не делал этого раньше в C#, только в Flex.. Наверное, есть много различий.
может ли кто - нибудь привести мне хороший пример?
4 ответов
существует шаблон, который используется во всех классах библиотеки. Рекомендуется также для ваших собственных классов, особенно для кода фреймворка / библиотеки. Но никто не остановит вас, когда вы отклонитесь или пропустите несколько шагов.
вот схема, основанная на простейшем событии-делегате,System.Eventhandler
.
// The delegate type. This one is already defined in the library, in the System namespace
// the `void (object, EventArgs)` signature is also the recommended pattern
public delegate void Eventhandler(object sender, Eventargs args);
// your publishing class
class Foo
{
public event EventHandler Changed; // the Event
protected virtual void OnChanged() // the Trigger method, called to raise the event
{
// make a copy to be more thread-safe
EventHandler handler = Changed;
if (handler != null)
{
// invoke the subscribed event-handler(s)
handler(this, EventArgs.Empty);
}
}
// an example of raising the event
void SomeMethod()
{
if (...) // on some condition
OnChanged(); // raise the event
}
}
как использовать:
// your subscribing class
class Bar
{
public Bar()
{
Foo f = new Foo();
f.Changed += Foo_Changed; // Subscribe, using the short notation
}
// the handler must conform to the signature
void Foo_Changed(object sender, EventArgs args) // the Handler (reacts)
{
// the things Bar has to do when Foo changes
}
}
и когда у вас есть информация для передачи:
class MyEventArgs : EventArgs // guideline: derive from EventArgs
{
public string Info { get; set; }
}
class Foo
{
public event EventHandler<MyEventArgs> Changed; // the Event
...
protected virtual void OnChanged(string info) // the Trigger
{
EventHandler handler = Changed; // make a copy to be more thread-safe
if (handler != null)
{
var args = new MyEventArgs(){Info = info}; // this part will vary
handler(this, args);
}
}
}
class Bar
{
void Foo_Changed(object sender, MyEventArgs args) // the Handler
{
string s = args.Info;
...
}
}
обновление
начиная с C# 6 вызывающий код в методе 'Trigger' стал намного проще, тест null можно сократить с помощью оператора null-conditional ?.
без делать экземпляр пока держащ поток-безопасность:
protected virtual void OnChanged(string info) // the Trigger
{
var args = new MyEventArgs{Info = info}; // this part will vary
Changed?.Invoke(this, args);
}
события в C# используют делегаты.
public static event EventHandler<EventArgs> myEvent;
static void Main()
{
//add method to be called
myEvent += Handler;
//call all methods that have been added to the event
myEvent(this, EventArgs.Empty);
}
static void Handler(object sender, EventArgs args)
{
Console.WriteLine("Event Handled!");
}
используя типичный шаблон событий .NET и предполагая, что вам не нужны никакие специальные аргументы в вашем событии. Ваш типичный шаблон событий и отправки выглядит следующим образом.
public class MyClassWithEvents
{
public event EventHandler MyEvent;
protected void OnMyEvent(object sender, EventArgs eventArgs)
{
if (MyEvent != null)
{
MyEvent(sender, eventArgs);
}
}
public void TriggerMyEvent()
{
OnMyEvent(sender, eventArgs);
}
}
привязать что-то к событию может быть так же просто, как:
public class Program
{
public static void Main(string[] args)
{
MyClassWithEvents obj = new MyClassWithEvents();
obj.MyEvent += obj_myEvent;
}
private static void obj_myEvent(object sender, EventArgs e)
{
//Code called when my event is dispatched.
}
}
взгляните на ссылки эта страница MSDN
посмотреть в "делегатов".
- определить делегата
- используйте тип делегата как поле / свойство (добавление ключевого слова "Event")
- теперь вы подвергаете события, которые пользователи могут подключить с помощью " + = MyEventMethod;"
надеюсь, это поможет,