欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

PHP中static關鍵字原理的學習研究分析

 更新時間:2011年07月18日 23:20:58   作者:  
PHP中static關鍵字原理的學習研究分析,學習php的朋友可以參考下。
看PHP手冊的時候發(fā)現了下面這樣一段代碼:
復制代碼 代碼如下:

<?php
function Test()
{
static $count = 0;
$count++;
echo $count;
if ($count < 10) {
Test();
}
$count--;
}
?>

執(zhí)行結果如下:
這是一個遞歸的函數,聲明的靜態(tài)變量count記錄次數,輸出1~10。
我在看的時候有個疑惑,遞歸調用的時候 static $count = 0; 語句會重復執(zhí)行,這為什么不會導致count變量被重復賦值呢?帶著這個疑問和同事研究了一下,測試用代碼如下:
復制代碼 代碼如下:

<?php
echo 'start<br />';
static $a = 10;
echo "$a <br />";
unset($GLOBALS['a']);
echo "$a <br />";
static $a = 20;
echo "$a <br />";
$GLOBALS['a'] = 10;
echo "$a <br />";
static $a = 30;
echo "$a <br />";
unset($GLOBALS['a']);
echo "$a <br />";
static $a;
echo "$a <br />";
static $a = 40;
echo "$a <br />";
$a = 100;
echo "$a <br />";
static $a = 50;
echo "$a <br />";
static $a = 4;
echo "$a <br />";
echo 'end <br />';
exit;
?>

執(zhí)行結果如下:
start
  1. Notice: Undefined variable: a 
  2. 10 
  3. 10 
  4. Notice: Undefined variable: a 
  5. 10 
  6. 10 
  7. 100 
  8. 100 
  9. 100 
  10. end
(結果中關于文件位置的部分已刪去。也可以去掉echo語句使用zend的debug功能查看,這樣結果更清晰)

代碼第5行第一次輸出$a的值為4,由此推測PHP在頁面初始化的時候分配靜態(tài)變量的內存,此時使用了同一個變量的最后一次聲明的值(這個可以把4改為其他數測試)。代碼第7行調用unset函數銷毀變量$a,再次輸出$a的值時看到未定義變量的提示,說明變量已經被銷毀。

第10行再次輸出時,輸出結果仍是4而不是20,有兩種可能,一個是php再次初始化了$a的值,另一種是php使用了$a被銷毀前的值,這個問題在第20行輸出的時候解決。第16行$a銷毀的時候值為10,第19行聲明后輸出仍為10。

第11行將$a的值修改為10,在14行再次聲明$a,17行輸出認為10。推測為重復聲明時php還是使用靜態(tài)變量內存中的值,而不再次賦值。

至此,手冊中發(fā)現的問題,大致上已經解決了,即遞歸調用中的聲明沒有改變$count的值,所以遞歸在$count=10時成功停止。

可能有理解不正確的地方,歡迎拍磚。

相關文章

  • php析構函數的簡單使用說明

    php析構函數的簡單使用說明

    與構造函數相反,在PHP5中,可以定義一個名為__destruct()的函數,稱之為PHP5析構函數,PHP將在對象在內存中被銷毀前調用析構函數,使對象在徹底消失之前完成一些工作。對象在銷毀一般可以通過賦值為null實現。
    2015-08-08
  • PHP實現的加密解密處理類

    PHP實現的加密解密處理類

    這篇文章主要介紹了PHP實現的加密解密處理類,結合實例形式分析了php加密解密類的定義與使用技巧,需要的朋友可以參考下
    2016-05-05
  • PHP開發(fā)不能違背的安全規(guī)則 過濾用戶輸入

    PHP開發(fā)不能違背的安全規(guī)則 過濾用戶輸入

    作為PHP程序員,特別是新手,對于互聯網的險惡總是知道的太少,對于外部的入侵有很多時候是素手無策的,他們根本不知道黑客是如何入侵的、提交入侵、上傳漏洞、sql 注入、跨腳本攻擊等等。
    2011-05-05
  • PHP數據流應用的一個簡單實例

    PHP數據流應用的一個簡單實例

    PHP數據流應用的一個簡單實例代碼,需要的朋友可以參考下
    2012-09-09
  • PHP遍歷數組的三種方法及效率對比分析

    PHP遍歷數組的三種方法及效率對比分析

    這篇文章主要介紹了PHP遍歷數組的三種方法及效率對比,實例分析了foreach、while與for三種遍歷數組的方法與相關的效率比對,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-02-02
  • PHP進階學習之依賴注入與Ioc容器詳解

    PHP進階學習之依賴注入與Ioc容器詳解

    這篇文章主要介紹了PHP進階學習之依賴注入與Ioc容器,結合實例形式詳細分析了依賴注入與Ioc容器概念、原理、用法及相關操作注意事項,需要的朋友可以參考下
    2019-06-06
  • apache php模塊整合操作指南

    apache php模塊整合操作指南

    本文將詳細介紹Linux下Apache、php3、MySQL的整合的相關問題的解決方法,需要的朋友可以參考下
    2012-11-11
  • 計算php頁面運行時間的函數介紹

    計算php頁面運行時間的函數介紹

    本篇文章是對計算php頁面運行時間的函數進行了詳細的分析介紹,需要的朋友參考下
    2013-07-07
  • Yii框架調試心得--在頁面輸出執(zhí)行sql語句

    Yii框架調試心得--在頁面輸出執(zhí)行sql語句

    這篇文章主要介紹了Yii框架調試心得--在頁面輸出執(zhí)行sql語句,需要的朋友可以參考下
    2014-12-12
  • PHP如何實現防止重復提交

    PHP如何實現防止重復提交

    防抖(Debounce)是一種防止重復提交的策略,它通過延遲一定時間來合并連續(xù)的操作,以確保只執(zhí)行一次,本文為大家整理了幾種防抖的實現方法,希望對大家有所幫助
    2023-09-09

最新評論