并发学习之:Synchronization进行粗粒度线程同步的例子

一个使用Synchronization进行粗粒度线程同步的例子。(注意,Synchronization特性和ContextBoundObject必须同时使用,否则无效)

这个例子很简单,2个Task对象,分别调用兽族农民的WorkWork和GugiGugi方法。GugiGugi内部有着3秒的停顿,用来观察输出结果。运行之后,很明显的可以看到,在某一个线程执行GugiGugi的时候,另一个线程在等待。


using System;
using System.Runtime.Remoting.Contexts;
using System.Threading;
using System.Threading.Tasks;

namespace SyncContextTest
{
    [Synchronization()]
    class Orc : ContextBoundObject
    {
        public void WorkWork()
        {
            Console.WriteLine(DateTime.Now + " WorkWork - ThreadId: " + Thread.CurrentThread.ManagedThreadId);
        }

        public void GugiGugi()
        {
            Task.Delay(3000).Wait();
            Console.WriteLine(DateTime.Now + " GugiGugi - ThreadId: " + Thread.CurrentThread.ManagedThreadId);
        }
    }

    class Program
    {
        static void Main(string[] args)
        {
            Orc sharedOrc = new Orc();

            Task task1 = Task.Factory.StartNew(() =>
            {
                for (int i = 0; i < 10; ++i)
                {
                    sharedOrc.WorkWork();
                }
            });

            Task task2 = Task.Factory.StartNew(() =>
            {
                for (int i = 0; i < 10; ++i)
                {
                    sharedOrc.GugiGugi();
                }
            });

            Task.WaitAll(task1, task2);
        }
    }
}


输出:

1/5/2013 5:02:04 PM GugiGugi - ThreadId: 5
1/5/2013 5:02:04 PM WorkWork - ThreadId: 4
1/5/2013 5:02:07 PM GugiGugi - ThreadId: 5
1/5/2013 5:02:07 PM WorkWork - ThreadId: 4
1/5/2013 5:02:10 PM GugiGugi - ThreadId: 5
1/5/2013 5:02:10 PM WorkWork - ThreadId: 4
1/5/2013 5:02:13 PM GugiGugi - ThreadId: 5
1/5/2013 5:02:13 PM WorkWork - ThreadId: 4
1/5/2013 5:02:16 PM GugiGugi - ThreadId: 5
1/5/2013 5:02:16 PM WorkWork - ThreadId: 4
1/5/2013 5:02:19 PM GugiGugi - ThreadId: 5
1/5/2013 5:02:19 PM WorkWork - ThreadId: 4
1/5/2013 5:02:22 PM GugiGugi - ThreadId: 5
1/5/2013 5:02:22 PM WorkWork - ThreadId: 4
1/5/2013 5:02:25 PM GugiGugi - ThreadId: 5
1/5/2013 5:02:25 PM WorkWork - ThreadId: 4
1/5/2013 5:02:28 PM GugiGugi - ThreadId: 5
1/5/2013 5:02:28 PM WorkWork - ThreadId: 4
1/5/2013 5:02:31 PM GugiGugi - ThreadId: 5
1/5/2013 5:02:31 PM WorkWork - ThreadId: 4
Press any key to continue . . .


转载于:https://www.cnblogs.com/puncha/archive/2013/01/05/3876949.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值