當前位置: 首頁>>代碼示例>>Java>>正文


Java AtomicLong.decrementAndGet方法代碼示例

本文整理匯總了Java中java.util.concurrent.atomic.AtomicLong.decrementAndGet方法的典型用法代碼示例。如果您正苦於以下問題:Java AtomicLong.decrementAndGet方法的具體用法?Java AtomicLong.decrementAndGet怎麽用?Java AtomicLong.decrementAndGet使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在java.util.concurrent.atomic.AtomicLong的用法示例。


在下文中一共展示了AtomicLong.decrementAndGet方法的8個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: tick

import java.util.concurrent.atomic.AtomicLong; //導入方法依賴的package包/類
void tick() {
    AtomicLong localCounter = this.counter;
    if (localCounter.getAndIncrement() == 0) {
        int emitted = 0;
        do {
            if (this.requested.get() > 0) {
                Object o = this.buffer.poll();
                if (o != null) {
                    if (this.buffer.isCompleted(o)) {
                        this.child.onCompleted();
                    } else {
                        this.buffer.accept(o, this.child);
                        emitted++;
                        this.requested.decrementAndGet();
                    }
                }
            }
        } while (localCounter.decrementAndGet() > 0);
        if (emitted > 0) {
            for (MultiSourceRequestableSubscriber<T, R> s : this.subscribers) {
                s.requestUpTo((long) emitted);
            }
        }
    }
}
 
開發者ID:JackChan1999,項目名稱:boohee_v5.6,代碼行數:26,代碼來源:OnSubscribeCombineLatest.java

示例2: emitItem

import java.util.concurrent.atomic.AtomicLong; //導入方法依賴的package包/類
private void emitItem(GroupState<K, T> groupState, Object item) {
    Queue<Object> q = groupState.buffer;
    AtomicLong keyRequested = groupState.requested;
    REQUESTED.decrementAndGet(this);
    if (keyRequested == null || keyRequested.get() <= 0 || !(q == null || q.isEmpty())) {
        q.add(item);
        BUFFERED_COUNT.incrementAndGet(this);
        if (groupState.count.getAndIncrement() == 0) {
            pollQueue(groupState);
        }
    } else {
        nl.accept(groupState.getObserver(), item);
        if (keyRequested.get() != Long.MAX_VALUE) {
            keyRequested.decrementAndGet();
        }
    }
    requestMoreIfNecessary();
}
 
開發者ID:JackChan1999,項目名稱:boohee_v5.6,代碼行數:19,代碼來源:OperatorGroupBy.java

示例3: checkExecution

import java.util.concurrent.atomic.AtomicLong; //導入方法依賴的package包/類
private void checkExecution(final RPromise<Long> result, final AtomicReference<Throwable> failed,
        final AtomicLong count, final AtomicLong executed) {
    if (executed.decrementAndGet() == 0) {
        if (failed.get() != null) {
            if (count.get() > 0) {
                RedisException ex = new RedisException("" + count.get() + " keys has been deleted. But one or more nodes has an error", failed.get());
                result.tryFailure(ex);
            } else {
                result.tryFailure(failed.get());
            }
        } else {
            result.trySuccess(count.get());
        }
    }
}
 
開發者ID:qq1588518,項目名稱:JRediClients,代碼行數:16,代碼來源:RedissonKeys.java

示例4: call

import java.util.concurrent.atomic.AtomicLong; //導入方法依賴的package包/類
public Subscriber<? super T> call(final Subscriber<? super T> child) {
    final AtomicLong requested = new AtomicLong();
    child.setProducer(new Producer() {
        public void request(long n) {
            BackpressureUtils.getAndAddRequest(requested, n);
        }
    });
    return new Subscriber<T>(child) {
        public void onStart() {
            request(Long.MAX_VALUE);
        }

        public void onCompleted() {
            child.onCompleted();
        }

        public void onError(Throwable e) {
            child.onError(e);
        }

        public void onNext(T t) {
            if (requested.get() > 0) {
                child.onNext(t);
                requested.decrementAndGet();
            } else if (OperatorOnBackpressureDrop.this.onDrop != null) {
                OperatorOnBackpressureDrop.this.onDrop.call(t);
            }
        }
    };
}
 
開發者ID:JackChan1999,項目名稱:boohee_v5.6,代碼行數:31,代碼來源:OperatorOnBackpressureDrop.java

示例5: pollQueue

import java.util.concurrent.atomic.AtomicLong; //導入方法依賴的package包/類
void pollQueue() {
    int emitted = 0;
    AtomicLong localRequested = this.requested;
    AtomicLong localCounter = this.counter;
    do {
        localCounter.set(1);
        long produced = 0;
        long r = localRequested.get();
        while (!this.child.isUnsubscribed()) {
            if (this.finished) {
                Throwable error = this.error;
                if (error != null) {
                    this.queue.clear();
                    this.child.onError(error);
                    return;
                } else if (this.queue.isEmpty()) {
                    this.child.onCompleted();
                    return;
                }
            }
            if (r > 0) {
                Object o = this.queue.poll();
                if (o != null) {
                    this.child.onNext(this.on.getValue(o));
                    r--;
                    emitted++;
                    produced++;
                }
            }
            if (produced > 0 && localRequested.get() != Long.MAX_VALUE) {
                localRequested.addAndGet(-produced);
            }
        }
        return;
    } while (localCounter.decrementAndGet() > 0);
    if (emitted > 0) {
        request((long) emitted);
    }
}
 
