search

Home  >  Q&A  >  body text

Regarding parameter type mismatch caused by java generic design interface

1. An interface is designed to wrap other pojos to calculate whether they are expired

public interface CatchWrapper<T>{
    public long getCatchedTime();
    
    public T getValue();
    
    public boolean valid();
}

A certain implementation:

public class DeviceCatchWrapper implements CatchWrapper<Device> {
    private final long catchedTime;
    private final Device device;
    private static final long CATCH_TIME = 20*1000; 
    
    public DeviceCatchWrapper(Device device) {
        this.device = device;
        catchedTime = System.currentTimeMillis();
    }

    @Override
    public long getCatchedTime() {
        return catchedTime;
    }

    @Override
    public Device getValue() {
        return device;
    }

    @Override
    public boolean valid() {
        return System.currentTimeMillis() - catchedTime < CATCH_TIME;
    }

}

There is also a management class, mainly to delete expired cache

public class DeviceCatchWrapperManager<T> {
    private static final ScheduledExecutorService service = Executors.newSingleThreadScheduledExecutor();
    private final ConcurrentMap<String, CatchWrapper<T>> catchStore;

    private final long initialDelay;
    private final long delay;
    private TimeUnit unit;

    private volatile boolean stop = false;

    public DeviceCatchWrapperManager(ConcurrentMap<String,CatchWrapper<T>> catchStore, long initialDelay,
            long delay, TimeUnit unit) {
        this.catchStore = catchStore;
        this.initialDelay = initialDelay;
        this.delay = delay;
        this.unit = unit;
    }

    /**
     * 周期性检查过期的缓存,然后删除
     */
    public void startLoop() {
        service.scheduleWithFixedDelay(new Runnable() {
            @Override
            public void run() {
                for (Entry<String, CatchWrapper<T>> entry : catchStore.entrySet()) {
                    if (stop)
                        break;
                    String key = entry.getKey();
                    CatchWrapper<T> cw = entry.getValue();
                    if (!cw.valid()){
                        System.out.println("Device catch manager --------------->remove:"+key);
                        catchStore.remove(key, cw);
                    }
                        
                }

            }
        }, initialDelay, delay, unit);
        
    }

    /**
     * 停在对缓存进行过期检查
     */
    public void stop() {
        stop = true;
        service.shutdownNow();
    }
}

But the real constructor reports an error when passing parameters

private final ConcurrentMap<String, DeviceCatchWrapper> catchMap = new ConcurrentHashMap<>(); 

下面的报错,参数不对
private final DeviceCatchWrapperManager<Device> catchManager = new DeviceCatchWrapperManager<Device>(catchMap, 2, 2, TimeUnit.HOURS);

How to solve this error or how to design the interface or improve it?

我想大声告诉你我想大声告诉你2784 days ago582

reply all(1)I'll reply

  • 天蓬老师

    天蓬老师2017-05-17 10:02:20

    ConcurrentMap<String, DeviceCatchWrapper> catchMap = new ConcurrentHashMap<>(); There is a problem with this sentence
    Change to ConcurrentMap<String, CatchWrapper<Device>> catchMap = new ConcurrentHashMap& lt;String, DeviceCatchWrapper >();Try it

    reply
    0
  • Cancelreply