zoukankan      html  css  js  c++  java
  • Using Dispatcher

    he following code example shows how you might attempt to update the UI from your task logic.

    // The Wrong Way to Update a UI Object
    public void btnGetTime_Click(object sender, RoutedEventArgs e)
    {
       Task.Run(() => 
          {
             string currentTime = DateTime.Now.ToLongTimeString();
             SetTime(currentTime);
          }
    }
    private void SetTime(string time)
    {
       lblTime.Content = time;
    }

    If you were to run the preceding code, you would get an InvalidOperationException exception with the message ”The calling thread cannot access this object because a different thread owns it.” This is because the SetTime method is running on a background thread, but the lblTime label was created by the UI thread. To update the contents of the lblTime label, you must run the SetTime method on the UI thread.

    To do this, you can retrieve the Dispatcher object that is associated with the lblTime object and then call the Dispatcher.BeginInvoke method to invoke the SetTime method on the UI thread.

    The following code example shows how to use the Dispatcher.BeginInvoke method to update a control on the UI thread.

    // The Correct Way to Update a UI Object
    public void buttonGetTime_Click(object sender, RoutedEventArgs e)
    {
       Task.Run(() => 
          {
             string currentTime = DateTime.Now.ToLongTimeString();
             lblTime.Dispatcher.BeginInvoke(new Action(() => SetTime(currentTime)));
          }
    }
    private void SetTime(string time)
    {
       lblTime.Content = time;
    }

    Note that the BeginInvoke method will not accept an anonymous delegate. The previous example uses the Action delegate to invoke the SetTime method. However, you can use any delegate that matches the signature of the method you want to call.

  • 相关阅读:
    chown
    [NOI2010]航空管制
    批量kill 某个用户session
    【BZOJ2395】【Balkan 2011】Timeismoney 最小乘积生成树
    找出 alter system kill session ‘sid,serial#’ kill 掉的数据库会话对应进程
    [NOI2016]优秀的拆分
    Oracle12C查询自建用户(非系统自带)
    查询包含某个字段的表
    [WC2011]最大XOR和路径
    监控慢SQL
  • 原文地址:https://www.cnblogs.com/qixue/p/7365772.html
Copyright © 2011-2022 走看看