本文整理汇总了Java中com.hazelcast.core.PartitionAware类的典型用法代码示例。如果您正苦于以下问题:Java PartitionAware类的具体用法?Java PartitionAware怎么用?Java PartitionAware使用的例子?那么恭喜您, 这里精选的类代码示例或许可以为您提供帮助。
PartitionAware类属于com.hazelcast.core包,在下文中一共展示了PartitionAware类的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。
示例1: writeObject
import com.hazelcast.core.PartitionAware; //导入依赖的package包/类
public Data writeObject(final Object obj) {
if (obj == null) {
return null;
}
if (obj instanceof Data) {
return (Data) obj;
}
byte[] bytes = toByteArray(obj);
if (bytes == null) {
return null;
} else {
Data data = new Data(bytes);
if (obj instanceof PartitionAware) {
Data partitionKey = writeObject(((PartitionAware) obj).getPartitionKey());
int partitionHash = (partitionKey == null) ? -1 : partitionKey.getPartitionHash();
data.setPartitionHash(partitionHash);
}
return data;
}
}
示例2: getTaskPartitionId
import com.hazelcast.core.PartitionAware; //导入依赖的package包/类
private <T> int getTaskPartitionId(Callable<T> task) {
int partitionId;
if (task instanceof PartitionAware) {
final Object partitionKey = ((PartitionAware) task).getPartitionKey();
partitionId = getNodeEngine().getPartitionService().getPartitionId(partitionKey);
} else {
partitionId = random.nextInt(partitionCount);
}
return partitionId;
}