All Downloads are FREE. Search and download functionalities are using the official Maven repository.

examples.VirtualThreadExamples Maven / Gradle / Ivy

There is a newer version: 5.0.0.CR1
Show newest version
/*
 * Copyright (c) 2011-2023 Contributors to the Eclipse Foundation
 *
 * This program and the accompanying materials are made available under the
 * terms of the Eclipse Public License 2.0 which is available at
 * http://www.eclipse.org/legal/epl-2.0, or the Apache License, Version 2.0
 * which is available at https://www.apache.org/licenses/LICENSE-2.0.
 *
 * SPDX-License-Identifier: EPL-2.0 OR Apache-2.0
 */
package examples;

import io.vertx.core.*;
import io.vertx.core.buffer.Buffer;
import io.vertx.core.http.*;
import io.vertx.docgen.Source;

import java.util.concurrent.CompletionStage;

@Source
public class VirtualThreadExamples {

  public void gettingStarted(Vertx vertx) {

    AbstractVerticle verticle = new AbstractVerticle() {
      @Override
      public void start() {
        HttpClient client = vertx.createHttpClient();
        HttpClientRequest req = Future.await(client.request(
          HttpMethod.GET,
          8080,
          "localhost",
          "/"));
        HttpClientResponse resp = Future.await(req.send());
        int status = resp.statusCode();
        Buffer body = Future.await(resp.body());
      }
    };

    // Run the verticle a on virtual thread
    vertx.deployVerticle(verticle, new DeploymentOptions().setThreadingModel(ThreadingModel.VIRTUAL_THREAD));
  }

  private int counter;

  public void fieldVisibility1() {
    int value = counter;
    value += Future.await(getRemoteValue());
    // the counter value might have changed
    counter = value;
  }

  public void fieldVisibility2() {
    counter += Future.await(getRemoteValue());
  }

  private Future callRemoteService() {
    return null;
  }

  private Future getRemoteValue() {
    return null;
  }

  public void deployVerticle(Vertx vertx, int port) {
    vertx.deployVerticle(() -> new AbstractVerticle() {
      HttpServer server;
      @Override
      public void start() {
        server = vertx
          .createHttpServer()
          .requestHandler(req -> {
            Buffer res;
            try {
              res = Future.await(callRemoteService());
            } catch (Exception e) {
              req.response().setStatusCode(500).end();
              return;
            }
            req.response().end(res);
          });
        Future.await(server.listen(port));
      }
    }, new DeploymentOptions()
      .setThreadingModel(ThreadingModel.VIRTUAL_THREAD));
  }

  public void awaitingFutures1(HttpClientResponse response) {
    Buffer body = Future.await(response.body());
  }

  public void awaitingFutures2(HttpClientResponse response, CompletionStage completionStage) {
    Buffer body = Future.await(Future.fromCompletionStage(completionStage));
  }

  private Future getRemoteString() {
    return null;
  }

  public void awaitingMultipleFutures() {
    Future f1 = getRemoteString();
    Future f2 = getRemoteValue();
    CompositeFuture res = Future.await(Future.all(f1, f2));
    String v1 = res.resultAt(0);
    Integer v2 = res.resultAt(1);
  }

  public void threadLocalSupport1(String userId, HttpClient client) {
    ThreadLocal local = new ThreadLocal();
    local.set(userId);
    HttpClientRequest req = Future.await(client.request(HttpMethod.GET, 8080, "localhost", "/"));
    HttpClientResponse resp = Future.await(req.send());
    // Thread local remains the same since it's the same virtual thread
  }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy