Exemplo n.º 1
0
        public static void ForEach <TSource>(IEnumerable <TSource> source, Action <TSource> body, Action <AggregateException> catchClause = null, int?maxThreads = null) where TSource : class
        {
            Action <TSource> localBody = o =>
            {
                LocalizationHelper.InitThread(); // Ensure appropriate culture
                body(o);
            };

            LoopWithExceptionHandling(() =>
            {
                using (var worker = new QueueWorker <TSource>(null, (s, i) => localBody(s)))
                {
                    worker.RunAsync(GetThreadCount(maxThreads), typeof(ParallelEx).Name);
                    foreach (TSource s in source)
                    {
                        if (worker.Exception != null)
                        {
                            break;
                        }
                        worker.Add(s);
                    }
                    worker.DoneAdding(true);
                    if (worker.Exception != null)
                    {
                        throw new AggregateException(@"Exception in Parallel.ForEx", worker.Exception);
                    }
                }
            }, catchClause);
//            LoopWithExceptionHandling(() => Parallel.ForEach(source, PARALLEL_OPTIONS, localBody), catchClause);
        }
Exemplo n.º 2
0
        public static void For(int fromInclusive, int toExclusive, Action <int> body, Action <AggregateException> catchClause = null, int?maxThreads = null)
        {
            Action <int> localBody = i =>
            {
                LocalizationHelper.InitThread(); // Ensure appropriate culture
                body(i);
            };

            LoopWithExceptionHandling(() =>
            {
                using (var worker = new QueueWorker <IntHolder>(null, (h, i) => localBody(h.TheInt)))
                {
                    worker.RunAsync(GetThreadCount(maxThreads), typeof(ParallelEx).Name);
                    for (int i = fromInclusive; i < toExclusive; i++)
                    {
                        if (worker.Exception != null)
                        {
                            break;
                        }
                        worker.Add(new IntHolder(i));
                    }
                    worker.DoneAdding(true);
                    if (worker.Exception != null)
                    {
                        throw new AggregateException(@"Exception in Parallel.For", worker.Exception);
                    }
                }
            }, catchClause);
//            LoopWithExceptionHandling(() => Parallel.For(fromInclusive, toExclusive, PARALLEL_OPTIONS, localBody), catchClause);
        }