使用BlockingCollection和Parallel.Invoke优化缓冲样本以进行并行执行

时间:2013-01-17 21:56:11

标签: c#

基于Optimizing a buffering sample for parallel execution出现了这个问题。

简而言之:

这段代码抛出了很多无法访问另一个线程异常的元素。它会创建空文件名,并且每3个左右跳过一次。

目标是在将字节数组并行转换为图像时,不要将编号(Nummerierung)混淆。请参阅链接以获取说明。

我需要改变什么?

Action action = () =>
{
    ArrayAnsammlung.TryTake(out data);
    if (data != null)
    {
        Nummerierung = Convert.ToString(Interlocked.Increment(ref Nummerierungszaehler));
        Enkodierung = null;
        Enkodierung = new JpegBitmapEncoder();
        Enkodierung.FlipHorizontal = true;
        var dateiStrom = new FileStream("E:\\Temp\\" + datum + " " + Nummerierung.PadLeft(12, '0') + ".jpg", FileMode.Create);
        Enkodierung.Frames.Add(BitmapFrame.Create(BitmapSource.Create(bildbreite, bildhoehe * 2,
        96, 96, PixelFormats.Bgr32, null, data, stride)));
        Enkodierung.Save(dateiStrom);
        dateiStrom = null;
        Enkodierung = null;
    }
};

while (aufnahme)
{
    try
    {
        Parallel.Invoke(action, action, action, action, action);
    }
    catch (AggregateException oo)
    {
        Console.WriteLine(oo.ToString());
    }
    Thread.Sleep(2000);
}

1 个答案:

答案 0 :(得分:0)

为Nummerierung使用本地字符串,再为Enkodierung使用本地变量,因为这两个变量在您的线程之间共享,如果另一个线程开始执行,则一个线程的Nummerierung和Enkodierung可能会被覆盖。