This is the third day of my participation in Gwen Challenge

Author: JavaGieGie

Wechat official account: Java development zero to one

preface

In the last installment of squat series, we introduced the basics of multithreading, and you usually know something different.

“Squat can also enter the factory” multi-threading this several basic interview questions, 80% of small partners on the first answer wrong

Today continue to explain the relative basic theory of multithreading knowledge points, if you are a novice or do not know much about multithreading, do not think of going up on the liver actual combat class, useless, just a bug you can not see what the reason, flower GIe strongly suggest to follow this series to finish (manual dog head protection body).

I: yo shout, dog stay son today how not at home self-cultivation, also don’t accompany your girl friend, come to the company to write bug again

Dog remaining son: hey hey, how may not accompany girlfriend, we every day inseparable

I:…

Dog remaining son: take advantage of today nobody, walk, pit see, I want to be honest with you relative.

The body of the

I: dog leftover son, please listen to the first question, daemon thread and user thread have what distinction?

Java has two kinds of threads: daemons and User threads. The only difference between the two is that the JVM exits automatically if all the threads in the JVM are daemons. However, if there is one or more non-daemons, the thread will not exit.

I: Yesterday I asked you about notify. Do you know the difference between notify and notifyAll in Java? Or how do we choose which one to use?

Yesterday’s thing incredibly still remember, your memory can also ah, I have forgotten.

, notify can’t wake up a specific thread specified (says the Internet, I followed that tell you as to why the back), may cause the signal loss such a question, is it only in a thread waiting at home, and notifyAll will wake all waiting threads, and allow them to compete for the locks, while the efficiency is not high, However, at least one thread is guaranteed to continue executing. If you want to use notify, you must make sure that two things happen.

  • Only one thread needs to be awakened at most at a time.
  • All threads waiting to wake up have the same processing logic. For example, different threads created using the Runnable interface instance, or multiple instances of the same Thread subclass new.

Me: Don’t be complacent, this is all appetizers, one more question, why wait can only be used in code blocks?

What? Wait can only be used in blocks of code. That is… Maybe Wait is a neat freak and likes to be alone.

I: you step a horse….

Oh… Now that I think of it, we can go the other way: if WAIT does not require that it be in a synchronized block, the following error may occur.

Let’s look at the code for thread-safe queues using Wait and notify:

class BlockingQueue {
    Queue<String> buffer = new LinkedList<String>();
 
    //
    public void give(String data) {
        buffer.add(data);
        notify();                   // Since someone may be waiting in take!
    }
 
    public String take(a) throws InterruptedException {
        while (buffer.isEmpty())    // don't use "if" due to spurious wakeups.
            wait();
        returnbuffer.remove(); }}Copy the code
  1. Consumer A calltake()At this time,buffer.isEmpty()To true;
  2. Consumer A enters the while, callingwait()Method before producer B calls a completegive()(buffer.add(data) and notify()));
  3. And then consumer A callswait(), but missed the producer B callnotify();
  4. If no other producer then calls the give() method, the thread of consumer A will wait.

Me: I can’t help but give you a thumbs-up for this explanation. Do you know what locks are in Java?

The concept of locking can also be seen after learning Gie's volatile.

It doesn’t matter if it’s an anti-theft lock, a gold lock, or a fingerprint lock, even if it’s a straw rope, a bicycle, or even a bunch of stuff. It doesn’t matter what the lock looks like, but what it represents: whoever holds it has independent access to critical resources.

Me: Have you ever learned what a thread deadlock is?

A deadlock is when two or more threads are waiting for a resource to be released during execution, so the thread is blocked indefinitely and the system is in a deadlock state.

As shown in the figure, thread A holds resource 2 and thread B holds resource 1. They both want to claim resources from each other at the same time, so the two threads wait for each other and enter A deadlock state.

Me: Do you know the four necessary conditions for a deadlock?

