search
HomeJavaJavaInterview questionsCollection of classic Java interview questions (4)

Collection of classic Java interview questions (4)

Jul 09, 2020 pm 04:28 PM
javaInterview questions

Collection of classic Java interview questions (4)

1. Application scenarios of reflection mechanism

(Related tutorial recommendations: java interview questions)

  1. Reverse code, such as decompilation

  2. Framework combined with annotations such as Retrofit

  3. Simple reflection mechanism Application frameworks such as EventBus 2.x

  4. Dynamically generated class frameworks such as Gson

2. What is multi-threading?

Multi-threading refers to the technology that realizes the concurrent execution of multiple threads from software or hardware. In a program, these independently running program fragments are called "threads", and the concept of programming using them is called "multi-threading".

Computers with multi-threading capabilities can execute more than one thread at the same time due to hardware support, thus improving overall processing performance.

Collection of classic Java interview questions (4)

#The main thread is the first thread generated in the creation process, which is the thread corresponding to the main function.

(Recommended learning: java introductory program)

3. Tell me about the benefits of multi-threading?

1. Advantages of multi-threading

  • The cost of creating a new thread is much smaller than creating a new process

  • Compared with switching between processes, switching between threads requires the operating system to do very little work

  • Threads occupy much fewer resources than processes

  • Can make full use of the parallel number of multi-processors

  • After waiting for the slow IO operation to end, the program can perform other computing tasks

  • Computing (CPU)-intensive applications, in order to run on multi-processor systems, the calculation is broken down into multiple threads to implement

  • IO-intensive applications , in order to improve performance, IO operations are overlapped, and threads can wait for different IO operations.

2. Disadvantages of multi-threading

  • Performance loss (a computing-intensive thread is rarely blocked by external events and cannot communicate with other Threads share the same processor. When the number of computationally intensive threads is more than the available processors, there may be a large performance loss. The performance loss here refers to the additional synchronization and scheduling overhead. Two available Resources remain unchanged.)

  • The robustness is reduced (there is a lack of protection between threads. In a multi-threaded program, due to the slight difference in time allocation or the sharing of some incorrect The possible impact of adverse effects on variables that should be shared is very large.)

  • Lack of access control (because the process is the basic granularity of access control, calling certain OS in a thread Functions will affect the entire process.)

  • Increased programming difficulty (writing and debugging a multi-threaded program is much more difficult than a single-threaded program.)

4. What is the difference between threads and processes?

1. Scheduling

The process is a basic unit for the operating system to allocate resources. Threads are the basic unit of CPU scheduling.

2. Concurrency

After the introduction of threads, not only processes can be executed concurrently, but multiple threads in a process can also be executed concurrently, even allowing one All processes in the process execute concurrently.

Similarly, threads in different processes can also be executed concurrently. This enables the OS to have better concurrency, improving resource utilization and system throughput.

3. Owning resources

A process can own resources and is the basic unit of system resource ownership. The thread itself does not own system resources, only some resources that can ensure independent operation. This resource is private to each thread.

For example, thread ID, a set of registers, stack, errno, signal mask word (there is only one pending signal in a process, but any thread can handle this signal), scheduling priority.

4. Independence

The independence of threads in the same process is much lower than that in different processes.

5. System overhead

The cost of thread switching is lower than the cost of process switching.

6.Support multi-processor system

For traditional processes , that is, a single-threaded process, no matter how many processors there are, the process can only run on the same processor, but for a multi-threaded process, multiple threads in a process can be assigned to multiple processors, so that Its concurrent execution speeds up the completion of the process.

(Video tutorial recommendation: java video tutorial)

5. Application scenarios of processes and threads

Collection of classic Java interview questions (4)

  • Need to frequently create and destroy priority threads.

  • Prioritize threads that require large amounts of calculations.

  • Threads are used for strong correlations, and processes are used for weak correlations.

  • It may be extended to use processes for multi-machine distribution and threads for multi-core distribution.

The above is the detailed content of Collection of classic Java interview questions (4). For more information, please follow other related articles on the PHP Chinese website!

Statement
This article is reproduced at:csdn. If there is any infringement, please contact admin@php.cn delete

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

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

Hot Tools

MantisBT

MantisBT

Mantis is an easy-to-deploy web-based defect tracking tool designed to aid in product defect tracking. It requires PHP, MySQL and a web server. Check out our demo and hosting services.

PhpStorm Mac version

PhpStorm Mac version

The latest (2018.2.1) professional PHP integrated development tool

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

This project is in the process of being migrated to osdn.net/projects/mingw, you can continue to follow us there. MinGW: A native Windows port of the GNU Compiler Collection (GCC), freely distributable import libraries and header files for building native Windows applications; includes extensions to the MSVC runtime to support C99 functionality. All MinGW software can run on 64-bit Windows platforms.

mPDF

mPDF

mPDF is a PHP library that can generate PDF files from UTF-8 encoded HTML. The original author, Ian Back, wrote mPDF to output PDF files "on the fly" from his website and handle different languages. It is slower than original scripts like HTML2FPDF and produces larger files when using Unicode fonts, but supports CSS styles etc. and has a lot of enhancements. Supports almost all languages, including RTL (Arabic and Hebrew) and CJK (Chinese, Japanese and Korean). Supports nested block-level elements (such as P, DIV),

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

Powerful PHP integrated development environment