Welcome to follow our wechat official account: Shishan100

My new course ** “C2C e-commerce System Micro-service Architecture 120-day Practical Training Camp” is online in the public account ruxihu Technology Nest **, interested students, you can click the link below for details:

120-Day Training Camp of C2C E-commerce System Micro-Service Architecture

Source: Big Data Muscle Ape

This article is submitted by the students of the interview experience

Thank you for your sharing

Directory:

1. The headline in your mind

2. Interview background

3. Prepare for the interview

4. Headlines (Java+ project)

5. Headline 2 (Big data + project)

6. Three aspects of the headline (algorithm + Scene)

7. How to pass the headline exam?

8. How do you prepare for a headline interview?

9. A tip on how to get into a big factory

First, the impression of the headlines

Here’s what I remember from today’s headlines:

1. My boss Zhang Yiming and I are fellow villagers from Fujian. Longyan city is like a mountain ditch in my friends’ eyes.

The written test is difficult even if you pay more money. Those of you who have taken the toutiao test know that you can take the toutiao test three times, which means you get three chances whether you take it or not.

Written test on 5 algorithm questions, two hours, the first time last year to see the algorithm on the closed, the first time to hang. The second time very seriously do, do half give up. A few days later, I was invited to do it for the third time, and I felt insulted by force.

3. Push inward and get rejected. As I said in the headline, resume rejected. In March last year, I saw a headline on Zhihu saying that spring internship could be promoted internally, so I sent him a private letter and resume. I looked at my resume and said there was a lot of competition for headlines. I didn’t have enough background. (Excuse me)

Second, the interview background

Last year, I was insulted by the algorithm of toutiao written test and instructed by the senior of Toutiao, and I felt that I could not get in, so I didn’t pay attention to the recruitment of Toutiao for most of the next half year, until the following two things happened.

1. One day, a friend of mine who was working as an intern made headlines and I was ready to start. I had an immature thought: “If he can get in, I can too.”

2. I happened to know a young leader who was working in the number warehouse of Douyin in the gym. I thought it was providence. So free to give him a private lesson (PS: MY hobby fitness, quite experience), let him help push.

Prepare for the interview

In fact, it only took me one month from sending out my resume in March to preparing for the interview to receiving the offer in April, but all of this is based on my accumulation in the past year. Countless overnight study rooms, the library’s exclusive chair is sitting in my sink.

In order to avoid misleading everyone, this time also do not headline party, wrote a year of preparation, steadfast work.

It’s a pretty good list

The following is the study plan I set for myself last year:

January:

Introduction to Big data. January was spent binge-watching howto videos and the Hadoop Guru’s Guide, and it was the end of the semester, waking up at 5:30 a.m. to watch two hours of videos and then attending class or studying for finals.

February:

Offer brush, data structure, JavaSE, JVM, multithreading

① The sword refers to some confused offer directly skip, wait for the second time next month to brush again;

② The data structure focuses on some characteristics of various trees, binary trees, red-black trees and linked lists;

③JavaSE is mainly the difference between class object interface, can inherit, Static characteristics, a variety of Hashmap, ArrayList and other collection framework principle source code;

④JVM is based on the online integration of high frequency interview questions to learn, brush through the interview questions before going to see Zhou Zhihua’s “In-depth Understanding of Java Virtual Machine”.

What is difficult about JVMS is not the theory of JVM layout, garbage collection algorithms, etc., but the combination of code and project scenarios.

For example, if a piece of code has many classes and methods, and static classes and global variables, which are loaded first and which variables are stored in which section when the project runs

Not only to understand the theory, but to understand the theory with the code. There is also OOM in the project, stack overflow, parameter tuning of JVM, and so on.

⑤ Multithreading is also brush online interview questions and blogs, several multithreading books are a lump of, do not understand.

The first start several multi-threaded implementation methods to achieve a time, and then analyze the advantages and disadvantages, and then cut into the thread is not safe and various locks.

Multithreaded learning different JVMS, do it yourself, debug it a little bit, and the console will tell you the answer.

March:

The sword refers to offer two brush, database, operating system, network, preparation interview

① Sword refers to the offer second time focus brush the first time thought understand the code do not understand.

