2020 New Java Interview Questions - Multithreading (1)
1. What is the difference between parallelism and concurrency?
Parallel refers to two or more events occurring at the same time; concurrency refers to two or more events occurring at the same time interval.
Parallelism is multiple events on different entities, and concurrency is multiple events on the same entity.
Parallelism is the "simultaneous" processing of multiple tasks on one processor, and concurrency is the simultaneous processing of multiple tasks on multiple processors. Such as hadoop distributed cluster.
So the goal of concurrent programming is to make full use of each core of the processor to achieve the highest processing performance.
(Recommended related video tutorials: java video)
2. What is the difference between threads and processes?
In short, a process is the basic unit for program running and resource allocation. A program has at least one process, and a process has at least one thread. The process has an independent memory unit during execution, and multiple threads share memory resources, reducing the number of switching times and making it more efficient. A thread is an entity of a process, the basic unit of CPU scheduling and dispatch, and a basic unit that is smaller than a program and can run independently. Multiple threads in the same process can execute concurrently.
3. What is the daemon thread?
The daemon thread (daemon thread) is a service thread. To be precise, it serves other threads.
4. What are the ways to create a thread?
(1) Inherit the Thread class to create a thread class
Define a subclass of the Thread class and override the run method of the class. The method body of the run method represents what the thread wants to complete. Task. Therefore, the run() method is called the execution body.
Create an instance of the Thread subclass, that is, create a thread object.
Call the start() method of the thread object to start the thread.
(Recommended tutorial: java introductory program)
(2) Create a thread class through the Runnable interface
Define the implementation class of the runnable interface, and re- Write the run() method of this interface. The method body of the run() method is also the thread execution body of the thread.
Create an instance of the Runnable implementation class, and use this instance as the target of Thread to create a Thread object. This Thread object is the real thread object.
Call the start() method of the thread object to start the thread.
(3) Create a thread through Callable and Future
Create an implementation class of the Callable interface and implement the call() method. The call() method will serve as the thread execution body and have a return value .
Create an instance of the Callable implementation class and use the FutureTask class to wrap the Callable object. The FutureTask object encapsulates the return value of the call() method of the Callable object.
Use the FutureTask object as the target of the Thread object to create and start a new thread.
Call the get() method of the FutureTask object to obtain the return value after the execution of the child thread ends.
5. What is the difference between runnable and callable?
This is a bit of a deep question, and it also shows the breadth of knowledge a Java programmer can acquire.
The return value of the run() method in the Runnable interface is void, and what it does is purely to execute the code in the run() method;
The call() in the Callable interface ) method has a return value and is a generic type. It can be used to obtain the results of asynchronous execution in conjunction with Future and FutureTask.
If you want to know more java interview questions, please pay attention to the java Advanced Interview Questions column.
The above is the detailed content of 2020 New Java Interview Questions - Multithreading (1). For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics











PHP is a scripting language widely used on the server side, especially suitable for web development. 1.PHP can embed HTML, process HTTP requests and responses, and supports a variety of databases. 2.PHP is used to generate dynamic web content, process form data, access databases, etc., with strong community support and open source resources. 3. PHP is an interpreted language, and the execution process includes lexical analysis, grammatical analysis, compilation and execution. 4.PHP can be combined with MySQL for advanced applications such as user registration systems. 5. When debugging PHP, you can use functions such as error_reporting() and var_dump(). 6. Optimize PHP code to use caching mechanisms, optimize database queries and use built-in functions. 7

Java 8 introduces the Stream API, providing a powerful and expressive way to process data collections. However, a common question when using Stream is: How to break or return from a forEach operation? Traditional loops allow for early interruption or return, but Stream's forEach method does not directly support this method. This article will explain the reasons and explore alternative methods for implementing premature termination in Stream processing systems. Further reading: Java Stream API improvements Understand Stream forEach The forEach method is a terminal operation that performs one operation on each element in the Stream. Its design intention is

PHP and Python each have their own advantages, and the choice should be based on project requirements. 1.PHP is suitable for web development, with simple syntax and high execution efficiency. 2. Python is suitable for data science and machine learning, with concise syntax and rich libraries.

PHP is suitable for web development, especially in rapid development and processing dynamic content, but is not good at data science and enterprise-level applications. Compared with Python, PHP has more advantages in web development, but is not as good as Python in the field of data science; compared with Java, PHP performs worse in enterprise-level applications, but is more flexible in web development; compared with JavaScript, PHP is more concise in back-end development, but is not as good as JavaScript in front-end development.

PHP and Python each have their own advantages and are suitable for different scenarios. 1.PHP is suitable for web development and provides built-in web servers and rich function libraries. 2. Python is suitable for data science and machine learning, with concise syntax and a powerful standard library. When choosing, it should be decided based on project requirements.

PHPhassignificantlyimpactedwebdevelopmentandextendsbeyondit.1)ItpowersmajorplatformslikeWordPressandexcelsindatabaseinteractions.2)PHP'sadaptabilityallowsittoscaleforlargeapplicationsusingframeworkslikeLaravel.3)Beyondweb,PHPisusedincommand-linescrip

The reasons why PHP is the preferred technology stack for many websites include its ease of use, strong community support, and widespread use. 1) Easy to learn and use, suitable for beginners. 2) Have a huge developer community and rich resources. 3) Widely used in WordPress, Drupal and other platforms. 4) Integrate tightly with web servers to simplify development deployment.

PHP is suitable for web development and content management systems, and Python is suitable for data science, machine learning and automation scripts. 1.PHP performs well in building fast and scalable websites and applications and is commonly used in CMS such as WordPress. 2. Python has performed outstandingly in the fields of data science and machine learning, with rich libraries such as NumPy and TensorFlow.
