It is true that this reason is correct, but what I want to talk about today is another reason.
We know that to determine whether a file is loaded, PHP needs to get the open_path of the file, meaning That is, for example:
1. Try to parse the absolute path of the file. If the parsing is successful, check EG (included_files). If it exists, return it. If it does not exist, continue
2. Open the file and get the open path of the file
3. Take the open path and search it in EG (included_files) to see if it exists. If it exists, return it. If it does not exist, continue
4. Compile file (compile_file)
In most cases, this is not a problem, but the problem lies when you use APC...
When using APC, APC hijacks the pointer of the compile_file file and directly reads it from the cache Get the compilation result in, avoid opening the actual file, and avoid the system call to open.
However, when you use include_once in the code, PHP has already tried to open the file before compile_file , and then enter the compile file hijacked by APC, which will generate an additional open operation. To solve this problem, APC introduced include_once_override. When include_once_override is turned on, APC will hijack PHP. ZEND_INCLUDE_OR_EVAL opcode handler, determine the absolute path of the file through stat, and then if it is found that it is not loaded, rewrite the opcode to include and make a tricky solution.
But, it is a pity, as I said, APC include_once_override has not been implemented well, and there will be some undefined problems, such as:
Excluding these technical factors, I have always believed that we should use include instead of include_once, because we can completely plan by ourselves and a file will only be loaded once. We can also use automatic loading to do this.
If you use include_once, it only proves that you have no confidence in your code.
So, I suggest everyone not to use include_once