preface

It has been more than a month since the interview, and I still remember 90% of the interview questions. I just left my job right before the Dragon Boat Festival and took advantage of the holiday to summarize the interview questions. Mainly is to record the question, the answer to write more than a few words, there are quite a lot of articles on the Internet about good so this article will not expand.

Technology stack

Java, Golang, JS, python are mainly the first two.

The interview summary

  1. Other Java team leaders
  2. Other Golang team leaders
  3. The team leader
  4. Director of the surface

The reason why I put the interview summary in front is because it is the first time to write an article without experience. The following layout is too simple, so I am afraid that we can not read it, so I will simply summarize a few words. The interviews lasted four hours and four rounds. Recall about 90~95% of the answer, the overall feeling is ok. I have the impression that these interviewers are very professional, with high quality questions and nice people.

This interview is like looking in the mirror to know their own shortcomings, and then need to solid precipitation technology. Enhance algorithmic capabilities. Understand the source code. Try to live up to every opportunity.

Came back to WH from SZ 2 years ago and then felt the good of SZ. It belongs to the type of hindsight. Looking at the former yonyou colleagues are pretty good one by one (Ali, Tencent, Ali, Baidu, JINGdong, Meituan, netease, etc.) I feel in the wilderness to survive.

In the past few years, I have never thought about what I want to pursue in life except playing games and watching technology. However, after thinking about life for half a year, I suddenly know what I want to do (I am in my late twenties and approaching 30 soon, which I realize after a while).

Let’s take a look at the numbers

Wh made 4 50+ faces in 19 years and got 2. Most of them don’t reply.

Wh has won 4 out of 7 out of 10 in ’17. (Later, I rejected the offer of IFlytek for some reason and chose a certain company)

I can’t remember the SZ data of 12~16 years. Although I am a weak chicken but feel the job is easy to find. (16 years of Yonyou)

So 19 years WH is really magical, I once suspected that the resume is too water, sent to SZ, HZ friends to see they said ok ah no problem. Could trump’s trade war have made hiring difficult? “Smile”

What is the title of this article

To tell a real joke, a while ago in WH, a small company architect position scene: 4 people face me at the same time, a large desk, the general manager’s office

General Manager: Do you want to work in sales? Have you worked in sales before?

Me: embarrassed to say that doing sales is too difficult for me to have this ability. Why are you talking to me about this in the first place? Do I seem so unskilled? I sent in dozens of resumes and came here excited and you’re telling me this? Does this justify my seriousness?

General Manager: Oh! Your company does hardware products! (I have the NLP robotics project on my resume)

Me: “It’s a software product.”

General manager: Then let the cTO have an interview.

Starting technical side

He: Tell me about the project you’ve been working on

Me: Introduced the background of a project, said what the project was used for, briefly mentioned the technology stack about 5~6 minutes because of interaction, so I can’t talk too long by myself

He: What does GRPC do? Why don’t you use HTTP restful to do it

I: Remote call based on HTTP2 there are 4 call methods serialization protocol using protobuf

He: Ok, I’m done with the technology

The general manager added a few concluding remarks the interview was over

Is this the end of WTF? It’s been less than 15 minutes? And that’s how I’m eliminated? Yeah, yeah. [Smile]

Ok to sum up, I finally got a technical mood to write down this topic.

A Java

