Home > Article > Backend Development > 8 levels of problem-solving abilities for PHP programmers
This topic has been talked about for a long time. Among the abilities that must be assessed in interviews, I personally think that problem-solving ability ranks first, and has a higher priority than learning ability. The ability to solve problems can not only show the programmer’s thinking ability, adaptability, exploration ability, etc., but also his experience. If you have poor problem-solving skills, you will not be able to pass the interview.
Here is an example, if I execute a PHP script, such as php test.php, it is expected to return a string. But no information is output after execution. How can we know where the program is wrong at this time? The problem-solving ability can be divided into 8 levels here. The higher the level, the stronger the ability.
Lv0 Check the PHP error message
The program did not achieve the expected results, which proves that the code is wrong. Looking at the PHP error message is the first step. If you ignore the error message, it indicates that this person is not suitable for a professional programmer position. In some cases, the error display is turned off in the php.ini configuration, and you need to modify php.ini to open the error message, or the error message is exported to a log file. In this case, you can directly tailf php_error.log to see the error message.
After getting the error message, you can directly locate the program code problem, or search on Google/Baidu to solve the problem.
Note: The way to turn on error display is to set display_errors / display_startup_errors in php.ini to On
performance optimization
of PHP programs.Passing all three tests shows that this programmer has the problem-solving abilities that a professional PHP programmer
should have.PHP ProgrammerAs long as you have passed this level, you are enough to cope with most situations, and there is no pressure in small and medium-sized websites. Lv3 Use strace tool to track program execution
strace can be used to view the execution of system calls, use strace php test.php, or strace -p process ID. strace can help you see the essence through the phenomenon and grasp the process of program execution. This method is most commonly used in large websites and large companies. If you don't know strace, I can only say sorry. We don't accept PHPer who don't know strace. strace is actually a test of the programmer's basics. If you don't know how to operate the operating system and don't understand the underlying layers at all, you will definitely not be able to use strace. Of course, strace cannot solve dead loops in PHP code. For example, if you find that the CPU of a php-fpm process is 100%, strace may not be able to solve it. Because strace looks at system calls, which are generally IO operations. Since it is IO intensive, the CPU cannot be 100%. Lv4 Use the tcpdump tool to analyze the network communication processtcpdump can capture the data communication process of the network card, and even the data content can be captured. You can use tcpdump to see what the network communication process looks like, when the TCP SYN 3-way handshake is initiated, when the FIN packet is sent, and when the RST packet is sent. This is a basic skill. If you don’t understand tcpdump, it proves that you do not have the ability to solve network problems.
Lv5 counts the time consumption and success rate of function callsUse xhporf/xdebug to export the calling process of PHP requests, and then analyze the process and time consumption of each function call. Ability to analyzeperformance bottlenecks
of PHP programs and find out points that can be optimized. Another call to network services, such as mysql query, curl, other API calls, etc., by recording the start and end microtime, and whether false is returned, you can get whether the call was successful and how much time it took. If the data can be summarized and the success rate, failure rate, and average delay of calls can be sorted out, it proves that this programmer is sensitive to interface quality and has experience in large-scale website projects.Lv6 gdb usage
gdb is a powerful tool for debugging C/C++ programs. Programmers with certain C/C++ skills are required to use gdb proficiently. The strace mentioned above cannot track php program CPU100%, but gdb can track it. In addition, gdb can also solve the problem of core dump of PHP program.Using the gdb -p process ID, combined with php-src's .gdbinit zbacktrace and other tools, you can easily track the execution of the PHP program. Like the CPU 100% above, it is often a dead loop in the PHP program. By checking it multiple times with gdb, you can roughly get the location of the dead loop. There are very few PHP programmerswho have the ability to solve problems with gdb. If you can use gdb to solve PHP problems, this PHPer can pass the interview 100% and get a higher technical rating. Lv7 View the PHP kernel and extension source codeIf you are familiar with the PHP kernel and extension source code, you will be able to solve the most complex memory errors in PHP programs. This kind of
PHP programmersare rare. With the gdb tool and familiarity with PHP source code, you can view opcode information, execute_data memory,
global variablestatus, etc. The above introduces the 8 major levels of problem-solving abilities of PHP programmers, including aspects of content. I hope it will be helpful to friends who are interested in PHP tutorials.