首页
/ CronNET 使用详解

CronNET 使用详解

2024-12-28 03:37:59作者:裘旻烁

1. 安装指南

CronNET 的安装非常简便,首先确保您的开发环境已经配置了.NET环境。然后,通过NuGet包管理器来安装CronNET。

在您的项目文件中,添加以下代码来引入CronNET:

<PackageReference Include="Iminetsoft.CronNET" Version="8.0.2" />

或者在NuGet包管理器控制台中执行以下命令:

Install-Package Iminetsoft.CronNET -Version 8.0.2

确保选择正确的项目,然后等待NuGet包安装完成。

2. 项目的使用说明

CronNET 是一个简单的C#库,用于基于cron计划执行任务。CronNET支持大多数cron计划格式。具体支持的格式如下:

  • * * * * *: 每分钟。
  • 0 * * * *: 每小时的开始。
  • 0,1,2 * * * *: 每小时的第0、1和2分钟。
  • */2 * * * *: 每2分钟。
  • 1-55 * * * *: 从第1分钟到第55分钟。
  • * 1,10,20 * * *: 每月的第1、10和20小时。

使用CronNET,您可以创建定时任务,如以下示例所示:

控制台应用程序示例

using System.Threading;
using CronNET;

namespace CronNETExample.Console
{
    class Program
    {
        private static readonly CronDaemon cron_daemon = new CronDaemon();            

        static void Main(string[] args)
        {
            cron_daemon.add_job(new CronJob("* * * * *", task));
            cron_daemon.start();

            // 无限等待,让cron守护程序运行。
            while(true) Thread.Sleep(6000);
        }

        static void task()
        {
            Console.WriteLine("Hello, world.");
        }
    }
}

Windows服务应用程序示例

using System.Threading;
using CronNET;

namespace CronNETExample.WindowsService
{
    public partial class Service : ServiceBase
    {
        private readonly CronDaemon cron_daemon = new CronDaemon();

        public Service()
        {
            InitializeComponent();
        }

        protected override void OnStart(string[] args)
        {
            cron_daemon.add_job(new CronJob("*/2 * * * *", task));
            cron_daemon.start();
        }

        protected override void OnStop()
        {
            cron_daemon.stop();
        }

        private void task()
        {
            Console.WriteLine("Hello, world.");
        }
    }
}

3. 项目API使用文档

CronNET 的API相对简单,主要包括以下类和方法:

  • CronDaemon: 用于管理cron任务的主类。

    • add_job(CronJob job): 添加一个新的cron任务。
    • start(): 开始执行cron任务。
    • stop(): 停止执行cron任务。
  • CronJob: 表示一个cron任务。

    • 构造函数 CronJob(string cronExpression, Action task): 使用cron表达式和要执行的任务初始化。

4. 项目安装方式

项目的安装方式已在“安装指南”部分详细说明,通过NuGet包管理器进行安装是最简单和推荐的方法。

登录后查看全文
热门项目推荐

热门内容推荐

最新内容推荐

项目优选

收起
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
178
262
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
867
513
openGauss-serveropenGauss-server
openGauss kernel ~ openGauss is an open source relational database management system
C++
129
183
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
265
305
HarmonyOS-ExamplesHarmonyOS-Examples
本仓将收集和展示仓颉鸿蒙应用示例代码,欢迎大家投稿,在仓颉鸿蒙社区展现你的妙趣设计!
Cangjie
398
371
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
1.07 K
0
ShopXO开源商城ShopXO开源商城
🔥🔥🔥ShopXO企业级免费开源商城系统,可视化DIY拖拽装修、包含PC、H5、多端小程序(微信+支付宝+百度+头条&抖音+QQ+快手)、APP、多仓库、多商户、多门店、IM客服、进销存,遵循MIT开源协议发布、基于ThinkPHP8框架研发
JavaScript
93
15
note-gennote-gen
一款跨平台的 Markdown AI 笔记软件,致力于使用 AI 建立记录和写作的桥梁。
TSX
83
4
cherry-studiocherry-studio
🍒 Cherry Studio 是一款支持多个 LLM 提供商的桌面客户端
TypeScript
598
57
GitNextGitNext
基于可以运行在OpenHarmony的git,提供git客户端操作能力
ArkTS
10
3