Basic skills for Java programmers

The basic grammar

This includes the use of static, final, transient, foreach loops, and so on. If you answer static modifiers, modifiers, I will think you qualified, if you answer static blocks, I will think you are good, if you answer static inner classes, I will think you are good, I will be very satisfied with you, because I can see that you are very keen on research technology.

A collection of

It’s very important and it’s a must-ask. List, Map, Set, etc.

ArrayList, LinkedList, Hashtable, HashMap, ConcurrentHashMap, HashSet, etc. ConcurrentHashMap is one of the most frequently asked questions in interviews, probably because it can generate so many questions. For ConcurrentHashMap, I would like to offer three answers or research directions:

  • Lock segmentation technique for ConcurrentHashMap

  • Should read of ConcurrentHashMap be locked? Why

  • Whether the iterator of ConcurrentHashMap is a strong or weak consistent iterator

Design patterns

Of course, we can not be so utilitarian, in order to learn the interview, design mode is still very important in the work, very useful, 23 kinds of design mode focus on the study of more than ten kinds of common can be, the interview about the design mode of the question and answer are mainly three directions:

  • What design patterns did you use in your projects and how did you use them

  • Know the strengths and weaknesses of common design patterns

  • Ability to draw UML diagrams of common design patterns

multithreading

This is also a must ask a piece. Because of three years of working experience, I will basically not ask you how to achieve multi-threading, I will ask some in-depth questions, such as the difference and connection between Thread and Runnable, how to start a Thread many times, what state the Thread has. Of course, this is just the most basic. Unexpectedly, several interviews were almost simultaneously asked the same question in different ways, which summed up the following meaning:

If Thread1, Thread2, ThreaD3, and Thread4 count the size of C, D, E, and F respectively, and all the threads are handed over to Thread5 for summary, how should this be implemented?

The JDK source

To get a high salary, JDK source must be read. The above content may also be linked to specific scenarios, JDK source code is to see you usually love to study. How to implement the hashCode() method of String? JDK source code in fact, there is no good summary, purely personal, summary of the more important source code:

  • List, Map, Set implementation class source code

  • ReentrantLock, AQS source code

  • AtomicInteger implementation principle, can mainly explain the CAS mechanism and AtomicInteger is how to use CAS mechanism to achieve

  • Implementation principle of thread pool

  • Methods in the Object class and what each method does

The framework

It’s a cliche. It’s an interview question. In general, I will ask you about the framework you are using in your project, and then I will give you some scenarios to ask you how to use the framework, such as how I want to do something when Spring initializes the bean, how I want to do something when the bean is destroyed, the difference between $and # in MyBatis, etc. All these are practical. Usually accumulated well, how much learning framework use details naturally are not a problem.

The database

Nine times out of ten, the database will ask. Some basic differences such as union and Union all, left join, several indexes and their differences are not discussed, more important is the database performance optimization, if you know nothing about database performance optimization, then have time, It is also recommended that you spend a day or two prior to the interview preparing specifically for SQL basics and SQL optimization.

However, the database is not to worry about, a company often has many departments, if you are not familiar with the database and the basic technology is very good, nine chengdu will ask you, it is estimated that you will be put into the database use is not very high requirements of the department exercise.

Data structure and algorithm analysis

Data structure and algorithm analysis, for a programmer, is better than never and definitely comes in handy in the workplace. Array, linked list is the basis, stack and queue in-depth but also not difficult, tree is very important, more important tree AVL tree, red black tree, can not understand their specific implementation, but to know what is a binary search tree, what is a balanced tree, AVL tree and red black tree difference. I remember an interview, and an interviewer and I were talking about the index of the database, and he asked me,

Do you know which data structure is used for the index implementation?

The Java virtual machine

What’s important in the Java Virtual Machine:

  • Memory layout of the Java VIRTUAL machine

  • GC algorithm and several garbage collectors

  • The class loading mechanism, also known as the parent delegate model

  • Java memory model

  • Happens-before rules

  • Rules for using the volatile keyword

This is only the most basic requirement of the Java programmer, you can’t be on basis of programmers do for a lifetime so we can only slowly go up, here is my collection of a system of learning map, if you need to click: https://shimo.im/docs/VqQR6tPrpR3C3tjq/