windows服务每隔一段时间执行程序

定时任务与数据库操作
本文介绍了一个使用 C# 实现的 Windows 服务程序,该程序通过定时器每隔 10 秒执行一次微博数据的抓取及入库操作,并记录日志。主要涉及的技术包括 Timer 的使用、SQL Server 数据库连接及 SQL 命令执行。
using System;
using System.Data.SqlClient;
using System.ServiceProcess;
using Timer = System.Timers.Timer;

namespace WeiBo
{
    public partial class Service1 : ServiceBase
    {
        public Service1()
        {
            InitializeComponent();
            Timer t=new Timer(10000);
            t.Elapsed += GetWeiBo;//到时间的时候执行事件; 
            t.AutoReset = true;//设置是执行一次(false)还是一直执行(true); 
            t.Enabled = true;//是否执行System.Timers.Timer.Elapsed事件; 
        }
        public void GetWeiBo(object source, System.Timers.ElapsedEventArgs e)
        {
            try
            {
                string ConnStr = Settings.Default.ConnStr;
                SqlConnection conn = new SqlConnection(ConnStr);
                SqlCommand comm = new SqlCommand("insert into tb1(str) values('111')", conn);
                conn.Open();
                int num=comm.ExecuteNonQuery();
                conn.Close();
                Utils.LogFile(string.Format("----成功插入{0}条----",num));
            }
            catch (Exception e1)
            {
                Utils.LogFile(e1.Message);
                throw;
            }
        }


        protected override void OnStart(string[] args)
        {
            Utils.LogFile("----开始采集----");
        }

        protected override void OnStop()
        {
            Utils.LogFile("----采集结束----");
        }
    }
}


### 设置 STM32 定时器实现周期性任务调度 #### 初始化定时器并配置中断 为了使 STM32 能够按照指定的时间间隔执行特定的任务,可以使用硬件定时器来触发中断,在每次定时结束时调用相应的服务例程(Interrupt Service Routine, ISR),从而实现周期性的操作。具体来说: - 配置定时器的工作模式为向上计数(up-counting mode)[^1]; - 设定自动重装载寄存器(Auto Reload Register)的值以决定溢出发生前的最大计数值,该值决定了定时周期长度; - 开启更新事件(update event)产生的中断请求允许位(UIE),以便于每当计数到达最大值即产生一次中断。 ```c // 假设使用 TIM2 进行每5秒一次的操作 void Timer_Init(void){ // RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM2, ENABLE); TIM_TimeBaseInitTypeDef TIM_TimeBaseStructure; NVIC_InitTypeDef NVIC_InitStructure; // 计算预分频系数和自动重载值 uint16_t PrescalerValue = (uint16_t)((SystemCoreClock / 72) - 1); //假设系统频率为72MHz TIM_DeInit(TIM2); TIM_TimeBaseStructInit(&TIM_TimeBaseStructure); TIM_TimeBaseStructure.TIM_Period = ((SystemCoreClock/PrescalerValue)/2)-1; //调整此参数改变延时时长 TIM_TimeBaseStructure.TIM_Prescaler = PrescalerValue; TIM_TimeBaseStructure.TIM_ClockDivision = 0; TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up ; TIM_TimeBaseInit(TIM2,&TIM_TimeBaseStructure); TIM_ITConfig(TIM2,TIM_IT_Update ,ENABLE ); NVIC_InitStructure.NVIC_IRQChannel = TIM2_IRQn ; NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority=0x00; NVIC_InitStructure.NVIC_IRQChannelSubPriority =0x00; NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE; NVIC_Init(&NVIC_InitStructure); TIM_Cmd(TIM2, ENABLE ); } ``` #### 编写中断服务程序 一旦设置了上述定时器之后,则需编写对应的ISR用于处理实际业务逻辑。这里展示的是一个简单的例子——每隔五秒钟通过串口打印消息“hello windows!”[^3]。 ```c extern "C" void TIM2_IRQHandler(void) { if(TIM_GetITStatus(TIM2, TIM_IT_Update ) != RESET ) { // 清除中断标志 TIM_ClearITPendingBit(TIM2, TIM_IT_Update ); printf("hello windows!\r\n"); // 发送字符串到PC端 // 可在此处加入其他需要定期执行的任务... } } ``` 对于 LED 的闪烁控制同样可以通过另一个定时器实例化完成,比如 TIM3 来负责两秒钟切换电平状态。需要注意的是两个不同定时器之间应该保持独立运作以免相互干扰影响精度[^4]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值