Java threads: Concepts and principles
The concept of threads and processes in an operating system
The current operating system is a multitasking operating system. Multithreading is a way to multitask.
A process is an application running in memory. Each process has its own independent memory space. Multiple threads can be started in a process. In Windows, for example, a running EXE is a process.
A thread is an execution flow in a process. Multiple threads can run in a process. For example, many threads can run in the java.exe process. Threads always belong to a process, and multiple threads in a process share the process’s memory.
Process is an independent unit of system resource allocation and scheduling, each process has its own memory space and system resources. It takes much time and space to realize process scheduling, dispatching and switching in multi-processor environment. In order to improve the execution efficiency of the system, reduce the idling time of the processor and the time of scheduling switch, and facilitate system management, so there are threads, threads replaced the process of scheduling the basic function \
The main reason to use multithreading is to improve system resource utilization. Nowadays, cpus are mostly multicore, so if you use a single thread, you are using only one core, and the rest of the core is just sitting there
Multithreading is always visible at work. For example, our system Web server uses Tomcat, and Tomcat processes each request with one thread from the thread connection pool. For example, if we use a connection database, we will use a connection pool, such as Druid/C3P0/DBCP, etc., which uses multiple threads.
In addition to the frameworks above which have helped us to eliminate the “handwriting” multithreading problem, I will also use multithreading in my own system. For example, if we want to run a scheduled task, the link execution time and process of the task are very long, we use a thread pool to process the request of the scheduled task. The advantage of this is that the result can be returned to the caller in time, which can improve the throughput of the system.
There are two ways to implement multithreading in Java, one is to continue the Thread class, the other is to implement the Runable interface (actually, there should be three, and the other is to implement the Callable interface and use it in conjunction with the Future and Thread pool.
Implementation of Java threads
The Thread method is one of the more common, if you’re just thinking of a Thread. Without any other special requirements, Thread can be used.
Thread class inheritance
Implement the Runnable interface
Create threads using the Callable and Future interfaces.
The main method is actually a thread. In Java, all threads are started at the same time, and when and which are executed first depends on who gets the CPU resources first.
In Java, at least two threads are started each time a program runs. One is the main thread and the other is the garbage collector thread. Because every time a class is executed using a Java command, a JVM is actually started, and each JVM is starting a process in the operating system.
What is thread safety
As I understand it, in the Java world, thread-safe means multiple threads executing a class that consistently behaves correctly. Let’s say I have a count variable and I keep adding that count variable to the service method
public class UnsafeCountingServlet extends GenericServlet implements Servlet { private long count = 0; public long getCount() { return count; } public void service(ServletRequest servletRequest, ServletResponse servletResponse) throws ServletException, IOException { ++count; // To something else… }}
My personal approach to thread safety is as follows:
- Can we guarantee the atomicity of the operation? Consider whether the classes under the atomic package are enough for us to use.
- Can operation visibility be guaranteed? Consider
volatile
Are the keywords enough for us to use - If thread control is involved (such as how many threads can be used at a time, whether conditions triggered by the current thread depend on the results of other threads), consider CountDownLatch/Semaphore, etc.
- If it’s a set, consider
java.util.concurrent
The collection class under the package. - If synchronized is not enough, consider classes under the Lock package
- .
In general, it is to determine whether there is a thread safety problem first, if there is, then according to the specific situation to determine how to use to deal with the thread safety problem. Synchronized is awesome, but mindless use of synchronized affects the performance of our program.
Deadlocks understand? What can cause a deadlock?
The cause of deadlock can be summarized as follows: the current thread has resources needed by other threads, and the current thread waits for resources already owned by other threads without giving up its own resources. Deadlocks are generally avoided in the following ways:
- For example, we can use the Hash value to determine the lock order
- Minimize the scope of locking and wait until shared variables are operated on.
- Use a releasable timing lock.