TimeLimitingCollector
包装其他的收集器,当查询超过指定时间时通过抛出TimeExceededException异常来中止搜索。通过一个被包装的收集器,一个时钟定时器和超时时间来构造TimeLimitingCollector对象。setBaseline(long clockTime):在包括实际收集文档在内的操作执行之前设置基线。默认情况下,第一个reader传给收集器时,收集器会初始化基线。
setBaseline():使用通过构造函数传入的clock的get()的值来设置基线。
isGreedy():是否贪婪地收集最后的命中结果。如果为false,在超时抛出TimeExceededException异常后,不允许被包装的收集器收集当前文档。如果为true,在超时后允许包装的收集器收集当前文档,然后再抛出TimeExceededException异常。
setCollector(Collector collector):对于多阶段的搜索过程,如果为每个阶段重新创建一个TimeLimitingCollector会重置计时器,使用此方法,可以使多个阶段的查询的每个阶段共用一个计时器。
collect(final int doc):收集结果,超时后会抛出TimeExceededException异常。
getGlobalCounter():返回一个全局的计时器。
getGlobalTimerThread():返回一个全局的TimerThread实例。
TimerThread:静态内部类,用于超时搜索请求的线程。默认的计时器为线程安全的AtomicCounter。
计时频率默认为20毫秒,即20毫秒计算一次,可以通过setResolution(long resolution)方法设置此频率,频率最小为5毫秒。
TimerThreadHolder:静态内部类,持有默认的使用AtomicCounter计时频率为20毫秒的TimerThread实例。