C#-系统Timer会自动停止,使用线程进行连续性测试

坚持记录实属不易,希望友善多金的码友能够随手点一个赞。
共同创建氛围更加良好的开发者社区!
谢谢~

概述

接上片Timer计时器的文章:C#中System.Threading.Timer的使用
利用周末时间测试了一下System.Threading.Timer的性能,发现两个问题:
1、会出现一些内存泄露的问题,第一天晚上出现了Out of memory的异常,由于是深夜没有第一时间看到线程,早上发现的时候已经中止了,所以还无法完全断定是因为Timer的原因,但后续测试了一下,在跑几个小时后,timer还是会容易出现一些内存泄露的问题,当然我是在里面进行了一些逻辑处理、页面UI的展示和硬件设备的调用;
2、长时间运行后,还是会出现自动停止的现象
故此使用线程进行连续性测试。

代码结构

创建和执行

		//全局变量
        Thread Looper;

        private void btnFatigueTest_Click(object sender, EventArgs e)
        {
            GroupControl(false);
            btn_FatigueCap.Enabled = false;
            btn_StopCap.Enabled = true;
            //硬件执行方法调用

			//创建线程
            Looper = new Thread(new ThreadStart(Loop));
            //执行线程
            Looper.Start();
        }

线程中执行的方法


        int count = 1;
        int count2 = 1;
        bool IsPointB;

        /// <summary>
        /// 循环调用方法
        /// </summary>
        /// <param name="sender"></param>
        private void Loop()
        {
            while (true)
            {
            	//线程睡眠1000ms
                Thread.Sleep(CameraHost.TimeOut);

                string name = IsPointB ? "B" : "A";
                IsPointB = !IsPointB;
                //获取硬件结果
                var filepath = ....
                if (File.Exists(filepath))
                {

                    
                    BeginInvoke(new Action(() => {
                        lb_Count.Text = "次数" + count++;
                    }));
                }
                else
                {
                    MainDeviceProvider.Instance.Logger.Warning($"出错 :{count2++}/{count - 1}");
                }
                //主动GC,系统不一定听你的
 tin               GC.Collect();
            }
        }

停止线程


        private void btn_StopCap_Click(object sender, EventArgs e)
        {
        	//终止线程
            Looper.Abort();

            GroupControl(true);
            count = 1;
            btn_FatigueCap.Enabled = true;
            btn_StopCap.Enabled =  false;
        }

参考文章

C#多线程——Thread睡眠、中断、合并、暂停与恢复、终止

  • 6
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
mssql-jdbc-shared-timer-core线程是Microsoft SQL Server JDBC Driver中的一个核心线程,它用于检查和清理连接池中的无效连接。通常情况下,建议不要直接关闭该线程,否则可能导致连接池中的连接得不到及时的清理和释放,进而影响应用程序的性能和稳定性。 如果您确实需要关闭mssql-jdbc-shared-timer-core线程,可以考虑使用以下两种方法之一: 1. 通过配置文件禁用定时器 在Microsoft SQL Server JDBC Driver的配置文件中,可以通过设置以下属性来禁用定时器: ``` <property name="disableConnectionPoolTimer" value="true" /> ``` 这样一来,定时器就被禁止,连接池中的连接也就不自动清理和释放了。需要注意的是,禁用定时器可能导致连接池中的连接资源得不到及时的回收和释放,从而影响应用程序的性能和稳定性。 2. 通过编写代码手动关闭连接池 如果您需要在应用程序中手动关闭连接池,可以调用连接池的close()方法,例如: ``` DataSource dataSource = new SQLServerDataSource(); ((SQLServerDataSource) dataSource).setURL("jdbc:sqlserver://localhost:1433;databaseName=test"); ((SQLServerDataSource) dataSource).setUser("user"); ((SQLServerDataSource) dataSource).setPassword("password"); Connection connection = dataSource.getConnection(); // 使用连接执行数据库操作 connection.close(); // 关闭连接 ``` 在关闭连接之后,连接池中的连接也就自动清理和释放,定时器也就不再需要执行了。需要注意的是,手动关闭连接池可能影响到应用程序中其他部分对数据库的访问,因此建议谨慎操作。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

默九思

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

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

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

打赏作者

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

抵扣说明:

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

余额充值