Windows服务简单实例

1.定时器使用

    partial class TimerService : ServiceBase
    {
        public TimerService()
        {
            InitializeComponent();
        }

        Timer timer = new Timer();
        protected override void OnStart(string[] args)
        {
            // TODO: 在此处添加代码以启动服务。
            AddLog("****服务启动");

            timer.Elapsed += timer_Elapsed;
            timer.Interval = 1000;
            timer.Start();
        }

        int number = 0;
        void timer_Elapsed(object sender, ElapsedEventArgs e)
        {
            try
            {
                number++;
                AddLog("" + number + "次执行方法");
                AddLog("当前时间:" + DateTime.Now.ToLongTimeString());
            }
            catch (Exception)
            {

            }
        }

        protected override void OnStop()
        {
            // TODO: 在此处添加代码以执行停止服务所需的关闭操作。
            AddLog("****服务终止");
            timer.Stop();
        }

        public void AddLog(string str)
        {
            using (StreamWriter sw = new StreamWriter(@"G:\log.data", true))
            {
                sw.WriteLine("****************************************");
                sw.WriteLine(str);
            }
        }
    }

 

 

 

2.记录日志和数据库访问
    partial class MessageBoxSer : ServiceBase
    {
        Thread mainThread;
        public MessageBoxSer()
        {
            InitializeComponent();

            mainThread = new Thread(new ThreadStart(ThreadFunc));
            mainThread.Priority = ThreadPriority.Normal;
        }



        
        public static void ThreadFunc()
        {
            //while (true)
            //{
            //    Thread.Sleep(1000);
            //    MessageBox.Show("asdfasdf");
            //}

            while (true)
            {

                // MessageBox.Show("asdfasdf");
                Thread.Sleep(3000);

                //修改数据库
                SerTableDA.AddData();


                //记录日志
                //try
                //{
                //    using (StreamWriter sw = new StreamWriter(@"G:\log.data", true))
                //    {
                //        sw.WriteLine(DateTime.Now.ToLongTimeString() + "执行循环代码");
                //    }
                //}
                //catch (Exception ex)
                //{

                //}
            }
        }


        protected override void OnStart(string[] args)
        {
            // TODO: 在此处添加代码以启动服务。
            mainThread.Start();
        }

        protected override void OnStop()
        {
            // TODO: 在此处添加代码以执行停止服务所需的关闭操作。
            mainThread.Abort();
        }
    }

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值