惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

The Register - Security
The Register - Security
博客园 - Franky
奇客Solidot–传递最新科技情报
奇客Solidot–传递最新科技情报
GbyAI
GbyAI
WordPress大学
WordPress大学
博客园 - 【当耐特】
月光博客
月光博客
Microsoft Security Blog
Microsoft Security Blog
宝玉的分享
宝玉的分享
Y
Y Combinator Blog
S
SegmentFault 最新的问题
B
Blog RSS Feed
酷 壳 – CoolShell
酷 壳 – CoolShell
腾讯CDC
U
Unit 42
OSCHINA 社区最新新闻
OSCHINA 社区最新新闻
阮一峰的网络日志
阮一峰的网络日志
aimingoo的专栏
aimingoo的专栏
博客园 - 三生石上(FineUI控件)
F
Fortinet All Blogs
博客园 - 司徒正美
人人都是产品经理
人人都是产品经理
Last Week in AI
Last Week in AI
Engineering at Meta
Engineering at Meta
D
DataBreaches.Net
C
Check Point Blog
G
Google Developers Blog
有赞技术团队
有赞技术团队
I
InfoQ
T
The Blog of Author Tim Ferriss
F
Full Disclosure
Help Net Security
Help Net Security
P
Palo Alto Networks Blog
G
GRAHAM CLULEY
T
Tenable Blog
Know Your Adversary
Know Your Adversary
N
Netflix TechBlog - Medium
H
Hacker News: Front Page
C
Cyber Attacks, Cyber Crime and Cyber Security
Project Zero
Project Zero
Latest news
Latest news
Recorded Future
Recorded Future
cs.CL updates on arXiv.org
cs.CL updates on arXiv.org
Threat Intelligence Blog | Flashpoint
Threat Intelligence Blog | Flashpoint
N
News | PayPal Newsroom
C
Cisco Blogs
T
Tor Project blog
Cyber Security Advisories - MS-ISAC
Cyber Security Advisories - MS-ISAC
S
Secure Thoughts
A
Arctic Wolf

博客园 - lovebanyi

Memory stream is not expandable 博客园密文招聘的解密 微软Azure平台 cloud service动态申请证书并绑定证书碰到的坑 PInvoke在 2.0 3.0的时候正常 升级到4.0后出错。 不要进行过度设计,某一层存在真的有意义吗?是否可以更简单。 化繁为简 定义权限 Ajax加载子域跨站cookie丢失的问题. Exists 比Contains 慢非常多。 ValidationExpression="http(s)?://([\w-]+\.)+[\w-]+(/[\w- ./?%&=]*)?" can not work - lovebanyi 支付系统会碰到的漏洞问题。 值类型引用类型List Remove 方法Remove不掉哪一个项。 流程变换与抽象 Compiler Error Message: CS1513: } expected 如何用好SVN的Branch EntityFramework Any 生成的sql语句超长。 新的一家公司Web开发选择的控件是Dev Express 太烂了,发现项目结构也是混乱的。 使用lambda表达式对属性进行验证。 数据库连接字符串配置的流程改进 从解放劳动力来看未来的科技进程
Quartz 的SB问题 GetNextValidTimeAfter 输出和输出 时区 不同步,好傻的方法?
lovebanyi · 2012-06-04 · via 博客园 - lovebanyi

测试代码如下

  DateTime kk = new DateTime(2012641500);
            Quartz.CronExpression cron = new Quartz.CronExpression("0 14 15 ? * *");
            var dt = cron.GetNextValidTimeAfter(kk);

好傻好伤。

dt的时候是 

{2012/6/5 7:14:00} 跑出了一个7点来了。

正确的期待值应该是  2012-6-4 15:14:00:00

后面才想到这个时间跟好跟我们差8个小时。(没有去验证它的代码是否真的是这个问题)

后面用了

得到的时间是 {2012/6/5 15:14:00} 跟我们期待值差一天。

查了一下它的方法。还有一个方法 GetNextInvalidTimeAfter

            

var dtInvalid = cron.GetNextInvalidTimeAfter(kk);

得到的时间是

2012-6-4 15:14:00:00

跟我们的期待值完全一样。不明白原来写的人为什么会这么用啊。


DateTime currenTime2 = new DateTime(20126515150);
            Quartz.CronExpression cron = new Quartz.CronExpression("0 14 15 ? * *");
         
            var dt2 = cron.GetNextValidTimeAfter(currenTime2);
            var dt3 = cron.GetNextInvalidTimeAfter(currenTime2);

 发现
dt2 是{2012/6/6 7:14:00} // local time后是 2012/6/6 15:14:00:00正确了。 6月5号的触发时间已过了。 所以时间应该是 6-6正确。

dt3 是{2012/6/5 15:15:00} //不对 原来 GetNextInvalidTimeAfter  是不行的。

升级到 最新的版本后 2.0.1.100上面的问题被解决了。但是发现了一个新问题。

我们的系统比如说相间隔7个小时触发。 然后我写出来的cronstring 是 

0 0 */7 * * ? *
但是发现这个不是表示间隔 7个小时触发,而是表示。从0:00:00 开始每7个小时触 发一次。 上面的表达式等价于

0 0 0/7 * * ? *
如果它可以让 * 号表示任意小时的话就cool了。

需要自己去修改源代码才可以达到这种效果了。 其实Repeat 这种代码不要用CronString写出来还可以更简单。每隔几个小时 几天 几周 直接就可以算出TimeSpan 然后可以很轻松的等到NextValidTime.

而CronString用在 每天的哪一个小时触发。每周的周一 周二 每月的第一天 或者最后一天。这种才更合适于它。