VSTO C# 多线程处理

最近在做一个插件,为了提升速度,首先想到的是借助多线程的力量。

却在实施的过程中,遇到重重困难,记录下这半个月的糟心经历。

需求中,有需要等待所有子线程跑完之后,继续主线程的环节,分享两种写法

1、使用Task

using System.Threading.Tasks;

List<Task<你任务的返回值>> taskList = new List<Task<你任务的返回值>>();
for(int i=0;i<线程数;i++){
    子任务参数 param=new 子任务参数();
    Task<你任务的返回值> addOne=Task.Factory.StartNew(()=>{
        return myTask(param);
    });
    taskList.Add(addOne);
}
Task.WaitAll(taskList.ToArray());
           

很好理解,构造一个List,存一下生成的任务,然后等待所有子任务完成。

如何获取子任务的返回值?

for(int i=0;i<taskList.count;i++){
    你任务的返回值 res=taskList[i].Result;
}

 从我们之前存的Task对象的Result属性,就可以拿到子线程的返回值了。

我用这种写法进行多线程读取不同的Excel工作簿,线程在10以内还可以,但是线程数多了,还是会不稳定。

 2、使用哨兵

using System.Threading;

AutoResetEvent[] writeWatchers = new AutoResetEvent[任务数];
for(int i=0;i<任务数;i++){
    writeWatchers[i] = new AutoResetEvent(false);
}

for(int i=0;i<任务数;i++){
   子任务参数 param=new  子任务参数();
    //将哨兵用参数的形式传进去,在子任务里完成后,关闭哨兵
   param.flag=writeWatchers[i];
    Thread addOne = new Thread(() =>{
        myTask(param);
    });
    addOne.SetApartmentState(ApartmentState.STA);
    addOne.Start();
}

for(int i=0;i<任务数;i++){
    writeWatchers[i].WaitOne();
}

重点就是需要把哨兵传到子任务里,让子任务关闭。并且这个属性一定要设置ApartmentState.STA,不然会报错

public void myTask(子任务参数 param){
    try{

    } finally{
        param.flag.Set();
    }

}

一定要在子任务关闭,不然就要一直等了。

AutoResetEvent.WaitAll(writeWatchers)

别用WaitAll写,不支持STA线程上多个句柄的WaitAll,会爆这个错误。

究其原因,在Excel里创建出来的线程,是STA属性的。

这上面多下线程读不同的工作簿可以,但是多线程写同一个工作簿不可以。

其他信息: 被呼叫方拒绝接收呼叫。

会报这个错误。

想想Excel只有一个主UI线程,也是可以理解的。

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
VSTO开发者指南》是为有兴趣把技能迁移到下一代Office开发的VBA开发者写的。你可以得到编写Word 2003、Excel 2003和Outlook 2003托管代码程序的易懂且实用的介绍,还将学到如何用VSTO 2005 SE为最受欢迎的Office 2003和Microsoft Office 2007应用程序创建插件。作为这方面的专家,作者通过丰富的代码示例来展示受欢迎的VSTO功能,例如智能标记和操作窗格。示例代码也向你演示了如何定制Microsoft Office 2007新的uI功能,包括功能区、自定义任务窗格和Outlook窗体区域。  Visual Studio Tools for Office(VSTO)的目标受众是“专业开发者”。这个术语有多重含义,而我们听到的最受认可的定义是“通过写代码获取报酬的人”。换句话说,这是他的主业。他不是部门开发者,比如说,把写Excel宏作为他的会计任务的一部分的会计人员,或者定制Word来增加他的生产力的办公人员。相反,他是一个有兴趣把Microsoft Office作为开发平台的.NET开发者。   我们相信传统的Office开发者也会对VSTO感兴趣。在加入Microsoft之前,我们俩都是VBA开发者,定制Office应用程序,并且我们非常有兴趣了解托管代码。在这方面,我们不认为我们是唯一的。有上百万VBA开发者,许多都有兴趣学习下一代Office开发。现在的VSTO图书和文档通常都不是为VBA开发者写的;它假设开发者熟悉Visual Studio、面向对象编程和.NET Framework。这就不难理解它把重点更多地放在VSTO的功能和如何使用笨重的Office对象模型。   我们想为VBA开发者写一本书。虽然你可能不熟悉.NET编程,但你有一个重要的优势:Office对象模型的知识。作为一个Office开发者,你很可能非常熟悉Office应用程序,在操作Office对象模型方面也有丰富的经验。我们认为学习托管代码的最佳环境是你已经熟悉的地方:Office开发。   VSTO把Office开发带到.NET的世界,和VBA相比,它有优点也有缺点。使用VSTO,你可以更好地定制Word、Excel和Outlook,比如说,创建自定义任务窗格、向文档添加智能标记和把文档上的对象绑定到数据源。使用VSTO 2005 SE,你可以为六个Office应用程序创建插件、定制新的2007 Microsoft Office System的功能区和创建应用程序级别的自定义任务窗格。   我们有幸和为VSTO设计、编码、测试和写文档的人一起工作,并从他们那里学到了很多。我们得到了内部人士对VSTO的看法,我们希望以一种易懂和有趣的方式把这些信息传递给你。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

rgbhi

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值