zoukankan      html  css  js  c++  java
  • 并发执行请求

     public class TaskHelper
        {
            private static int ThreadCount = 0;
            private static int ThreadMax = 5;
            private static object _lockObject = new object();
    
            /// <summary>
            /// 并行执行多个方法
            /// </summary>
            /// <param name="action"></param>
            private static void ActionAsParallel(params Action[] action)
            {
                return;
                bool enableParallel = false;
                lock (_lockObject)
                {
                    if (ThreadMax - ThreadCount < action.Length)
                    {
                        enableParallel = true;
                        ThreadCount = ThreadCount + 5;
                    }
                    else
                    {
                        enableParallel = false;
                    }
                }
                action.AsParallel();
            }
    
            /// <summary>
            /// 并发执行请求
            /// </summary>
            public static Dictionary<string, object> Batch(Dictionary<string, Func<object>> funcs)
            {
                var result = new Dictionary<string, object>();
                using (var countdown = new MutipleThreadResetEvent(funcs.Count))
                {
                    foreach (var func in funcs)
                    {
                        //开启N个线程,传递MutipleThreadResetEvent对象给子线程 
                        ThreadPool.QueueUserWorkItem((t) =>
                        {
                            func.Value.Invoke();
                            result.Add(func.Key, func.Value.Invoke());
                            MutipleThreadResetEvent ctd = t as MutipleThreadResetEvent;
                            //发送信号量 本线程执行完毕 
                            countdown.SetOne();
                        }, countdown);
                    }
                    //等待所有线程执行完毕 
                    countdown.WaitAll();
                }
                return result;
            }
    
            /// <summary>
            /// 无返回值,并发方法委托
            /// </summary>
            /// <param name="funcs"></param>
            public static void Batch(params Action[] funcs)
            {
                using (var countdown = new MutipleThreadResetEvent(funcs.Length))
                {
                    foreach (var func in funcs)
                    {
                        //开启N个线程,传递MutipleThreadResetEvent对象给子线程 
                        ThreadPool.QueueUserWorkItem((t) =>
                        {
                            func();
                            MutipleThreadResetEvent ctd = t as MutipleThreadResetEvent;
                            //发送信号量 本线程执行完毕 
                            countdown.SetOne();
                        }, countdown);
                    }
                    //等待所有线程执行完毕 
                    countdown.WaitAll();
                }
            }
        }
    
        /// <summary> 
        ///  封装ManualResetEvent 
        /// </summary> 
        public class MutipleThreadResetEvent : IDisposable
        {
            private readonly ManualResetEvent done;
            private readonly int total;
            private long current;
    
            /// <summary> 
            /// 构造函数 
            /// </summary> 
            /// <param name="total">需要等待执行的线程总数</param> 
            public MutipleThreadResetEvent(int total)
            {
                this.total = total;
                current = total;
                done = new ManualResetEvent(false);
            }
    
            /// <summary> 
            /// 唤醒一个等待的线程 
            /// </summary> 
            public void SetOne()
            {
                // Interlocked 原子操作类 ,此处将计数器减1 
                if (Interlocked.Decrement(ref current) == 0)
                {
                    //当所有等待线程执行完毕时,唤醒等待的线程 
                    done.Set();
                }
            }
    
            /// <summary> 
            /// 等待所有线程执行完毕 
            /// </summary> 
            public void WaitAll()
            {
                done.WaitOne();
            }
    
            /// <summary> 
            /// 释放对象占用的空间 
            /// </summary> 
            public void Dispose()
            {
                ((IDisposable)done).Dispose();
            }
    View Code
    Batch( 
                    () =>
                    {
                        var mltres = ServerClientHelper.JsonServiceClient.Send<GetUserByIdsRes>(new GetUserByIdsRequest
                        {
                            MemberIds = new List<int> { request.UserId },
                        });
                        if (mltres .DoFlag && mltres .Mmebers != null)
                        {
                            if (mltres .Mmebers.Any() && mltres .Mmebers.Count > 0)
                            {
                                response.fansnum = mltres .Mmebers[0].FansCount;
                                response.focusnum = mltres .Mmebers[0].FocusMCount;
                            }
                        }
                    },
                    //获取用户信息
                    () =>
                    {
                        var memberres = ServerClientHelper.VIPJsonServiceClient.Send<AppSelectMemberRes>(new AppSelectMember
                       {
                           UserId = request.UserId,
                           SourceTypeSysNo = request.SystemType
                       });
                        if (memberres .DoFlag && memberres .MemberEntity != null)
                        {
                            response.head = memberres .MemberEntity.HeadImg;
                            response.nick = memberres .MemberEntity.NickName;
                            response.level = memberres .MemberEntity.MemberLevelShow;
                            response.levelimg = memberres .MemberEntity.MemberLevelIcon;
                        }
    
                    }
  • 相关阅读:
    三层架构简单实例【转】
    排序 普通插入法排序
    排序 选择排序
    C#中的继承与覆盖
    排序 冒泡排序法
    c#使用Split分割字符串的几种方法
    GROUP BY,WHERE,HAVING之间的区别和用法
    递归 斐波那契数列
    【公众号系列】一文看懂税费改革
    【MM系列】SAP库龄报表逻辑理解
  • 原文地址:https://www.cnblogs.com/shy1766IT/p/5225369.html
Copyright © 2011-2022 走看看