第二章 管理程序流(In .net4.5) 之 管理多线程

1. 概述

  本章包括同步资源以及取消长时间任务相关的内容。

2. 主要内容

  2.1 同步资源

    ① lock关键字实现。会阻塞程序,有可能会导致死锁。

    ② volatile关键字可以禁用编译优化,用于避免优化代码时对多线程的影响。

private static volatile int _flag = 0;

    ③ Interlocked关键字可以原子化一些简单数字运算和比较替换操作。

Interlocked.Increment(ref n); //
Interlocked.Decrement(ref n); //
Interlocked.Exchange(ref isInUse, 1);
Interlocked.CompareExchange(ref value, newValue, compareTo);

  2.2 取消任务

    ① CancellationToken

CancellationTokenSource cancellationTokenSource = 
    new CancellationTokenSource(); 
CancellationToken token = cancellationTokenSource.Token; 

Task task = Task.Run(() => 
{
    while(!token.IsCancellationRequested)
    {
        Console.Write("*");
        Thread.Sleep(1000);
    }
}, token);

Console.WriteLine("Please enter to stop the task");
Console.ReadLine();
cancellationTokenSource.Cancel();

    ② 使用Task.WaitAny()可以设置任务的超时时间。

Task longRunning = Task.Run(() =>
{
    Thread.Sleep(10000);
});

int index = Task.WaitAny(new[] {longRunning}, 1000);

if (index == -1)
    Console.WriteLine("Task time out ");

3. 总结

  ① 多线程环境访问共享数据时,要考虑避免数据的损坏和脏读。

  ② 使用lock关键字可以实现共享资源的多线程顺序访问。

  ③ 可以使用Interlocked实现简单的原子操作。

  ④ 可以使用CancellationTokenSource类的CancellationToken来控制取消任务。

posted @ 2015-03-18 16:27  stone lv  阅读(166)  评论(0编辑  收藏  举报