在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个或者多个字符

参考技术B 可以使用拼接sql语句来实现。
模糊查询使用 “like" ,精确查询使用“=”.
拼接sql语句用 StringBuffer。
例如:
StringBuffer sql = new StringBuffer();
sql.append("");//引号里面放你的sql语句。
参考技术C StringBuffer  sb

可以实现的,多个,输入,判断每个条件是否为空。

如果不为空append进sb,具体,你自己决定,反正,查询功能上,查询一条和多条。机理是类似的

参考技术D 针对时间可以用 between..and 来约束范围,同时Oracle的时间亦可以用大于等于小于等操作符。
楼主的意思不大明白,你所说的多选是指一张表中的多个字段同时约束结果,还是一个字段中的约束一定范围。
如果是多个字段同时约束查询结果的话,这些字段约束条件间可以用and进行连接。

以上是关于在Java中如何实现较为精确的定时器的主要内容,如果未能解决你的问题,请参考以下文章

java项目中如何实现多选项的模糊或者精确查询

织女星开发板RISC-V内核实现微秒级精确延时

STM32 FreeRTOS中延时可以用vTaskDelay,但是计时,定时该如何实现?

Java 如何实现这样的定时任务

java中如何实现将float精确到小数点后两位

java中怎么实现定时功能