
io.jsync.spi.cluster.impl.HazelcastAsyncMap Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of jsync.io Show documentation
Show all versions of jsync.io Show documentation
jsync.io is a non-blocking, event-driven networking framework for Java
/*
* Copyright (c) 2011-2013 The original author or authors
* ------------------------------------------------------
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* and Apache License v2.0 which accompanies this distribution.
*
* The Eclipse Public License is available at
* http://www.eclipse.org/legal/epl-v10.html
*
* The Apache License v2.0 is available at
* http://www.opensource.org/licenses/apache2.0.php
*
* You may elect to redistribute this code under either of these licenses.
*/
package io.jsync.spi.cluster.impl;
import com.hazelcast.core.IMap;
import io.jsync.AsyncResult;
import io.jsync.Handler;
import io.jsync.spi.AsyncSPI;
import io.jsync.spi.cluster.AsyncMap;
public class HazelcastAsyncMap implements AsyncMap {
private final AsyncSPI async;
private final IMap map;
public HazelcastAsyncMap(AsyncSPI async, IMap map) {
this.async = async;
this.map = map;
}
@Override
public void get(final K k, Handler> asyncResultHandler) {
async.executeBlocking(() -> map.get(k), asyncResultHandler);
}
@Override
public void put(final K k, final V v, Handler> completionHandler) {
async.executeBlocking(() -> {
map.put(k, HazelcastServerID.convertServerID(v));
return null;
}, completionHandler);
}
@Override
public void remove(final K k, Handler> completionHandler) {
async.executeBlocking(() -> {
map.remove(k);
return null;
}, completionHandler);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy