// 同时使用两种实现多线程的方式
public class BothRunnableThread {public static void main(String[] args) {new Thread(new Runnable() {@Overridepublic void run() {System.out.println("Runnable");}}) {public void run() {System.out.println("Thread");}}.start();}}
输出结果
Thread
/* What will be run. */private Runnable target;@Override
public void run() {if (target != null) {target.run();}
}
在传入Runnable对象之后,run方法会默认执行Runnable的run方法,但是后面我们又重写了Thread类的runnable的方法,导致原本的run方法被覆盖,并不会运行,所以执行的是Thread重写的run方法
// 线程池创建线程
public class Threadpool {public static void main(String[] args) {ExecutorService executorService = Executors.newCachedThreadPool();for (int i = 0; i < 10; i++) {executorService.submit(new Task(){});}}
}class Task implements Runnable {@Overridepublic void run() {try {Thread.sleep(500);} catch (InterruptedException e) {e.printStackTrace();}System.out.println(Thread.currentThread().getName());}
}
static class DefaultThreadFactory implements ThreadFactory {private static final AtomicInteger poolNumber = new AtomicInteger(1);private final ThreadGroup group;private final AtomicInteger threadNumber = new AtomicInteger(1);private final String namePrefix;DefaultThreadFactory() {SecurityManager s = System.getSecurityManager();group = (s != null) ? s.getThreadGroup() :Thread.currentThread().getThreadGroup();namePrefix = "pool-" +poolNumber.getAndIncrement() +"-thread-";}public Thread newThread(Runnable r) {Thread t = new Thread(group, r,namePrefix + threadNumber.getAndIncrement(),0);if (t.isDaemon())t.setDaemon(false);if (t.getPriority() != Thread.NORM_PRIORITY)t.setPriority(Thread.NORM_PRIORITY);return t;}}