Collection of classic Java interview questions (4)
1. Application scenarios of reflection mechanism
(Related tutorial recommendations: java interview questions)
Reverse code, such as decompilation
Framework combined with annotations such as Retrofit
Simple reflection mechanism Application frameworks such as EventBus 2.x
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.
#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
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!

Hot AI Tools

Undress AI Tool
Undress images for free

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

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

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)

The settings.json file is located in the user-level or workspace-level path and is used to customize VSCode settings. 1. User-level path: Windows is C:\Users\\AppData\Roaming\Code\User\settings.json, macOS is /Users//Library/ApplicationSupport/Code/User/settings.json, Linux is /home//.config/Code/User/settings.json; 2. Workspace-level path: .vscode/settings in the project root directory

To correctly handle JDBC transactions, you must first turn off the automatic commit mode, then perform multiple operations, and finally commit or rollback according to the results; 1. Call conn.setAutoCommit(false) to start the transaction; 2. Execute multiple SQL operations, such as INSERT and UPDATE; 3. Call conn.commit() if all operations are successful, and call conn.rollback() if an exception occurs to ensure data consistency; at the same time, try-with-resources should be used to manage resources, properly handle exceptions and close connections to avoid connection leakage; in addition, it is recommended to use connection pools and set save points to achieve partial rollback, and keep transactions as short as possible to improve performance.

DependencyInjection(DI)isadesignpatternwhereobjectsreceivedependenciesexternally,promotingloosecouplingandeasiertestingthroughconstructor,setter,orfieldinjection.2.SpringFrameworkusesannotationslike@Component,@Service,and@AutowiredwithJava-basedconfi

Use classes in the java.time package to replace the old Date and Calendar classes; 2. Get the current date and time through LocalDate, LocalDateTime and LocalTime; 3. Create a specific date and time using the of() method; 4. Use the plus/minus method to immutably increase and decrease the time; 5. Use ZonedDateTime and ZoneId to process the time zone; 6. Format and parse date strings through DateTimeFormatter; 7. Use Instant to be compatible with the old date types when necessary; date processing in modern Java should give priority to using java.timeAPI, which provides clear, immutable and linear

TheJVMenablesJava’s"writeonce,runanywhere"capabilitybyexecutingbytecodethroughfourmaincomponents:1.TheClassLoaderSubsystemloads,links,andinitializes.classfilesusingbootstrap,extension,andapplicationclassloaders,ensuringsecureandlazyclassloa

ChromecanopenlocalfileslikeHTMLandPDFsbyusing"Openfile"ordraggingthemintothebrowser;ensuretheaddressstartswithfile:///;2.SecurityrestrictionsblockAJAX,localStorage,andcross-folderaccessonfile://;usealocalserverlikepython-mhttp.server8000tor

Pre-formanceTartuptimeMoryusage, Quarkusandmicronautleadduetocompile-Timeprocessingandgraalvsupport, Withquarkusoftenperforminglightbetterine ServerLess scenarios.2.Thyvelopecosyste,

Networkportsandfirewallsworktogethertoenablecommunicationwhileensuringsecurity.1.Networkportsarevirtualendpointsnumbered0–65535,withwell-knownportslike80(HTTP),443(HTTPS),22(SSH),and25(SMTP)identifyingspecificservices.2.PortsoperateoverTCP(reliable,c
