include和require的異同: 相同點:都可以引入其他的php文件。 不同點:include當出現引入文件錯誤時,只會出現警告,但程序仍然會繼續往下執行。而當require出現錯誤時則會報錯,程序終止。 一般來說都是使用include_once和require_once,而不使用include和require。引入文件的語句要放在最前面,這點就類似C語言。 php變量是區分大小寫的,但是函數名卻不區分大小寫。且不能以數字開頭。例如Abc和abc是一樣的,如果這樣的兩個函數共存在一個文件中就會報錯。 局部變量和全局變量同名下的情況分析; 看下面的一段代碼: $a=45; function abc(){ //定義函數 $a+= 10; } abc(); //調用函數 echo ‘$a=’.$a; 輸出結果是多少呢?結果還是45,為什麼呢?在函數體內的是局部變量,和外部變量$a同名,但不是同一個變量,而是兩個完全不相干的變量。函數內的變量$a隨著函數執行完畢就釋放了。輸出的仍是外部變量,如果要在函數體內使用外部變量(全局變量)那麼就要在內部的同名變量前加上global 聲明。其實在編譯器看來,聲明為global時其實是把外部同名的變量的地址賦給這個局部變量,這時內部變量和外部同名變量是同一地址,所以自然就成了同一變量了。在函數體的形參或沒有聲明為global的局部變量,那麼就是作為局部變量來使用的,作用域就是在函數體內。例如下面的一段代碼輸出結果是45,而不是55. $a=45; function abc($a){ //定義函數 $a += 10; } abc($a); //調用函數 echo ‘$a=’.$a; 在php中一共有三種級別的錯誤: 第一級錯誤:notice,最輕的錯誤,還可以執行 第二級錯誤:warn ,警告,還可以執行 第三級錯誤:error ,程序無法執行下去,這個錯誤是最嚴重的錯誤 unset函數解說: (PHP 3, PHP 4 ) unset -- 釋放給定的變量,當我們不想使用該變量時就可以釋放這個變量。 描述 void unset ( mixedvar [, mixed var [, ...]]) unset()銷毀指定的變量。注意在 PHP 3 中,unset() 將返回 TRUE(實際上是整型值 1),而在 PHP 4 中,unset() 不再是一個真正的函數:它現在是一個語句。這樣就沒有了返回值,試圖獲取 unset() 的返回值將導致解析錯誤。 如果在函數中 unset() 一個全局變量,則只是局部變量被銷毀,而在調用環境中的變量將保持調用unset() 之前一樣的值。即在函數外部該全局變量仍保持原樣。如果在函數中unset() 一個通過引用傳遞的變量,則只是局部變量被銷毀,而在調用環境中的變量將保持調用unset() 之前一樣的值。即形參是個取地址符的情況。 php有點類似C語言,不支持多態,不允許同名函數的存在,但對於形參更靈活,在調用時可以不寫或少寫幾個形參值。還可以給形參賦默認值。例如 function diyMethod($a,$b=3)就是給形參賦默認值為3 ,php函數默認傳值方式是值傳遞,要想使用引用傳遞(地址傳遞),在形參前加上地址符&就可以了。引用傳遞其實有點相當於變相地將形參所對應的調用該函數的傳入參數變成了全局變量。雖然沒有global聲明。引用傳遞會改變傳入參數的值!但要注意這裡的引用並不是C語言的指針.因為指針本身是一個變量,而php的引用其實是變量的一種別名,說白了,就是一個地址可以有多個變量名字。在 PHP 中引用意味著用不同的名字訪問同一個變量內容。當用 global $var 聲明一個變量時實際上建立了一個到全局變量的引用。 php中變量、常量定義方法 1. 定義常量define("CONSTANT", "Hello world."); 常量只能包含標量數據(boolean,integer,float 和 string)。 調用常量時,只需要簡單的用名稱取得常量的值,而不能加“$”符號,如:echoCONSTANT; 注: 常量和(全局)變量在不同的名字空間中。這意味著例如 TRUE 和 $TRUE 是不同的。 2.普通變量$a = "hello"; 3.可變變量(使用兩個美元符號($)) $$a = "world"; 兩個變量都被定義了: $a 的內容是“hello”並且 $hello 的內容是“world”。 因此,可以表述為: echo "$a ${$a}";或者 echo "$a $hello";它們都會輸出:hello world 要將可變變量用於數組,必須解決一個模稜兩可的問題。這就是當寫下 $$a[1] 時,解析器需要知道是想要 $a[1] 作為一個變量呢,還是想要 $$a 作為一個變量並取出該變量中索引為 [1] 的值。解決此問題的語法是,對第一種情況用 ${$a[1]},對第二種情況用 ${$a}[1]。 4.靜態變量 在函數內部static $a =0; 注意:聲明中用表達式的結果對其賦值會導致解析錯誤如static $a =3+3;(error) 靜態變量僅在局部函數域中存在(函數內部),函數執行完之後,變量值不會丟失,可用於遞歸調用 5.全局變量 在函數體內定義的global變量,函數體外可以使用,在函數體外定義的global變量不能在函數體內使用,在全局范圍內訪問變量可以用特殊的 PHP 自定義 $GLOBALS 數組: 如:$GLOBALS["b"] = $GLOBALS["a"] +$GLOBALS["b"]; 在一個函數域內用 global 語句導入的一個真正的全局變量實際上是建立了一個到全局變量的引用 global $obj; 注:對於變量的 static 和 global 定義是以應用的方式實現的 6.給變量賦值:傳地址賦值(簡單引用): $bar = &$foo; //加&符號到將要賦值的變量前 改動新的變量將影響到原始變量,這種賦值操作更加快速 注意:只有命名變量才可以傳地址賦值 注意:如果 $bar = &$a; $bar = &$foo; 改變$bar的值只能改變變量foo的值,而不改變a的值(引用改變了) 7.PHP超全局變量$GLOBALS :包含一個引用指向每個當前腳本的全局范圍內有效的變量。該數組的鍵標為全局變量的名稱。從 PHP 3 開始存在 $GLOBALS 數組。 $_SERVER :變量由 Web 服務器設定或者直接與當前腳本的執行環境相關聯。類似於舊數組 $HTTP_SERVER_VARS 數組(依然有效,但反對使用)。 $_GET :經由 HTTP GET 方法提交至腳本的變量。 $_POST :經由 HTTP POST 方法提交至腳本的變量。 $_COOKIE :經由 HTTP Cookies 方法提交至腳本的變量。 $_FILES :經由 HTTP POST 文件上傳而提交至腳本的變量。 文件上傳表單中要有 enctype="multipart/form-data" $_ENV :執行環境提交至腳本的變量。 $_REQUEST :經由 GET,POST 和 COOKIE 機制提交至腳本的變量,因此該數組並不值得信任。所有包含在該數組中的變量的存在與否以及變量的順序均按照 php.ini 中的variables_order 配置指示來定義。該數組沒有直接模擬 PHP4.1.0 的早期版本。參見 import_request_variables()。 注意:自 PHP 4.3.0 起,$_FILES 中的文件信息不再存在於 $_REQUEST 中。 $_SESSION :當前注冊給腳本會話的變量。 如何禁用phpinfo(): php.ini中 disable_functions = phpinfo() 重啟web服務器。 php中的常量 常量只能用define(常量名,常量值); 常量只能包含標量數據(boolean,integer,float 和 string)。 可以簡單的通過指定其名字來取得常量的值,不要在常量前面加上 $ 符號。如果常量名是動態的,也可以用函數 constant() 來讀取常量的值。用 get_defined_constants() 可以獲得所有已定義的常量列表。 注: 常量和(全局)變量在不同的名字空間中。這意味著例如 TRUE 和 $TRUE 是不同的。 如果使用了一個未定義的常量,PHP 假定想要的是該常量本身的名字,如同用字符串調用它一樣(CONSTANT 對應"CONSTANT")。此時將發出一個 E_NOTICE 級的錯誤。參見手冊中為什麼 $w3sky[bar] 是錯誤的(除非事先用 define() 將 bar 定義為一個常量)。如果只想檢查是否定義了某常量,用 defined() 函數。 常量和變量不同: * 常量前面沒有美元符號($); * 常量只能用 define() 函數定義,而不能通過賦值語句; * 常量可以不用理會變量范圍的規則而在任何地方定義和訪問; * 常量一旦定義就不能被重新定義或者取消定義; * 常量的值只能是標量。 定義常量 <?PHP define("CONSTANT", "Helloworld."); echo CONSTANT; // outputs "Helloworld." echo Constant; // outputs "Constant"and issues a notice. ?> 跳水比賽,10個評委打分,去掉一個最高分和一個最低分,然後求剩下的評委的分數總和的平均分為該運動員的得分,試輸出給最高分的評委和給最低分的評委以及該運動員的得分。 答案如下:
<?php $arr = array("arial"=>12,"ms"=>9.0,"ok"=>7.1,"song"=>5.0,"bold"=>3.8,"know"=>2.7,"wow"=>1.7,"serial"=>7.9,"moder"=>7.6,"froke"=>6.7); function getMinMax($arr,$k=true){ //$k 為 true時輸出最小值,為false 則輸出最大值,還有平均數 $num=$arr["arial"];$sum=0;$s="arial"; foreach($arr as $i => $value){ if($k){ if($value<$num){ $num =$value;$s=$i; } }else { if($value>$num){ $num =$value;$s=$i; } } } $sum = array_sum($arr); return array($sum,$num,$s); } $newArr=getMinMax($arr,true); $sum=$newArr[0]-$newArr[1]; echo 'the lowest degree people is '.$newArr[2]."<br />"; unset($newArr); $newArr=getMinMax($arr,false); $sum -= $newArr[1]; echo '<br />the highest degree people is '.$newArr[2]; echo '<br />the average degree is '.$sum/(count($arr)-2); ?>