② database brush more than 100 SQL combat, the other are index principle, pessimistic and optimistic lock theory.

③ Operating system brush frequent interview questions. Deadlock conditions, solutions and so on, resource scheduling algorithm, concurrency and parallelism.

④ The Internet is also brush interview questions. Three-way handshake, four-way wave and why, TCP and UDP, web page request process, DNS resolution process, network model, meaning of response code, etc.

⑤ EVERY time I brush an algorithm or understand an interview question, I will sort it out, so I can just read the documents and blogs before the interview, which is very easy.

This month, I continued to send out my resume for interview. Since March, I have been preparing for the interview while submitting my resume. There is no need to submit my resume when I am fully prepared.

In March, I received offers from second-tier factories such as JINGdong and Guazi Second-hand cars.

April:

Big data projects, handwritten sword offer, continue the interview

(1) In March, I was accused by three interviewers from the rookie department of Ali, saying that there was no big data project in my resume and the theory would be of no use, so I planned to make up the project in April.

② While making up the project, remember the algorithm and practice whiteboard coding.

In April, I received some offers from Tencent and Qunar. Tencent and Qunar both had to meet on site, so I flew to Beijing one day and Shenzhen one day.

When I got the offer from Tencent, I discussed with HR whether I could go to the base in Shanghai or Beijing, but HR said no, so I didn’t go.

I choose the city where I work and live by a hard and fast criterion: far away from home! Those students who studied in the north always run home after graduation, while I always jump out, maybe because I stayed in Xiamen for four years, my hometown is also “besieged” ah.

5-12 months:

Internship, look at the frame source code, interview, sorting out the interview

Finally, I chose to go to Kyligence for internship. I just took this opportunity to learn Kylin source code and read some source codes of Hadoop and Spark. Behind the interview is also to force themselves to learn, in the interview to find insufficient, but also incidentally sorted out some interview information.

Conclusion:

First of all, be sure to list their own learning plan, but also learn to adjust the plan according to their own learning situation. The project is the stepping stone of the interview, but also the main part of the interview. I went out to practice in the sophomore year, so I can spend less time on the project and do not have to learn from scratch.

Secondly, the underlying theory must be able to, or big factory hopeless. The algorithm must be hard, a total of those types of questions.

I was also very resistant at the beginning, feel too difficult, the back of the difficulties also so the matter. If I fail in the first offer, I will do the second one, or I will do the third one. Up to now, there are still some questions in the offer that I do not understand, but I will not go into the details.

Other students put the winter vacation, his own a person next to the school rented a small house to learn New Year’s eve; In order to consolidate the internship project and have a better interview, I went to the previous internship company for several times to invite my colleagues to dinner to ask for project details. Study all night for ali interview (but this is not good for health, or not recommended)

Sending out too many resumes, selling all the information, and assuming your cell phone is calling for an interview; Go to Tencent end, in the deep university overnight study room review.

The above is my preparation for the past year. Next, I will talk about my preparation for the month from sending resumes to receiving offers.

1. Review the algorithm. I sorted out the algorithms I had brushed before, because I had sorted them out before, so I didn’t spend much time reviewing them. I also deliberately went to understand the long KMP algorithm and LRU algorithm.

2. Review the theoretical basis. In addition to reviewing the interviews and materials, I also made a special visit to Golang, because the headlines use go language.

3. Prepare several technical difficulties of the project so that you can show them off during the interview.

Iv. Headlines (Java+ Project)

Focus on Java and projects. Here are some of the things I remember:

  • How does an inverted index work? What’s the hash table in Redis? Happen -before rules?

  • Volatile modifiers, synchronize locks. What do you understand about them?

  • Implementation of Java singleton pattern, lazy, hungry? What’s the difference between a process and a thread, multi-process and multi-thread?

  • HashMap principle, why use red black tree, red black tree characteristics? Fast scheduling of time and space complexity, best – worst case, optimization?

  • What is the specific process of TCP congestion control? Does UDP have congestion control? How to solve it?

  • Talk about garbage collection algorithms and collectors. When do you execute STOP THE WORLD?

  • Do you know Go?

V. Headline two interviews (big data + project)