What do we not know about this family? I’ll list it for you.

  1. Mutually exclusive: A thread (process) is exclusive to an allocated resource, that is, only one process can occupy the resource at any time.
  2. Request and hold conditions: when a thread (process) is blocked by requesting a resource, it holds on to the acquired resource.
  3. Non-expropriation condition: a thread (process) cannot deprive a resource acquired by another thread until it is used up. The resource can be released only after it is used up.
  4. Circular wait condition: When a deadlock occurs, the waiting thread (process) must form a loop, which causes a permanent block.

Me: Since you know the conditions for a deadlock, you must know how to avoid it?

If you want to avoid deadlocks, you need any one of the four essential conditions for saboteur.

  1. Break mutex conditions: This route is blocked because we use locks to make them mutually exclusive.
  2. Break request and hold conditions: request all resources at once.
  3. Destruction not deprivation condition: a thread in possession of resources can try to apply for other resources, if not, can actively release the resources it has.
  4. Break the loop waiting condition: Apply for resources in a certain order, and release resources in reverse order.

I: this wave answer of good, last night whether secretly prepared. Dog left son please continue to listen to the question, context switch know?

Please respect me and call me Dog.

When it comes to context switching, we need to know what context is, which is literally the contents of CPU registers and program counters at a certain point in time.

Extension: Each thread has a program counter (to record the next instruction to execute), a set of registers (to hold the current thread’s work variables), and a stack (to record the execution history, where each frame holds a procedure that was called but not returned).

Registers: Registers are the internal MEMORY of the CPU, which is responsible for storing small but fast tasks that have been, are, and will be executed, as opposed to the relatively slow RAM main memory outside the CPU.

Program counter: A program counter is a special register that indicates where the instruction sequence CPU is currently executing. It stores the location where the instruction is being executed or will be executed next time.

With a general understanding of the context, context switch is easy. It means that after the current task is executed, the CPU will save its state before switching to the next task, so that it can continue to execute the task when switching back to the next time. The task from saving to reloading is a context switch.

If it’s not clear, there are three steps.

  1. Suspend a process and store the state (context) of the process in the CPU in memory.
  2. Retrieves the context of the next process in memory and restores that process to a CPU register.
  3. Resuming the process by jumping to the position indicated by the program counter, where the code was executed when the process was interrupted.

Me: Tell good detail, suddenly good enchanted, that context switch will bring what problem?

After reading the above introduction, we should have a feeling that if the high concurrency situation, frequent context switching will lead to the system serial execution, running speed is greatly reduced.

  • Direct consumption: includes CPU registers that need to be saved and loaded, and system scheduler code that needs to be executed.
  • Indirect consumption: CPU in order to accelerate the speed of execution, the common data cached, but when a context switch (that is, the CPU to perform different thread code), the cached content originally very much did not use value, therefore the CPU will to cache, it also cause the thread is scheduled to run after the first start the speed will be slow.

Extension: In order to avoid the overhead of frequent context switching, the thread scheduler will set a minimum execution time for each thread that is scheduled to reduce the number of context switching, thus improving performance, but the disadvantage is also obvious, that is, it will slow down the response time.

Me: Why don’t you tell me what volatile is?

No, no, I’m tired to death today, I need a rest, tomorrow we fight again.

conclusion

Multi-threaded knowledge is very large, involving many aspects, especially for the new contact with multi-threaded partners, it is very difficult to understand the concept of lock, context, want to really master all the knowledge involved in each question, How to use Wait/Notify to implement the producer-consumer mode, how to schedule threads, how to convert Java code step by step to be executed by CPU, how to start and interrupt threads, and how to communicate between threads.

GieGie will gradually guide you to master these flowers in the future, and some big knowledge points will be taken out for individual explanation. I hope you continue to pay attention to these flowers.

Pay attention to avoid getting lost

The above is the whole content of this issue, if there is any mistake, please leave a message for advice, thank you very much. I’m GieGie, feel free to leave a comment and we’ll see you next time at 🦮.

The article continues to update, you can wechat search “Java development zero to one” for the first time to read, the follow-up will continue to update Java interview and all kinds of knowledge points, interested partners welcome to pay attention to, learn together, ha 🐮🥃.

Original is not easy, how can you bear to whoring for nothing, if you think this article is a little useful to you, thank old tie for this article to like, comment or forward, because this will be my output more quality articles of power, thank you!