c# 处理超时的问题

       最近在调用厂商的dll时发现有时候会停在dll里出不来,因为等不及厂商改,所以只能调用的方法外围加上超时管控了,以下是demo 代码,用作自己的记录:用到的Task.Run(()=>自己不可控的方法).wait(指定时间),意思就是在指定时间内,如果那个自己不可控的方法执行完了,便没啥事,如果走丢了就不等它了,直接往下跑,用它的前辈Task.Factory.StartNew也可以,但是看微软的说明还是有点差别的,只是我目前还没有涉及到那些区别,所以就没再研究。

      static void Main(string[] args)
        {
            double data = 0;
            bool result = Task.Run(() =>
            {
                data = calcu();
            }).Wait(5*1000);
            if (result)
            {
                Console.WriteLine(data);
            }
            else
            {
                Console.WriteLine("overtime!");
            }
            Console.ReadLine();
        }

        static double calcu() //假装这个是厂商那个跑不出来的方法,定多少个0就看自己电脑的速度了
        {
            double data = 0;
            for (int i = 0; i < 1000000000000; i++) {
                data =  i * i;
            }
            return data;
        }

最后出来的结果:

不过要注意一个问题,如果后边的程式还没有运行完,但是那个不可控的方法却运行完了,就会出现另一个结果:

下面是关于Task.Run

https://docs.microsoft.com/zh-cn/dotnet/api/system.threading.tasks.task.run?view=net-5.0#System_Threading_Tasks_Task_Run__1_System_Func___0__

关于Task.Run和Task.Factory.StartNew的区别,有兴趣的同学可以研究一下哈

https://devblogs.microsoft.com/pfxteam/task-run-vs-task-factory-startnew/

.net C#线程超时的解决方案,使用的时候在被调线程入口调用一下这个方法就可以。更多详细代码见附件 Report.RegisterThread(Report.GetCurrentWin32ThreadID(),Thread.CurrentThread); #region 获取当取线程的ThreadID [DllImport("Kernel32", EntryPoint = "GetCurrentThreadId", ExactSpelling = true)] public static extern Int32 GetCurrentWin32ThreadID(); #endregion #region 登记访问任务子线程 /// /// 访问任务子线程 /// public static Hashtable TaskThreadIDTable = Hashtable.Synchronized(new Hashtable()); private static int[] TaskThreadIDs { get { int[] IDs = new int[TaskThreadIDTable.Keys.Count]; TaskThreadIDTable.Keys.CopyTo(IDs, 0); return IDs; } } public static void RegisterThread(int _threadid, System.Threading.Thread thread) { if (!TaskThreadIDTable.ContainsKey(_threadid)) TaskThreadIDTable.Add(_threadid, thread); if (!ExitInvalidThreadLoopRunning) { Thread ExitInvalidThreadLoopThread = new Thread(new ThreadStart(ExitInvalidThreadLoop)); ExitInvalidThreadLoopThread.Priority = ThreadPriority.AboveNormal; ExitInvalidThreadLoopThread.Start(); } } #endregion #region 关闭,退出超时的用户线程 private static DateTime ExitInvalidThreadLoop_LastRunTime = DateTime.Now.Subtract(new TimeSpan(1, 0, 0, 0, 0)); private static bool ExitInvalidThreadLoopRunning { get { return DateTime.Now.Subtract(ExitInvalidThreadLoop_LastRunTime).TotalMinutes 10) { try { Thread thread = (Thread)TaskThreadIDTable[t.Id]; thread.Abort(); } catch { } t.Dispose(); } } #endregion } #endregion
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值