The focus of the second session shifted to big data, aiming at all kinds of problems related to big data technology, the fire is still fierce:

  • Kylin’s project structure? Paxos and ZAB protocols, CAP theory, partition fault tolerance significance?

  • HDFS read and write, fault tolerant processing (explained from the source level), Namenode HA, split brain, Yarn scheduling mechanism.

  • Large table Join small table optimization, how to handle data skew? Let’s talk about maximum heap and minimum heap

  • MapReduce Process (first and second versions), MapReduce Shuffle, and Spark Shuffle.

  • Hive internal and external table differences, warehouse modeling model, warehouse hierarchy, snowflake model and star model. Know anything about ClickHouse? How is it different from Kylin?

Vi. Three aspects of the headline (Algorithm + Scene)

Three sides to the algorithm, generally speaking, ok, did not meet the abnormal level of difficulty of the topic:

  • LRU algorithm implementation (pseudocode) linked list last KTH number

  • A bunch of screws and nuts with minimal time matching (code implementation)

  • Seek new users to browse the page every day (Hive QL implementation)

  • Search for the top 10 views of Douyin small videos per day (Hash + maximum heap)

7. How to pass the headline written test?

There are 5 questions in the written test, I AC 2.5 questions, the first question 90%, the second question 90%, the third question 70%, not good, but barely passed.

This time last year, I could not even understand the topic. What I could understand only knew how to say in my mouth, not in code.

Through the algorithm training during this period, the following points of algorithm written test experience are summarized:

1. Usually brush questions must be summed up, the best classification.

For example, on the tree question type, linked list, array, etc., observe their solution ideas, summarize the solution routine.

2. Accumulation of tool algorithms.

What is a tool-like algorithm? When you solve an algorithm problem using another algorithm, the algorithm being called is the tool for solving the algorithm problem.

For example, common “depth-first traversal”, “breadth-first traversal”, “01 knapsack”, “KMP algorithm” and common selection and sorting algorithms are often used tool algorithms.

3. Learn to abstract questions.

The written test algorithm is different from the interview algorithm, will not tell you directly to use which algorithm to answer, more to learn their own abstraction.

You need to look beyond the title itself, understand what’s going on inside, and don’t be fooled by the title’s sugar coating. It’s only by abstracting the problem into the original algorithm that you’re going to be able to do it better with the tool-like algorithm.

8. How to prepare for a headline interview?

The headline interview may be similar to other big companies, but it is this small difference that is the key, what makes it different from others. Preparations can be made from the following aspects:

1. Specially prepare several interview questions source code

As I answer some of the regular interview questions, will start from the source point of view. For example, common HashMap and other collection classes, a variety of multi-threaded locks and big data framework part of the source code.

2. Prepare for project difficulties

When facing some big factories, it is unavoidable to be asked about the difficulties of the project. It is impossible to use common bugs to obscure the past.

Here, we can start from the technology stack used in the project to find the difficulties existing in the technology stack in the project, and then put them into our own project to find one that I can understand, and it is better to understand all of them.

3. Learn about the use of the company’s technology stack.

For example, the headlines use Go, which is well known, so why don’t I learn?

For example, I know in the industry that Toutiao was first used in the Kylin framework, which has since shifted to ClickHouse.

** In that case, ** I have to understand the difference between the two, and it can be combined with the business scenario of Toutiao.

Nine, a tip on how to enter a big factory

I have always advocated the practice of “curving to save the country”, and I have been spreading this practice to others.

It doesn’t matter if you don’t have a good background, as long as you plan your own learning route and climb up step by step, you can always achieve your goals.

I started my internship in the sophomore year because I was a sophomore, and I made up for my lack of background with projects and internship experiences. Then, I went step by step to “offer freedom”.

Most of the time, not only the giant can be successful, you just need to do the action of ordinary people, you can surpass a lot of thought giants, action dwarfs.

END

Personal public account: Architecture Notes of Huishania (ID: Shishan100)

Welcome to long press the picture below to pay attention to the public number: Huoia architecture notes!

The official number backstage replies the information, obtains the author exclusive secret system study material

Architecture notes, BAT architecture experience taught each other