在Java中如何实现较为精确的定时器
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了在Java中如何实现较为精确的定时器相关的知识,希望对你有一定的参考价值。
用java.util.Timer生成定时器,但是明显计时不准,要求10毫秒执行一次的代码,实测30毫秒左右执行一次,vb的定时器就没有这个问题,Java如何实现较为精确的定时器?(该程序要为某事件持续时间精确计时必须要每隔10毫秒执行一次)
大部分人在遇到需要使用定时任务的时候首先会想到Timer类,不过在JDK5.0之后就不建议使用这个Timer了,因为它有很多的缺陷。
在新的java.util.concurrent包中的ScheduledExecutorService可以替代这个Timer:
使用方法举例:
Java代码
ScheduledThreadPoolExecutor exec = new ScheduledThreadPoolExecutor(1);
exec.scheduleAtFixedRate(new Runnable()
public void run()
try
throw new RuntimeException();
catch (Exception e)
System.out.println("RuntimeException catched");
, 1000, 5000, TimeUnit.MILLISECONDS); 参考技术A 1. 可以使用Java中的Timer类,里面的schedule函数,可以定时执行,也可以循环执行 参考技术B 集成spring 的 定时器
《
定时器的两种实现方式:
1.继承 java.util.TimerTask
2.继承 org.springframework.scheduling.quartz.QuartzJobBean
》
java项目中如何实现多选项的模糊或者精确查询
在java中如何实现多选项的查询,如:时间、商品名、生厂商、仓库、商品数量等等,其中根据一个选项或多个选项来精确或者模糊查询。在业务逻辑中SQL语句应该如何实现?数据库为ORACLE 11g
时间、商品名、生厂商、仓库、商品数量 这几个量 你从前端传送到业务逻辑层的时候先判断 其是否为空 之后拼接SQL
String sql=“select * from 表 where “
if(shijian!=null||!“”.eqaues(shijian))
sql=sql+"shijian='+时间 +'"
大概是这个意思
eqaues 我写错了 不用eclipse 敲 我很多东西不会写 参考技术A select * from 表 where 条件
一个选项或多个选项:
多个条件 可以用 and 或者 or连接, and表示且 or表示或者
精确或者模糊查询
精确使用 = 模糊使用like 其中like有占位符 _ 和匹配符 %
占位符表示提一个字符,匹配符表示替代0个或者多个字符
模糊查询使用 “like" ,精确查询使用“=”.
拼接sql语句用 StringBuffer。
例如:
StringBuffer sql = new StringBuffer();
sql.append("");//引号里面放你的sql语句。 参考技术C StringBuffer sb
可以实现的,多个,输入,判断每个条件是否为空。
如果不为空append进sb,具体,你自己决定,反正,查询功能上,查询一条和多条。机理是类似的
参考技术D 针对时间可以用 between..and 来约束范围,同时Oracle的时间亦可以用大于等于小于等操作符。楼主的意思不大明白,你所说的多选是指一张表中的多个字段同时约束结果,还是一个字段中的约束一定范围。
如果是多个字段同时约束查询结果的话,这些字段约束条件间可以用and进行连接。
以上是关于在Java中如何实现较为精确的定时器的主要内容,如果未能解决你的问题,请参考以下文章