我需要一个多线程的Java 8示例。
我需要能够手动选择线程的数量。
在下面的示例中,我在使用Thread.currentThread().getName()时遇到了问题,我需要使用lambda表达式。
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
public class Thread {
public static void main(String args[]) {
ExecutorService service = Executors.newFixedThreadPool(10);
for (int i =0; i<100; i++){
service.submit(new Task(i));
}
}
final class Task implements Runnable{
private int taskId;
public Task(int id){
this.taskId = id;
}
@Override
public void run() {
System.out.println("Task ID : " + this.taskId +" performed by "
+ Thread.currentThread().getName());
}
}发布于 2016-09-16 01:08:56
使用IntStream可以很容易地实现Lambda。
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.stream.IntStream;
public class ThreadLauncher
{
public static void main(String args[])
{
ExecutorService service = Executors.newFixedThreadPool(10);
IntStream.range(0, 100).forEach(i -> service.submit(new Task(i)));
}
}
final class Task
implements Runnable
{
private int taskId;
public Task(int id)
{
this.taskId = id;
}
@Override
public void run()
{
System.out.println("Task ID : " + this.taskId + " performed by "
+ Thread.currentThread().getName());
}
}发布于 2016-09-16 03:01:13
对于lambda,我建议:
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
public class Main {
public static void main(String args[]) {
ExecutorService service = Executors.newFixedThreadPool(10);
for (int i =0; i < 100; i++) {
final int fi = i;
service.submit(() -> System.out.println("Task ID : " + fi + " performed by "
+ Thread.currentThread().getName()));
}
}
}或者如果你想在lambdas上全力以赴
public class Main {
public static void main(String args[]) {
ExecutorService service = Executors.newFixedThreadPool(10);
IntStream.range(0, 100)
.forEach(i -> service.submit(()
-> System.out.println("Task ID : " + i + " performed by " + Thread.currentThread().getName())));
}
}发布于 2020-03-12 15:20:37
希望这对某些人有帮助。一个由3个Thread组成的池被创建并并行运行。
public class threadClass {
ExecutorService executor = Executors.newFixedThreadPool(3);
public void multiThread() {
Runnable thread1 = () -> {
// perform some operation
System.out.println(Thread.currentThread().getName());
};
Runnable thread2 = () -> {
// perform some operation
System.out.println(Thread.currentThread().getName());
};
Runnable thread3 = () -> {
// perform some operation
System.out.println(Thread.currentThread().getName());
};
executor.execute(thread1);
executor.execute(thread2);
executor.execute(thread3);
executor.shutdown();
}}
https://stackoverflow.com/questions/39515447
复制相似问题