Mainly Java basic framework principles

  1. detailedThe thread poolWhat are the constructors?ctl,allowCoreThreadTimeOutThe function of variables, initialization phase, mass commit task phase, execute all tasks phase this writing process. (addWorkerProcess and other parts are good answersrunWorker getTaskSome of the details are not well answered. Thread pools are a problem that Java can’t avoid and there are many answers on the web that won’t be covered in detail.
  2. HashMapData structure,resizeWhat are the problems with multithreading? What are the changes in 1.7 and 1.8, now that I’ve mentioned themRed and black treeSo let’s talk about it andBST,AVLHave what characteristic to have what distinction severally, say balance process (OK. This is the basic content. There are a lot of answers online. I won’t go into details.
  3. So let’s talk aboutconcurrenthashmapHow to keep thread-safe difference 1.7 and 1.8 (OK)
  4. Threads have several states,sleep waitDifference (OK)
  5. synchronized LockSynchronized, object headers, optimization of locks in the JVM, and more on AQS, read-write locks, CAS, and the underlying unsafe (OK)
  6. JVM memory structureWhat memory structure of the heap is shared by threads? Have you used the Javap command to talk about your understanding of the various areas of JVM memory? Tuning is relevant. (ok)
  7. chatGC.Accessibility analysis algorithm, which objects can be used asGC ROOTAccording to the characteristics of the new generation and the old generation, let’s talk about which garbage collection algorithms are suitable for them. Compare theMark clearandTag to sort out. (ok)
  8. Class loader.Parents delegate.Security sandbox mechanism(ok)
  9. Let’s talk about IO,BIO,NIO.IO modelHow does the JVM implement NIO? Fortunately, I took a quick look at the C ++ code for the JVM. I won’t go into the multiplexing non-blocking stuff. For a few key points, see Unix Network Programming for the IO model.select,poll,epoll.fcntl)
  10. Consistency hash algorithms, distributed objects, Service Mesh practices, RabbitMQ (basic OK)
  11. TCP sliding windowACK mechanism. (ok)
  12. Zuul, Hystrix, Feign working principle, SpringMVC working principle (OK)
  13. Examples of design patterns used in Spring (ok, Nuggets has this article)
  14. Git Usage Specification, GitFlow (OK)
  15. Dubbo related questions (OK)

2 face golang

  1. Golang’s concurrency model (general M, P, G for answers)
  2. Gin source routing, Group, Middleware & design patterns (Routing implemented using prefix trees)
  3. GRPC 4 kinds of call methods, you have seen GRPC Golang version of the source code client -> server this process you talk about. GRPC performance optimization for protobuf protocol, http2
  4. Cap principle, registry selection AP or CP.
  5. What kind of CAP is ETCD? What is etCD data consistency algorithm? Describe raft protocol, what happens when partition isolation occurs, and how to ensure data consistency after isolation recovery. (Ok, Paxos before “raft” and then “raft” and then “raft” and then “raft” is highly recommended to look at raft.github. IO /)
  6. You said you have read the source code, let’s talk about Gomicro (talk about the various components and what each is suitable for doing, and talk about what microservices are used in our project, the last company gomicro technology stack is promoted by me, so this answer is ok.)
  7. Talk about how you implemented microservices without Gomicro (etCD for registry discovery, lease renewal, service degradation, traffic limiting, fuses, caching, consistency hashes, GRPC, Golang RabbitMQ client & Disconnection and reconnection). Unlike Spring Cloud or Gomicro, there are a lot of things that you can use out of the box. These are all hand-lifted, of course, and this is done by my team, so don’t be afraid to learn another language or technology stack.
  8. Golang pressure pprof, flame diagram, and performance improvement points of architecture deduction combined with the project (OK)
  9. Your project structure and dependency management (OK, goDEp, Glide is not as good as Maven)
  10. Pits encountered (pits encountered in the process of using ETCD, coroutine leakage caused by improper use and how to avoid it, watch, lease, space compression, etc.)
  11. What have you been impressed with using Golang (coroutines, chan, select this is cliff is great to use, defer, panic&reverse)
  12. Golang coding specification, logging specification (here to mention a specification is very important, the architecture evolution of refactoring experience, but there is no very uniform specification like Java Ali specification, There was no recommended directory division for subcontracting, so Google then developed an internal specification based on their own experience and found that there was an article from Nuggets that echoed and strongly endorsed the DraP. Me/Golang-101 logging framework that didn’t use Java directly under SLF4J Log4j2 or logback is so decisive that we decide to use Logrus. The QL of the team is customized according to the requirements.

Three synthetic surface

  1. Kafka working principle, zero copy, packet coordinator working principle, offset related issues
  2. Link tracking SkyWalking, Zipkin’s respective characteristics and implementation principle, Java probe
  3. Mysql lock, index, transaction, large amount of data optimization sub-table sub-library solution
  4. Redis thread model skiplist Ziplist data structure, persistence scheme RDB snapshot backup process (copy-on-write this answer is not good I only know Java copyonwrite, Linux fork process specific operation is not clear). Elimination strategy, cache penetration massive failure solution
  5. Given two numbers a, B requires you to calculate the minimum number of steps from a to B through these two operations. (OK, algorithm is not my strength, this problem brush algorithm has not done the time fortunately to give a relatively simple, I have an idea for about 10 seconds. I wrote it in a few minutes. It’s not complete.
  6. Talk about the future of the technology you are interested in (technical)

Every director

I will not elaborate on the following issues

Career planning, why to change jobs, hobbies, personality, self-evaluation of the last work experience and so on, I also asked some questions for interaction.

After the interview, go back and wait for the notice from HR.

Finally get the offer

The experience of these two years can be summed up in one sentence.

That’s right. Don’t underestimate anyone.

Finally, I wish the rest of the team partners wretched development.