zoukankan      html  css  js  c++  java
  • 多线程同步、异步(BeginInvoke)

    一、线程的基础知识

    1 System.Threading.Thread类

    System.Threading.Thread是用于控制线程的基础类,通过Thread可以控制当前应用程序域中线程的创建、挂起、停止、销毁。

    它包括以下常用公共属性:

    属性名称说明
    CurrentContext 获取线程正在其中执行的当前上下文。
    CurrentThread 获取当前正在运行的线程。
    ExecutionContext 获取一个 ExecutionContext 对象,该对象包含有关当前线程的各种上下文的信息。
    IsAlive 获取一个值,该值指示当前线程的执行状态。
    IsBackground 获取或设置一个值,该值指示某个线程是否为后台线程。
    IsThreadPoolThread 获取一个值,该值指示线程是否属于托管线程池。
    ManagedThreadId 获取当前托管线程的唯一标识符。
    Name 获取或设置线程的名称。
    Priority 获取或设置一个值,该值指示线程的调度优先级。
    ThreadState 获取一个值,该值包含当前线程的状态。

     

    2 线程的标识符

    ManagedThreadId是确认线程的唯一标识符,程序在大部分情况下都是通过Thread.ManagedThreadId来辨别线程的。而Name是一个可变值,在默认时候,Name为一个空值 Null,开发人员可以通过程序设置线程的名称,但这只是一个辅助功能。

     

    3 线程的优先级别

    .NET为线程设置了Priority属性来定义线程执行的优先级别,里面包含5个选项,其中Normal是默认值。除非系统有特殊要求,否则不应该随便设置线程的优先级别。

    成员名称说明
    Lowest 可以将 Thread 安排在具有任何其他优先级的线程之后。
    BelowNormal 可以将 Thread 安排在具有 Normal 优先级的线程之后,在具有 Lowest 优先级的线程之前。
    Normal 默认选择。可以将 Thread 安排在具有 AboveNormal 优先级的线程之后,在具有 BelowNormal优先级的线程之前
    AboveNormal 可以将 Thread 安排在具有 Highest 优先级的线程之后,在具有 Normal 优先级的线程之前。
    Highest 可以将 Thread 安排在具有任何其他优先级的线程之前。

     

    4 线程的状态

    通过ThreadState可以检测线程是处于Unstarted、Sleeping、Running 等等状态,它比 IsAlive 属性能提供更多的特定信息。

    前面说过,一个应用程序域中可能包括多个上下文,而通过CurrentContext可以获取线程当前的上下文。

    CurrentThread是最常用的一个属性,它是用于获取当前运行的线程。

     

    5 System.Threading.Thread的方法

    Thread 中包括了多个方法来控制线程的创建、挂起、停止、销毁,以后来的例子中会经常使用。

    方法名称说明
    Abort()     终止本线程。
    GetDomain() 返回当前线程正在其中运行的当前域。
    GetDomainId() 返回当前线程正在其中运行的当前域Id。
    Interrupt() 中断处于 WaitSleepJoin 线程状态的线程。
    Join() 已重载。 阻塞调用线程,直到某个线程终止时为止。
    Resume() 继续运行已挂起的线程。
    Start()   执行本线程。
    Suspend() 挂起当前线程,如果当前线程已属于挂起状态则此不起作用
    Sleep()   把正在运行的线程挂起一段时间。

    6 使用BeginInvoke异步例子

    privatedelegatevoid myDelegate(DataSet searchDs);//声明一个委托
    protected DataSet SearchDataSet = null;

    //主线程
    this.Cursor = Cursors.WaitCursor; caml = GetCaml(); xc = new Thread(search); xc.IsBackground = true; xc.Start(); private void search()//新线程调用的方法 { myDelegate d = new myDelegate(ruturnValue); SearchDataSet = OperatePort.SearchDataList(listName, caml, null);//新线程有返回值 this.BeginInvoke(d, SearchDataSet);//在创建控件的基础句柄所在线程上异步执行指定委托,并将委托的传的方法的参数传给这个异步操作 } private void ruturnValue(DataSet searchDs)//委托调用的方法,将返回的ds交给SearchDataSet { SearchDataSet = searchDs; if (SearchDataSet == null) { BaseDgv.DataSource = null; } else { //sh.Message(SearchDataSet.Tables[0].Rows.Count.ToString()); DgvHelper.BandingDgvShowColumn("本地数据", listName, BaseDgv, true); Common.ForbidSortColumn(BaseDgv); BaseDgv.DataSource = SearchDataSet.Tables[0]; } if (xc.IsAlive)//关闭这个进程 { xc.Abort(); } }
  • 相关阅读:
    软工实践个人总结
    第03组 每周小结 (3/3)
    第03组 每周小结 (2/3)
    第03组 Beta冲刺 总结
    第03组 Beta冲刺 (5/5)
    第03组 Beta冲刺 (4/5)
    第03组 Beta冲刺 (3/5)
    第03组 Beta冲刺 (2/5)
    第03组 Beta冲刺 (1/5)
    Alpha冲刺 总结
  • 原文地址:https://www.cnblogs.com/hongmaju/p/4270025.html
Copyright © 2011-2022 走看看