Why will suddenly thought of such a method, if you work in not very common, but in the usual interview with regards to multiple threads, in most cases will be asked about this method, we also simply see the interview questions to say probably, but the real usage you might like me before it is fuzzy.
1. Look at a piece of code first. What do you think is the output order of the following codes? public static void main(String[] args) throws Exception { Thread t1 = new Thread(() -> { try { Thread.sleep(3000); } catch (InterruptedException e) { e.printStackTrace(); } system.out. println(” thread A executes “); }); Thread t2 = new Thread(() -> { try { Thread.sleep(2000); } catch (InterruptedException e) { e.printStackTrace(); } system.out. println(” thread B executes “); }); t1.start(); t2.start(); System.out.println(” I am the main thread “); } Yes, the result is exactly what most people would expect: the main thread executes first, then thread B, and finally thread A.
How much do you know about the join() method in multithreading?
Let’s change the code a little bit
public static void main(String[] args) throws Exception { Thread t1 = new Thread(() -> { try { Thread.sleep(3000); } catch (InterruptedException e) { e.printStackTrace(); } system.out. println(” thread A executes “); }); Thread t2 = new Thread(() -> { try { Thread.sleep(2000); } catch (InterruptedException e) { e.printStackTrace(); } system.out. println(” thread B executes “); }); t1.start(); t1.join(); t2.start(); System.out.println(” I am the main thread “); } what do you think the order of execution would be? Let’s take a look at the answer first! With that in mind, let’s look at what the join method does.
How much do you know about the join() method in multithreading?
Join () = join() = join() = join()
Then we go to see the above that added the join () code, the first open A thread A, followed by A thread calls the join () method into the blocking state, then thread must wait for thread A executed after down again, complete, thread A thread B open, sleep, on the main thread, thread B sleep over, implementation;
3, real scene demand I doing a crawler project last week, probably is that I want to open multiple threads at the same time in different site information, processing, and then returned to the front desk, it should pay attention to is that we have to wait for the front end of the thread to execute, can be returned to the front, then the join () method is very suitable for our requirements.
public static void main(String[] args) throws Exception { Thread t1 = new Thread(() -> { for (int i = 1; i < 4; I ++) {system.out.println (” thread A: “+ I); }}); Thread t2 = new Thread(() -> { for (int i = 1; i < 4; I ++) {system.out.println (” thread B: “+ I); }}); t1.start(); t2.start(); t1.join(); t2.join(); System.out.println(” end of crawl “); } In this way, thread A and thread B start execution and wait for the completion of all their execution before unified processing of the results. Let’s see what happens if we don’t apply the join() method.
How much do you know about the join() method in multithreading?
Sending the result back before the thread has finished executing clearly doesn’t meet our needs.
Join (); join(); join()
public static void main(String[] args) throws Exception { Thread t1 = new Thread(() -> { for (int i = 1; i < 4; i++) { try { Thread.sleep(1000); } catch (InterruptedException e) { e.printStackTrace(); } system.out. println(” thread A: “+ I); }}); Thread t2 = new Thread(() -> { for (int i = 1; i < 4; i++) { try { Thread.sleep(1000); } catch (InterruptedException e) { e.printStackTrace(); } system.out. println(” thread B: “+ I); }}); t1.start(); t2.start(); t1.join(); t2.join(); System.out.println(” end of crawl “); }public static void main(String[] args) throws Exception { Thread t1 = new Thread(() -> { for (int i = 1; i < 4; i++) { try { Thread.sleep(1000); } catch (InterruptedException e) { e.printStackTrace(); } system.out. println(” thread A: “+ I); }}); Thread t2 = new Thread(() -> { for (int i = 1; i < 4; i++) { try { Thread.sleep(1000); } catch (InterruptedException e) { e.printStackTrace(); } system.out. println(” thread B: “+ I); }}); t1.start(); t1.join(); t2.start(); t2.join(); System.out.println(” end of crawl “); } although the position of T1.join () is changed, the effect is very big. After changing the position, the code will become this meaning. T1 thread starts, and then T1 calls join(), so it must wait for T1 to complete execution before executing T2, so the multi-threaded code at this time, It’s actually a single thread, so let’s look at the results of the next two pieces of code.
First code result:
How much do you know about the join() method in multithreading?
Second code result:
How much do you know about the join() method in multithreading? Obviously, the first piece of code is the multithreaded result we want.
Welcome everyone to communicate ~ if you think this article is good, then forward attention to it, thank you for your support!