<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <meta http-equiv="content-type" content="text/html; charset=UTF-8"> <title>TICKS</title> </head> <body><div class="manualnavbar" style="text-align: center;"> <div class="prev" style="text-align: left; float: left;"><a href="internals2.opcodes.throw.html">THROW</a></div> <div class="next" style="text-align: right; float: right;"><a href="internals2.opcodes.unset-dim.html">UNSET_DIM</a></div> <div class="up"><a href="internals2.opcodes.list.html">Opcode Descriptions and Examples</a></div> <div class="home"><a href="index.html">PHP Manual</a></div> </div><hr /><div id="internals2.opcodes.ticks" class="section"> <h2 class="title">TICKS</h2> <div class="section" id="internals2.opcodes.ticks.code"> <h2 class="title">PHP code</h2> <div class="example-contents"> <div class="phpcode"><code><span style="color: #000000"> <span style="color: #0000BB"><?php<br /></span><span style="color: #FF8000">/*<br /> * <br /> * opcode number: 105<br /> */<br />// A function that records the time when it is called<br /></span><span style="color: #007700">function </span><span style="color: #0000BB">profile</span><span style="color: #007700">()<br />{<br /> echo </span><span style="color: #DD0000">"profile function is called\n"</span><span style="color: #007700">;<br />}<br /><br /></span><span style="color: #FF8000">// Set up a tick handler<br /></span><span style="color: #0000BB">register_tick_function</span><span style="color: #007700">(</span><span style="color: #DD0000">"profile"</span><span style="color: #007700">);<br /><br /></span><span style="color: #FF8000">// Initialize the function before the declare block<br /></span><span style="color: #0000BB">profile</span><span style="color: #007700">();<br /><br /></span><span style="color: #FF8000">// Run a block of code, throw a tick every 2nd statement<br /></span><span style="color: #007700">declare(</span><span style="color: #0000BB">ticks</span><span style="color: #007700">=</span><span style="color: #0000BB">2</span><span style="color: #007700">) {<br /> for (</span><span style="color: #0000BB">$x </span><span style="color: #007700">= </span><span style="color: #0000BB">0</span><span style="color: #007700">; </span><span style="color: #0000BB">$x </span><span style="color: #007700">< </span><span style="color: #0000BB">10</span><span style="color: #007700">; ++</span><span style="color: #0000BB">$x</span><span style="color: #007700">) {<br /> echo </span><span style="color: #DD0000">"hello world\n"</span><span style="color: #007700">;<br /> }<br />}<br /></span><span style="color: #0000BB">?></span> </span> </code></div> </div> </div> <div class="section" id="internals2.opcodes.ticks.listing"> <h2 class="title">PHP opcodes</h2> <p class="simpara">Function name: (null)</p> <p class="simpara">Compiled variables: !0=$x </p> <table class="doctable informaltable"> <thead> <tr> <th>line</th><th>#</th><th>op</th> <th>fetch</th><th>ext</th><th>return</th> <th>operands</th> </tr> </thead> <tbody class="tbody"> <tr> <td>7</td><td>0</td> <td>NOP</td><td class="empty"> </td> <td class="empty"> </td><td class="empty"> </td> <td class="empty"> </td> </tr> <tr> <td>13</td><td>1</td> <td>SEND_VAL</td><td class="empty"> </td> <td class="empty"> </td><td class="empty"> </td> <td>'profile'</td> </tr> <tr> <td class="empty"> </td><td>2</td> <td>DO_FCALL</td><td class="empty"> </td> <td>1</td><td class="empty"> </td> <td>'register_tick_function'</td> </tr> <tr> <td>16</td><td>3</td> <td>DO_FCALL</td><td class="empty"> </td> <td>0</td><td class="empty"> </td> <td>'profile'</td> </tr> <tr> <td>20</td><td>4</td> <td>ASSIGN</td><td class="empty"> </td> <td class="empty"> </td><td class="empty"> </td> <td>!0,0</td> </tr> <tr> <td class="empty"> </td><td>5</td> <td>IS_SMALLER</td><td class="empty"> </td> <td class="empty"> </td><td>~3</td> <td>!0,10</td> </tr> <tr> <td class="empty"> </td><td>6</td> <td>JMPZNZ</td><td class="empty"> </td> <td>9</td><td class="empty"> </td> <td>~3,->13</td> </tr> <tr> <td class="empty"> </td><td>7</td> <td>PRE_INC</td><td class="empty"> </td> <td class="empty"> </td><td class="empty"> </td> <td>!0</td> </tr> <tr> <td class="empty"> </td><td>8</td> <td>JMP</td><td class="empty"> </td> <td class="empty"> </td><td class="empty"> </td> <td>->5</td> </tr> <tr> <td>21</td><td>9</td> <td>ECHO</td><td class="empty"> </td> <td class="empty"> </td><td class="empty"> </td> <td>'hello+world%0A'</td> </tr> <tr> <td class="empty"> </td><td>10</td> <td>TICKS</td><td class="empty"> </td> <td class="empty"> </td><td class="empty"> </td> <td>2</td> </tr> <tr> <td>22</td><td>11</td> <td>TICKS</td><td class="empty"> </td> <td class="empty"> </td><td class="empty"> </td> <td>2</td> </tr> <tr> <td class="empty"> </td><td>12</td> <td>JMP</td><td class="empty"> </td> <td class="empty"> </td><td class="empty"> </td> <td>->7</td> </tr> <tr> <td class="empty"> </td><td>13</td> <td>TICKS</td><td class="empty"> </td> <td class="empty"> </td><td class="empty"> </td> <td>2</td> </tr> <tr> <td>23</td><td>14</td> <td>TICKS</td><td class="empty"> </td> <td class="empty"> </td><td class="empty"> </td> <td>2</td> </tr> <tr> <td>24</td><td>15</td> <td>RETURN</td><td class="empty"> </td> <td class="empty"> </td><td class="empty"> </td> <td>1</td> </tr> </tbody> </table> <p class="simpara">Function name: profile</p> <p class="simpara">Compiled variables: none </p> <table class="doctable informaltable"> <thead> <tr> <th>line</th><th>#</th><th>op</th> <th>fetch</th><th>ext</th><th>return</th> <th>operands</th> </tr> </thead> <tbody class="tbody"> <tr> <td>9</td><td>0</td> <td>ECHO</td><td class="empty"> </td> <td class="empty"> </td><td class="empty"> </td> <td>'profile+function+is+called%0A'</td> </tr> <tr> <td>10</td><td>1</td> <td>RETURN</td><td class="empty"> </td> <td class="empty"> </td><td class="empty"> </td> <td>null</td> </tr> </tbody> </table> </div> </div><hr /><div class="manualnavbar" style="text-align: center;"> <div class="prev" style="text-align: left; float: left;"><a href="internals2.opcodes.throw.html">THROW</a></div> <div class="next" style="text-align: right; float: right;"><a href="internals2.opcodes.unset-dim.html">UNSET_DIM</a></div> <div class="up"><a href="internals2.opcodes.list.html">Opcode Descriptions and Examples</a></div> <div class="home"><a href="index.html">PHP Manual</a></div> </div></body></html>