開發者ID:JackChan1999,項目名稱:boohee_v5.6,代碼行數:40,代碼來源:OperatorObserveOn.java

示例6: tick

import java.util.concurrent.atomic.AtomicLong; //導入方法依賴的package包/類
void tick() {
    Object[] observers = this.observers;
    if (observers != null && getAndIncrement() == 0) {
        int length = observers.length;
        Observer<? super R> child = this.child;
        AtomicLong requested = this.requested;
        while (true) {
            RxRingBuffer buffer;
            Object[] vs = new Object[length];
            boolean allHaveValues = true;
            for (int i = 0; i < length; i++) {
                buffer = ((InnerSubscriber) observers[i]).items;
                Object n = buffer.peek();
                if (n == null) {
                    allHaveValues = false;
                } else if (buffer.isCompleted(n)) {
                    child.onCompleted();
                    this.childSubscription.unsubscribe();
                    return;
                } else {
                    vs[i] = buffer.getValue(n);
                }
            }
            if (requested.get() > 0 && allHaveValues) {
                try {
                    child.onNext(this.zipFunction.call(vs));
                    requested.decrementAndGet();
                    this.emitted++;
                    for (Object obj : observers) {
                        buffer = ((InnerSubscriber) obj).items;
                        buffer.poll();
                        if (buffer.isCompleted(buffer.peek())) {
                            child.onCompleted();
                            this.childSubscription.unsubscribe();
                            return;
                        }
                    }
                    if (this.emitted > THRESHOLD) {
                        for (Object obj2 : observers) {
                            ((InnerSubscriber) obj2).requestMore((long) this.emitted);
                        }
                        this.emitted = 0;
                    }
                } catch (Throwable e) {
                    Exceptions.throwOrReport(e, child, vs);
                    return;
                }
            } else if (decrementAndGet() <= 0) {
                return;
            }
        }
    }
}
 
開發者ID:JackChan1999,項目名稱:boohee_v5.6,代碼行數:54,代碼來源:OperatorZip.java

示例7: checkCreated

import java.util.concurrent.atomic.AtomicLong; //導入方法依賴的package包/類
@VisibleForTesting
Boolean checkCreated(Context context, Key key, String id, AtomicLong retry, Duration interval) {

    Key.KeyBuilder builder = Key.build(key);

    while (true) {

        Key current = builder.build();

        if (context.getState(current) == StateType.TERMINATE) {

            log.trace("Reconciling create terminated : {}", id);

            return FALSE;

        }

        Order order = context.findOrder(current, id);

        if (order != null) {

            log.trace("Reconcile create succeeded : {}", id);

            return TRUE;

        }

        if (retry.decrementAndGet() < 0) {
            break;
        }

        try {

            Thread.sleep(interval.toMillis());

            builder.timestamp(current.getTimestamp().plus(interval));

        } catch (InterruptedException e) {

            log.trace("Reconciling create interrupted : {}", id);

            return FALSE;

        }

    }

    log.trace("Reconcile create failed : {}", id);

    return FALSE;

}
 
開發者ID:after-the-sunrise,項目名稱:cryptotrader,代碼行數:53,代碼來源:TemplateAgent.java

示例8: checkCancelled

import java.util.concurrent.atomic.AtomicLong; //導入方法依賴的package包/類
@VisibleForTesting
Boolean checkCancelled(Context context, Key key, String id, AtomicLong retry, Duration interval) {

    Key.KeyBuilder builder = Key.build(key);

    while (true) {

        Key current = builder.build();

        if (context.getState(current) == StateType.TERMINATE) {

            log.trace("Reconciling cancel terminated : {}", id);

            return FALSE;

        }

        Order order = context.findOrder(current, id);

        if (order == null || !TRUE.equals(order.getActive())) {

            log.trace("Reconcile cancel succeeded : {}", id);

            return TRUE;

        }

        if (retry.decrementAndGet() < 0) {
            break;
        }

        try {

            Thread.sleep(interval.toMillis());

            builder.timestamp(current.getTimestamp().plus(interval));

        } catch (InterruptedException e) {

            log.trace("Reconciling cancel interrupted : {}", id);

            return FALSE;

        }

    }

    log.trace("Reconcile cancel failed : {}", id);

    return FALSE;

}
 
開發者ID:after-the-sunrise,項目名稱:cryptotrader,代碼行數:53,代碼來源:TemplateAgent.java


注:本文中的java.util.concurrent.atomic.AtomicLong.decrementAndGet方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。