本文整理汇总了Java中com.lmax.disruptor.EventTranslatorTwoArg类的典型用法代码示例。如果您正苦于以下问题:Java EventTranslatorTwoArg类的具体用法?Java EventTranslatorTwoArg怎么用?Java EventTranslatorTwoArg使用的例子?那么恭喜您, 这里精选的类代码示例或许可以为您提供帮助。
EventTranslatorTwoArg类属于com.lmax.disruptor包,在下文中一共展示了EventTranslatorTwoArg类的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。
示例1: translateAndPublishBatch
import com.lmax.disruptor.EventTranslatorTwoArg; //导入依赖的package包/类
private <A, B> void translateAndPublishBatch(final EventTranslatorTwoArg<E, A, B> translator, final A[] arg0,
final B[] arg1, int batchStartsAt, int batchSize,
final long finalSequence)
{
final long initialSequence = finalSequence - (batchSize - 1);
try
{
long sequence = initialSequence;
final int batchEndsAt = batchStartsAt + batchSize;
for (int i = batchStartsAt; i < batchEndsAt; i++)
{
translator.translateTo(get(sequence), sequence++, arg0[i], arg1[i]);
}
}
finally
{
sequencer.publish(initialSequence, finalSequence);
}
}
示例2: tryPublishEvent
import com.lmax.disruptor.EventTranslatorTwoArg; //导入依赖的package包/类
/**
* Allows two user supplied arguments.
*
* @see #tryPublishEvent(EventTranslator)
* @param translator The user specified translation for the event
* @param arg0 A user supplied argument.
* @param arg1 A user supplied argument.
* @return true if the value was published, false if there was insufficient
* capacity.
*/
public <A, B> boolean tryPublishEvent(EventTranslatorTwoArg<E, A, B> translator, A arg0, B arg1)
{
try
{
final long sequence = sequencer.tryNext();
translateAndPublish(translator, sequence, arg0, arg1);
return true;
}
catch (InsufficientCapacityException e)
{
return false;
}
}
示例3: tryPublishEvents
import com.lmax.disruptor.EventTranslatorTwoArg; //导入依赖的package包/类
/**
* Allows two user supplied arguments per event.
*
* @param translator The user specified translation for the event
* @param batchStartsAt The first element of the array which is within the batch.
* @param batchSize The actual size of the batch.
* @param arg0 An array of user supplied arguments, one element per event.
* @param arg1 An array of user supplied arguments, one element per event.
* @return true if the value was published, false if there was insufficient
* capacity.
* @see #tryPublishEvents(EventTranslator[])
*/
public <A, B> boolean tryPublishEvents(EventTranslatorTwoArg<E, A, B> translator, int batchStartsAt, int batchSize, A[] arg0, B[] arg1)
{
checkBounds(arg0, arg1, batchStartsAt, batchSize);
try
{
final long finalSequence = sequencer.tryNext(batchSize);
translateAndPublishBatch(translator, arg0, arg1, batchStartsAt, batchSize, finalSequence);
return true;
}
catch (InsufficientCapacityException e)
{
return false;
}
}
示例4: translateAndPublish
import com.lmax.disruptor.EventTranslatorTwoArg; //导入依赖的package包/类
private <A, B> void translateAndPublish(EventTranslatorTwoArg<E, A, B> translator, long sequence, A arg0, B arg1)
{
try
{
translator.translateTo(get(sequence), sequence, arg0, arg1);
}
finally
{
sequencer.publish(sequence);
}
}
示例5: tryPublishEvent
import com.lmax.disruptor.EventTranslatorTwoArg; //导入依赖的package包/类
/**
* Allows two user supplied arguments.
*
* @see #tryPublishEvent(EventTranslator)
* @param translator The user specified translation for the event
* @param arg0 A user supplied argument.
* @param arg1 A user supplied argument.
* @return true if the value was published, false if there was insufficient capacity.
*/
public <A, B> boolean tryPublishEvent(EventTranslatorTwoArg<E, A, B> translator, A arg0, B arg1) {
try {
final long sequence = sequencer.tryNext();
translateAndPublish(translator, sequence, arg0, arg1);
return true;
} catch (InsufficientCapacityException e) {
return false;
}
}
示例6: translateAndPublish
import com.lmax.disruptor.EventTranslatorTwoArg; //导入依赖的package包/类
private <A, B> void translateAndPublish(EventTranslatorTwoArg<E, A, B> translator, long sequence, A arg0, B arg1) {
try {
translator.translateTo(get(sequence), sequence, arg0, arg1);
} finally {
sequencer.publish(sequence);
}
}
示例7: translateAndPublishBatch
import com.lmax.disruptor.EventTranslatorTwoArg; //导入依赖的package包/类
private <A, B> void translateAndPublishBatch(final EventTranslatorTwoArg<E, A, B> translator, final A[] arg0, final B[] arg1, int batchStartsAt,
int batchSize, final long finalSequence) {
final long initialSequence = finalSequence - (batchSize - 1);
try {
long sequence = initialSequence;
final int batchEndsAt = batchStartsAt + batchSize;
for (int i = batchStartsAt; i < batchEndsAt; i++) {
translator.translateTo(get(sequence), sequence++, arg0[i], arg1[i]);
}
} finally {
sequencer.publish(initialSequence, finalSequence);
}
}
示例8: publishEvent
import com.lmax.disruptor.EventTranslatorTwoArg; //导入依赖的package包/类
@Override
public <A, B> void publishEvent(EventTranslatorTwoArg<ResponseEvent, A, B> translator, A arg0, B arg1) {
ResponseEvent ev = new ResponseEvent();
translator.translateTo(ev, 0, arg0, arg1);
responseEvents.add(ev);
}
示例9: tryPublishEvent
import com.lmax.disruptor.EventTranslatorTwoArg; //导入依赖的package包/类
@Override
public <A, B> boolean tryPublishEvent(EventTranslatorTwoArg<ResponseEvent, A, B> translator, A arg0, B arg1) {
throw new UnsupportedOperationException();
}
示例10: publishEvents
import com.lmax.disruptor.EventTranslatorTwoArg; //导入依赖的package包/类
@Override
public <A, B> void publishEvents(EventTranslatorTwoArg<ResponseEvent, A, B> translator, A[] arg0, B[] arg1) {
throw new UnsupportedOperationException();
}
示例11: tryPublishEvents
import com.lmax.disruptor.EventTranslatorTwoArg; //导入依赖的package包/类
@Override
public <A, B> boolean tryPublishEvents(EventTranslatorTwoArg<ResponseEvent, A, B> translator, A[] arg0, B[] arg1) {
throw new UnsupportedOperationException();
}
示例12: publishEvents
import com.lmax.disruptor.EventTranslatorTwoArg; //导入依赖的package包/类
/**
* Allows two user supplied arguments per event.
*
* @param translator The user specified translation for the event
* @param batchStartsAt The first element of the array which is within the batch.
* @param batchSize The actual size of the batch.
* @param arg0 An array of user supplied arguments, one element per event.
* @param arg1 An array of user supplied arguments, one element per event.
* @see #publishEvents(EventTranslator[])
*/
public <A, B> void publishEvents(EventTranslatorTwoArg<E, A, B> translator, int batchStartsAt, int batchSize, A[] arg0, B[] arg1)
{
checkBounds(arg0, arg1, batchStartsAt, batchSize);
final long finalSequence = sequencer.next(batchSize);
translateAndPublishBatch(translator, arg0, arg1, batchStartsAt, batchSize, finalSequence);
}
示例13: tryPublishEvents
import com.lmax.disruptor.EventTranslatorTwoArg; //导入依赖的package包/类
/**
* Allows two user supplied arguments per event.
*
* @param translator The user specified translation for the event
* @param batchStartsAt The first element of the array which is within the batch.
* @param batchSize The actual size of the batch.
* @param arg0 An array of user supplied arguments, one element per event.
* @param arg1 An array of user supplied arguments, one element per event.
* @return true if the value was published, false if there was insufficient capacity.
* @see #tryPublishEvents(EventTranslator[])
*/
public <A, B> boolean tryPublishEvents(EventTranslatorTwoArg<E, A, B> translator, int batchStartsAt, int batchSize, A[] arg0, B[] arg1) {
checkBounds(arg0, arg1, batchStartsAt, batchSize);
try {
final long finalSequence = sequencer.tryNext(batchSize);
translateAndPublishBatch(translator, arg0, arg1, batchStartsAt, batchSize, finalSequence);
return true;
} catch (InsufficientCapacityException e) {
return false;
}
}
示例14: publishEvent
import com.lmax.disruptor.EventTranslatorTwoArg; //导入依赖的package包/类
/**
* Allows two user supplied arguments.
*
* @see #publishEvent(EventTranslator)
* @param translator The user specified translation for the event
* @param arg0 A user supplied argument.
* @param arg1 A user supplied argument.
*/
public <A, B> void publishEvent(EventTranslatorTwoArg<E, A, B> translator, A arg0, B arg1)
{
final long sequence = sequencer.next();
translateAndPublish(translator, sequence, arg0, arg1);
}
示例15: publishEvent
import com.lmax.disruptor.EventTranslatorTwoArg; //导入依赖的package包/类
/**
* Allows two user supplied arguments.
*
* @see #publishEvent(EventTranslator)
* @param translator The user specified translation for the event
* @param arg0 A user supplied argument.
* @param arg1 A user supplied argument.
*/
public <A, B> void publishEvent(EventTranslatorTwoArg<E, A, B> translator, A arg0, B arg1) {
final long sequence = sequencer.next();
translateAndPublish(translator, sequence, arg0, arg1);
}