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


Java AtomicReference.set方法代碼示例

本文整理匯總了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"));
}
 
開發者ID:junicorn,項目名稱:NiuBi,代碼行數:29,代碼來源:HttpRequestTest.java

示例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());
}
 
開發者ID:junicorn,項目名稱:NiuBi,代碼行數:30,代碼來源:HttpRequestTest.java

示例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);
}
 
開發者ID:traneio,項目名稱:future,代碼行數:19,代碼來源:NoFutureTest.java

示例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) {

        }
    };

}
 
開發者ID:akarnokd,項目名稱:RxJava3-preview,代碼行數:21,代碼來源:SafeSubscriberTest.java

示例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"));
}
 
開發者ID:junicorn,項目名稱:NiuBi,代碼行數:29,代碼來源:HttpRequestTest.java

示例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());
}
 
開發者ID:zugzug90,項目名稱:guava-mock,代碼行數:25,代碼來源:AbstractServiceTest.java

示例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"));
}
 
開發者ID:junicorn,項目名稱:NiuBi,代碼行數:29,代碼來源:HttpRequestTest.java

示例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"));
}
 
開發者ID:junicorn,項目名稱:NiuBi,代碼行數:26,代碼來源:HttpRequestTest.java

示例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"));
}
 
開發者ID:junicorn,項目名稱:NiuBi,代碼行數:29,代碼來源:HttpRequestTest.java

示例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());
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:32,代碼來源:ExpandSearchPhaseTests.java

示例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");
}
 
開發者ID:apache,項目名稱:incubator-netbeans,代碼行數:28,代碼來源:NetBeansClusterCreator.java

示例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());
}
 
開發者ID:akarnokd,項目名稱:RxJava3-preview,代碼行數:37,代碼來源:FlowableErrorHandlingTests.java

示例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());
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:12,代碼來源:AtomicReference9Test.java

示例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());
}
 
開發者ID:akarnokd,項目名稱:RxJava3-preview,代碼行數:36,代碼來源:ObservableOnErrorResumeNextViaFunctionTest.java

示例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()));
}
 
開發者ID:paul-hammant,項目名稱:googles-monorepo-demo,代碼行數:16,代碼來源:AbstractCacheTest.java


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