本文整理匯總了Java中java.util.concurrent.atomic.AtomicReference.set方法的典型用法代碼示例。如果您正苦於以下問題:Java AtomicReference.set方法的具體用法?Java AtomicReference.set怎麽用?Java AtomicReference.set使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類java.util.concurrent.atomic.AtomicReference
的用法示例。
在下文中一共展示了AtomicReference.set方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。
示例1: headWithEscapedMappedQueryParams
import java.util.concurrent.atomic.AtomicReference; //導入方法依賴的package包/類
/**
* Verify HEAD with escaped query parameters
*
* @throws Exception
*/
@Test
public void headWithEscapedMappedQueryParams() throws Exception {
Map<String, String> inputParams = new HashMap<String, String>();
inputParams.put("name", "us er");
inputParams.put("number", "100");
final Map<String, String> outputParams = new HashMap<String, String>();
final AtomicReference<String> method = new AtomicReference<String>();
handler = new RequestHandler() {
@Override
public void handle(Request request, HttpServletResponse response) {
method.set(request.getMethod());
outputParams.put("name", request.getParameter("name"));
outputParams.put("number", request.getParameter("number"));
response.setStatus(HTTP_OK);
}
};
HttpRequest request = head(url, inputParams, true);
assertTrue(request.ok());
assertEquals("HEAD", method.get());
assertEquals("us er", outputParams.get("name"));
assertEquals("100", outputParams.get("number"));
}
示例2: uploadProgressSend
import java.util.concurrent.atomic.AtomicReference; //導入方法依賴的package包/類
/**
* Verify progress callback when sending a file
*
* @throws Exception
*/
@Test
public void uploadProgressSend() throws Exception {
final AtomicReference<String> body = new AtomicReference<String>();
handler = new RequestHandler() {
@Override
public void handle(Request request, HttpServletResponse response) {
body.set(new String(read()));
response.setStatus(HTTP_OK);
}
};
final File file = File.createTempFile("post", ".txt");
new FileWriter(file).append("hello").close();
final AtomicLong tx = new AtomicLong(0);
UploadProgress progress = new UploadProgress() {
public void onUpload(long transferred, long total) {
assertEquals(file.length(), total);
assertEquals(tx.incrementAndGet(), transferred);
}
};
post(url).bufferSize(1).progress(progress).send(file).code();
assertEquals(file.length(), tx.get());
}
示例3: getInterrupted
import java.util.concurrent.atomic.AtomicReference; //導入方法依賴的package包/類
@Test
public void getInterrupted() throws CheckedFutureException, InterruptedException {
AtomicReference<Throwable> cause = new AtomicReference<>();
Thread t = new Thread() {
@Override
public void run() {
try {
noFuture.get(Duration.ofMinutes(1));
} catch (CheckedFutureException e) {
cause.set(e.getCause());
}
}
};
t.start();
t.interrupt();
t.join();
assertTrue(cause.get() instanceof InterruptedException);
}
示例4: OBSERVER_SUCCESS
import java.util.concurrent.atomic.AtomicReference; //導入方法依賴的package包/類
private static Subscriber<String> OBSERVER_SUCCESS(final AtomicReference<Throwable> onError) {
return new DefaultSubscriber<String>() {
@Override
public void onComplete() {
}
@Override
public void onError(Throwable e) {
onError.set(e);
}
@Override
public void onNext(String args) {
}
};
}
示例5: getWithMappedQueryParams
import java.util.concurrent.atomic.AtomicReference; //導入方法依賴的package包/類
/**
* Verify GET with query parameters
*
* @throws Exception
*/
@Test
public void getWithMappedQueryParams() throws Exception {
Map<String, String> inputParams = new HashMap<String, String>();
inputParams.put("name", "user");
inputParams.put("number", "100");
final Map<String, String> outputParams = new HashMap<String, String>();
final AtomicReference<String> method = new AtomicReference<String>();
handler = new RequestHandler() {
@Override
public void handle(Request request, HttpServletResponse response) {
method.set(request.getMethod());
outputParams.put("name", request.getParameter("name"));
outputParams.put("number", request.getParameter("number"));
response.setStatus(HTTP_OK);
}
};
HttpRequest request = get(url, inputParams, false);
assertTrue(request.ok());
assertEquals("GET", method.get());
assertEquals("user", outputParams.get("name"));
assertEquals("100", outputParams.get("number"));
}
示例6: testAwaitTerminated_FailedService
import java.util.concurrent.atomic.AtomicReference; //導入方法依賴的package包/類
public void testAwaitTerminated_FailedService() throws Exception {
final ManualSwitchedService service = new ManualSwitchedService();
final AtomicReference<Throwable> exception = Atomics.newReference();
Thread waiter = new Thread() {
@Override public void run() {
try {
service.awaitTerminated();
fail("Expected an IllegalStateException");
} catch (Throwable t) {
exception.set(t);
}
}
};
waiter.start();
service.startAsync();
service.notifyStarted();
assertEquals(State.RUNNING, service.state());
service.notifyFailed(EXCEPTION);
assertEquals(State.FAILED, service.state());
waiter.join(LONG_TIMEOUT_MILLIS);
assertFalse(waiter.isAlive());
assertThat(exception.get()).isInstanceOf(IllegalStateException.class);
assertEquals(EXCEPTION, exception.get().getCause());
}
示例7: headWithMappedQueryParams
import java.util.concurrent.atomic.AtomicReference; //導入方法依賴的package包/類
/**
* Verify HEAD with query parameters
*
* @throws Exception
*/
@Test
public void headWithMappedQueryParams() throws Exception {
Map<String, String> inputParams = new HashMap<String, String>();
inputParams.put("name", "user");
inputParams.put("number", "100");
final Map<String, String> outputParams = new HashMap<String, String>();
final AtomicReference<String> method = new AtomicReference<String>();
handler = new RequestHandler() {
@Override
public void handle(Request request, HttpServletResponse response) {
method.set(request.getMethod());
outputParams.put("name", request.getParameter("name"));
outputParams.put("number", request.getParameter("number"));
response.setStatus(HTTP_OK);
}
};
HttpRequest request = head(url, inputParams, false);
assertTrue(request.ok());
assertEquals("HEAD", method.get());
assertEquals("user", outputParams.get("name"));
assertEquals("100", outputParams.get("number"));
}
示例8: getWithVarargsQueryParams
import java.util.concurrent.atomic.AtomicReference; //導入方法依賴的package包/類
/**
* Verify GET with query parameters
*
* @throws Exception
*/
@Test
public void getWithVarargsQueryParams() throws Exception {
final Map<String, String> outputParams = new HashMap<String, String>();
final AtomicReference<String> method = new AtomicReference<String>();
handler = new RequestHandler() {
@Override
public void handle(Request request, HttpServletResponse response) {
method.set(request.getMethod());
outputParams.put("name", request.getParameter("name"));
outputParams.put("number", request.getParameter("number"));
response.setStatus(HTTP_OK);
}
};
HttpRequest request = get(url, false, "name", "user", "number", "100");
assertTrue(request.ok());
assertEquals("GET", method.get());
assertEquals("user", outputParams.get("name"));
assertEquals("100", outputParams.get("number"));
}
示例9: putWithMappedQueryParams
import java.util.concurrent.atomic.AtomicReference; //導入方法依賴的package包/類
/**
* Verify PUT with query parameters
*
* @throws Exception
*/
@Test
public void putWithMappedQueryParams() throws Exception {
Map<String, String> inputParams = new HashMap<String, String>();
inputParams.put("name", "user");
inputParams.put("number", "100");
final Map<String, String> outputParams = new HashMap<String, String>();
final AtomicReference<String> method = new AtomicReference<String>();
handler = new RequestHandler() {
@Override
public void handle(Request request, HttpServletResponse response) {
method.set(request.getMethod());
outputParams.put("name", request.getParameter("name"));
outputParams.put("number", request.getParameter("number"));
response.setStatus(HTTP_OK);
}
};
HttpRequest request = put(url, inputParams, false);
assertTrue(request.ok());
assertEquals("PUT", method.get());
assertEquals("user", outputParams.get("name"));
assertEquals("100", outputParams.get("number"));
}
示例10: testSkipPhase
import java.util.concurrent.atomic.AtomicReference; //導入方法依賴的package包/類
public void testSkipPhase() throws IOException {
MockSearchPhaseContext mockSearchPhaseContext = new MockSearchPhaseContext(1);
mockSearchPhaseContext.searchTransport = new SearchTransportService(
Settings.builder().put("search.remote.connect", false).build(), null, null) {
@Override
void sendExecuteMultiSearch(MultiSearchRequest request, SearchTask task, ActionListener<MultiSearchResponse> listener) {
fail("no collapsing here");
}
};
SearchHits hits = new SearchHits(new SearchHit[]{new SearchHit(1, "ID", new Text("type"),
Collections.singletonMap("someField", new SearchHitField("someField", Collections.singletonList(null)))),
new SearchHit(2, "ID2", new Text("type"),
Collections.singletonMap("someField", new SearchHitField("someField", Collections.singletonList(null))))}, 1, 1.0F);
InternalSearchResponse internalSearchResponse = new InternalSearchResponse(hits, null, null, null, false, null, 1);
SearchResponse response = mockSearchPhaseContext.buildSearchResponse(internalSearchResponse, null);
AtomicReference<SearchResponse> reference = new AtomicReference<>();
ExpandSearchPhase phase = new ExpandSearchPhase(mockSearchPhaseContext, response, r ->
new SearchPhase("test") {
@Override
public void run() throws IOException {
reference.set(r);
}
}
);
phase.run();
mockSearchPhaseContext.assertNoFailure();
assertNotNull(reference.get());
assertEquals(1, mockSearchPhaseContext.phasesExecuted.get());
}
示例11: findConf
import java.util.concurrent.atomic.AtomicReference; //導入方法依賴的package包/類
private static File findConf(AtomicReference<File> parent, List<? super File> clusters) {
String nbdirs = System.getProperty("netbeans.dirs");
if (nbdirs != null) {
StringTokenizer tok = new StringTokenizer(nbdirs, File.pathSeparator); // NOI18N
while (tok.hasMoreElements()) {
File cluster = new File(tok.nextToken());
clusters.add(cluster);
if (!cluster.exists()) {
continue;
}
if (parent.get() == null) {
parent.set(cluster.getParentFile());
}
if (!parent.get().equals(cluster.getParentFile())) {
// we can handle only case when all clusters are in
// the same directory these days
return null;
}
}
}
return new File(new File(parent.get(), "etc"), "netbeans.clusters");
}
示例12: testOnNextErrorAcrossThread
import java.util.concurrent.atomic.AtomicReference; //導入方法依賴的package包/類
/**
* Test that an error from a user provided Observer.onNext is handled and emitted to the onError
* even when done across thread boundaries with observeOn
* @throws InterruptedException if the test is interrupted
*/
@Test
public void testOnNextErrorAcrossThread() throws InterruptedException {
final CountDownLatch latch = new CountDownLatch(1);
final AtomicReference<Throwable> caughtError = new AtomicReference<Throwable>();
Flowable<Long> o = Flowable.interval(50, TimeUnit.MILLISECONDS);
Subscriber<Long> observer = new DefaultSubscriber<Long>() {
@Override
public void onComplete() {
System.out.println("completed");
latch.countDown();
}
@Override
public void onError(Throwable e) {
System.out.println("error: " + e);
caughtError.set(e);
latch.countDown();
}
@Override
public void onNext(Long args) {
throw new RuntimeException("forced failure");
}
};
o.observeOn(Schedulers.newThread())
.safeSubscribe(observer);
latch.await(2000, TimeUnit.MILLISECONDS);
assertNotNull(caughtError.get());
}
示例13: testGetPlainSet
import java.util.concurrent.atomic.AtomicReference; //導入方法依賴的package包/類
/**
* getPlain returns the last value set
*/
public void testGetPlainSet() {
AtomicReference<Integer> ai = new AtomicReference<>(one);
assertEquals(one, ai.getPlain());
ai.set(two);
assertEquals(two, ai.getPlain());
ai.set(m3);
assertEquals(m3, ai.getPlain());
}
示例14: testResumeNextWithAsyncExecution
import java.util.concurrent.atomic.AtomicReference; //導入方法依賴的package包/類
@Test
public void testResumeNextWithAsyncExecution() {
final AtomicReference<Throwable> receivedException = new AtomicReference<Throwable>();
Disposable s = mock(Disposable.class);
TestObservable w = new TestObservable(s, "one");
Function<Throwable, Observable<String>> resume = new Function<Throwable, Observable<String>>() {
@Override
public Observable<String> apply(Throwable t1) {
receivedException.set(t1);
return Observable.just("twoResume", "threeResume");
}
};
Observable<String> o = Observable.unsafeCreate(w).onErrorResumeNext(resume);
Observer<String> observer = TestHelper.mockObserver();
o.subscribe(observer);
try {
w.t.join();
} catch (InterruptedException e) {
fail(e.getMessage());
}
verify(observer, Mockito.never()).onError(any(Throwable.class));
verify(observer, times(1)).onComplete();
verify(observer, times(1)).onNext("one");
verify(observer, Mockito.never()).onNext("two");
verify(observer, Mockito.never()).onNext("three");
verify(observer, times(1)).onNext("twoResume");
verify(observer, times(1)).onNext("threeResume");
assertNotNull(receivedException.get());
}
示例15: testGetIfPresent
import java.util.concurrent.atomic.AtomicReference; //導入方法依賴的package包/類
public void testGetIfPresent() {
final AtomicReference<Object> valueRef = new AtomicReference<Object>();
Cache<Object, Object> cache = new AbstractCache<Object, Object>() {
@Override
public Object getIfPresent(Object key) {
return valueRef.get();
}
};
assertNull(cache.getIfPresent(new Object()));
Object newValue = new Object();
valueRef.set(newValue);
assertSame(newValue, cache.getIfPresent(new Object()));
}