TICKS
PHP code
<?php
/*
*
* opcode number: 105
*/
// A function that records the time when it is called
function profile()
{
echo "profile function is called\n";
}
// Set up a tick handler
register_tick_function("profile");
// Initialize the function before the declare block
profile();
// Run a block of code, throw a tick every 2nd statement
declare(ticks=2) {
for ($x = 0; $x < 10; ++$x) {
echo "hello world\n";
}
}
?>
PHP opcodes
Function name: (null)
Compiled variables: !0=$x
line | # | op | fetch | ext | return | operands |
---|---|---|---|---|---|---|
7 | 0 | NOP | ||||
13 | 1 | SEND_VAL | 'profile' | |||
2 | DO_FCALL | 1 | 'register_tick_function' | |||
16 | 3 | DO_FCALL | 0 | 'profile' | ||
20 | 4 | ASSIGN | !0,0 | |||
5 | IS_SMALLER | ~3 | !0,10 | |||
6 | JMPZNZ | 9 | ~3,->13 | |||
7 | PRE_INC | !0 | ||||
8 | JMP | ->5 | ||||
21 | 9 | ECHO | 'hello+world%0A' | |||
10 | TICKS | 2 | ||||
22 | 11 | TICKS | 2 | |||
12 | JMP | ->7 | ||||
13 | TICKS | 2 | ||||
23 | 14 | TICKS | 2 | |||
24 | 15 | RETURN | 1 |
Function name: profile
Compiled variables: none
line | # | op | fetch | ext | return | operands |
---|---|---|---|---|---|---|
9 | 0 | ECHO | 'profile+function+is+called%0A' | |||
10 | 1 | RETURN | null |
- PHP Руководство
- Функции по категориям
- Индекс функций
- Ядро PHP: Руководство хакера
- Zend Engine 2 Opcodes
- ADD
- ADD_ARRAY_ELEMENT
- ADD_CHAR
- ADD_INTERFACE
- ADD_STRING
- ADD_VAR
- ASSIGN
- ASSIGN_ADD
- ASSIGN_BW_AND
- ASSIGN_BW_OR
- ASSIGN_BW_XOR
- ASSIGN_CONCAT
- ASSIGN_DIM
- ASSIGN_DIV
- ASSIGN_MOD
- ASSIGN_MUL
- ASSIGN_OBJ
- ASSIGN_REF
- ASSIGN_SL
- ASSIGN_SR
- ASSIGN_SUB
- BEGIN_SILENCE
- BOOL
- BOOL_NOT
- BOOL_XOR
- BRK
- BW_AND
- BW_NOT
- BW_OR
- BW_XOR
- CASE
- CAST
- CATCH
- CLONE
- CONCAT
- CONT
- DECLARE_CLASS
- DECLARE_CONST
- DECLARE_FUNCTION
- DECLARE_INHERITED_CLASS
- DECLARE_INHERITED_CLASS_DELAYED
- DIV
- DO_FCALL
- DO_FCALL_BY_NAME
- ECHO
- END_SILENCE
- EXIT
- EXT_FCALL_BEGIN
- EXT_FCALL_END
- EXT_NOP
- EXT_STMT
- FE_FETCH
- FE_RESET
- FETCH_CLASS
- FETCH_CONSTANT
- FETCH_DIM_FUNC_ARG
- FETCH_DIM_IS
- FETCH_DIM_R
- FETCH_DIM_RW
- FETCH_DIM_TMP_VAR
- FETCH_DIM_UNSET
- FETCH_DIM_W
- FETCH_FUNC_ARG
- FETCH_IS
- FETCH_OBJ_FUNC_ARG
- FETCH_OBJ_IS
- FETCH_OBJ_R
- FETCH_OBJ_RW
- FETCH_OBJ_UNSET
- FETCH_OBJ_W
- FETCH_R
- FETCH_RW
- FETCH_UNSET
- FETCH_W
- FREE
- GOTO
- HANDLE_EXCEPTION
- INCLUDE_OR_EVAL
- INIT_ARRAY
- INIT_FCALL_BY_NAME
- INIT_METHOD_CALL
- INIT_NS_FCALL_BY_NAME
- INIT_STATIC_METHOD_CALL
- INIT_STRING
- INSTANCEOF
- IS_EQUAL
- IS_IDENTICAL
- IS_NOT_EQUAL
- IS_NOT_IDENTICAL
- IS_SMALLER
- IS_SMALLER_OR_EQUAL
- ISSET_ISEMPTY_DIM_OBJ
- ISSET_ISEMPTY_PROP_OBJ
- ISSET_ISEMPTY_VAR
- JMP
- JMPNZ
- JMPNZ_EX
- JMPZ
- JMPZ_EX
- JMPZNZ
- MOD
- MUL
- NEW
- NOP
- POST_DEC
- POST_DEC_OBJ
- POST_INC
- POST_INC_OBJ
- PRE_DEC
- PRE_DEC_OBJ
- PRE_INC
- PRE_INC_OBJ
- QM_ASSIGN
- RAISE_ABSTRACT_ERROR
- RECV
- RECV_INIT
- RETURN
- RETURN_BY_REF
- SEND_REF
- SEND_VAL
- SEND_VAR
- SEND_VAR_NO_REF
- SL
- SR
- SUB
- SWITCH_FREE
- THROW
- TICKS
- UNSET_DIM
- UNSET_OBJ
- UNSET_VAR
- USER_OPCODE
- VERIFY_ABSTRACT_CLASS
- ZEND_DECLARE_LAMBDA_FUNCTION
- ZEND_JMP_SET
Коментарии
404 Not Found