php類self
㈠ php實例化
給你舉個例子吧:
比如說:現在有user.class.php
mysql.class.php
現在用戶類有注冊、登錄等一系列的操作(要使用資料庫類)
我們直接在user.class.php
中把資料庫類給實力化了
這樣就了可以達到你的那個效果了;
千萬不要在將所有的方法放在一個類中,這樣是不好做法,住好是一個類只對於他本身的方法;這樣做的目的是讓邏輯更加清晰,和降低伺服器的資源消耗。
㈡ PHP預定義變數$_SERVER中的PHP_SELF和SCRIPT_FILENAME有什麼詳細區別
SCRIPT_FILENAME指向當前執行腳本的絕對路徑;PHP_SELF當前正在執行腳本的文件名,兩者經常混淆,舉一個例子你就明白了,假如D盤web文件夾為根目錄,web下的htdocs文件夾有文件a.php,語句如下:
<?php
include(common/b.php);
?>,
htdocs文件下common目錄b.php,語句如下:
<?php
echo $_SERVER['PHP_SELF'];
echo "<br />";
echo $_SERVER['SCRIPT_FILENAME'];
?>
運行a.php得出結果:
/htdocs/in.php
D:/web/htdocs/in.php
可以看出PHP_SELF只輸出以根目錄為開始網站文件路徑,但是SCRIPT_FILENAME輸出的是所在硬碟的文件絕對路徑,可以認為一個是輸出網路文件路徑,一個是文件所在路徑.
SCRIPT_NAME指的是當前腳本文件名,比如b.php有echo $_SERVER['SCRIPT_NAME'];那麼輸出是/htdocs/common/b.php,明白了,會直接把當前語句所在腳本文件路徑輸出。
㈢ php 單例模式
單例模式是一種常用的軟體設計模式,可以保證系統中一個類只有一個實例,從而達到節約系統資源提升特殊類使用效率的目的
php實現單例模式的方法
classA{
//靜態屬性
privatestatic$_instance;
//空的克隆方法,防止被克隆
privatefunction__clone(){}
//獲取實例
(){
if(!(self::$_instanceinstanceofself)){
self::$_instance=newA();
}
returnself::$_instance;
}
}
//調用
$obj=A::getInstance();
㈣ php類屬性的賦值問題
cache_factory::$cache_factory 是 類 cache_factory 的一個單例 , 該語句的意思是給 這個單例實例的cache_config屬性賦初值,我這么說能聽懂嗎?!
享笑網為您解答。可以來我們這里看看,有不清楚的,我再給你解釋。
㈤ 在php中self與$this的分別
1、意思上的區別
self代表類,$this代表對象(self是引用靜態類的類名,而$this是引用非靜態類的實例名)
2、用法上的區別
能用$this的地方一定使用self,能用self的地方不一定能用$this。
(5)php類self擴展閱讀:
Python中self用法詳解
1、以Student類為例,在Python中,定義類如下:
class Student(object):
pass
(Object)表示該類從哪個類繼承下來的,Object類是所有類都會繼承的類。
2、實例:定義好了類,就可以通過Student類創建出Student的實例,創建實例是通過類名+()實現:
student = Student()
3、由於類起到模板的作用,因此,可以在創建實例的時候,把我們認為必須綁定的屬性強制填寫進去。這里就用到Python當中的一個內置方法__init__方法,例如在Student類時,把name、score等屬性綁上去:
class Student(object):
def __init__(self, name, score):
self.name = name
self.score = score
㈥ 哪位高手能詳解下 PHP session_set_save_handler() 。 往往會寫這樣一個類,搜索了寫答案,但不詳細
我有代碼。但是我的報錯。好像是配置文件哪兒沒弄對:
Warning: Unknown: Unknown session.serialize_handler. Failed to encode session object. in Unknown on line 0
類的代碼:
class session{
private static $handler=null;
private static $ip=null;
private static $lifetime=null;
private static $time=null;
private static function init($pdo){
self::$handler=$handler;
self::$ip = !empty($_SERVER["REMOTE_ADDR"])?$_SERVER["REMOTE_ADDR"]:unknown;
self::$lifetime=ini_get("session.gc_maxlifetime");
self::$time=time();
}
static function start(PDO $pdo){
self::init($pdo);
session_set_save_handler(
array(__CLASS__,"open"),
array(__CLASS__,"close"),
array(__CLASS__,"read"),
array(__CLASS__,"write"),
array(__CLASS__,"destroy"),
array(__CLASS__,"gc")
);
session_start();
}
public static function open($path,$name){
return true;
}
public static function close(){
return true;
}
public static function read($PHPSESSID){
$sql="select PHPSESSID,update_time,client_ip,data from session where PHPSESSID= ?";
$stmt=self::$handler->prepare($sql);
$stmt->execute(array($PHPSESSID));
if(!$result=$stmt->fetch(PDO::FETCH_ASSOC)){
return "";
}
if(self::$ip != $result['client_ip']){
self::destroy($PHPSESSID);
return "";
}
if(($result['update_time'] + self::$lifetime) < self::$time){
self::destroy($PHPSESSID);
return "";
}
return $result["data"];
}
public static function write($PHPSESSID,$data){
$sql="select PHPSESSID,update_time,client_ip,data from session where PHPSESSID= ?";
$stmt=self::$handler->prepare($sql);
$stmt->execute(array($PHPSESSID));
if($result=$stmt->fetch(PDO::FETCH_ASSOC)){
if($result["data"] != $data || self::$time > ($result['update_time']+30)){
$sql="update session set update_time=?,data=? where PHPSESSID=?";
$stmt=self::$handler->prepare($sql);
$stmt->execute(array(self::$time,$data,$PHPSESSID));
}
}else{
if(!empty($data)){
$sql="insert into session(PHPSESSID,update_time,client_ip,data values(?,?,?,?))";
$sth=self::$handler->prepare($sql);
$sth->execute(array($PHPSESSID,self::$time,self::$ip,$data));
}
}
return true;
}
public static function destroy($PHPSESSID){
$sql="delete from session where PHPSESSID=?";
$stmt=self::$handler->prepare($sql);
$stmt->execute(array($PHPSESSID));
return true;
}
public static function gc($lifetime){
$sql="delete from session where update_time < ?";
$stmt=self::$handler->prepare($sql);
$stmt->execute(array(self::$time-$lifetime));
return true;
}
}
try{
$pdo=new PDO("mysql:host=localhost;dbname=shoping","root","123456");
}catch(PDDException $e){
echo $e->getMessage();
}
session::start($pdo);
㈦ PHP中this,self和static的區別
PHP支持類和面向對象結構,PHP的類的靜態函數和變數不與任何特定類的實例相關聯(換句話說,一個對象)。
相反,靜態函數和變數與類定義本身相關聯。換言之,一個類的所有實例都共享相同的靜態變數。在一個類的方法(函數)的上下文中,靜態變數和函數被訪問使用self::,在一個類的對象(實例)的上下文中使用其他方法和變數時用this。
靜態函數只能使用靜態變數,靜態函數和變數的引用是通過 self::函數名() 和 self::變數名。上述實例中,靜態變數的引用是由類名(exampleClass::$foo),或者self::(self::$foo),當在這個類的靜態方法[稱為 靜態函數()]里使用時。類的正則函數和變數需要一個對象上下文來引用,他們不能脫離對象上下文而存在。對象上下文由$this提供。在上述函數中,$bar 是一個正則變數,所以它被 $obj->bar(上下文使用變數obj) 來引用,或者使用 $this->bar(再次在一個對象的方法里在一個對象上下文中) 來引用。
self 不使用前面的 $,因為 self 不意味著是一個變數而是類結構本身。而 $this 引用一個特定的變數,所以有前面的 $ 。
㈧ php this和self的區別
面向對象編程(OOP,Object Oriented Programming)現已經成為編程人員的一項基本技能。利用OOP的思想進行PHP的高級編程,對於提高PHP編程能力和規劃web開發構架都是很有意義的。
PHP5 經過重寫後,對OOP的支持額有了很大的飛躍,成為了具備了大部分面向對象語言的特性的語言,比PHP4有了很多的面向對象的特性。這里我主要談的是 this,self,parent 三個關鍵字之間的區別。從字面上來理解,分別是指 這、自己、父親。先初步解釋一下,this是指向當前對象的指針(可以看成C裡面的指針),self是指向當前類的指針,parent是指向父類的指針。 我們這里頻繁使用指針來描述,是因為沒有更好的語言來表達。關於指針的概念,大家可以去參考網路。
下面我們就根據實際的例子結合來講講。
class name //建立了一個名為name的類
{
private $name; //定義屬性,私有
//定義構造函數,用於初始化賦值
function __construct( $name )
{
$this->name = $name; //這里已經使用了this指針語句①
}
//析構函數
function __destruct(){}
//列印用戶名成員函數
function printname()
{
print( $this->name ); //再次使用了this指針語句②,也可以使用echo輸出
}
}
$obj1 = new name( "PBPHome" ); //實例化對象 語句③
//執行列印
$obj1->printname(); //輸出: PBPHome
echo "
"; //輸出:回車
//第二次實例化對象
$obj2 = new name( "PHP" );
//執行列印
$obj2->printname(); //輸出:PHP
?>
說 明:上面的類分別在 語句①和語句②使用了this指針,那麼當時this是指向誰呢?其實this是在實例化的時候來確定指向誰,比如第一次實例化對象的時候(語句③),那 么當時this就是指向$obj1對象,那麼執行語句②的列印時就把 print( $this->name ),那麼當然就輸出了"PBPHome"。第二個實例的時候,print( $this->name )變成了print( $obj2->name ),於是就輸出了"PHP"。所以說,this就是指向當前對象實例的指針,不指向任何其他對象或類。
{二}。PHP中this,self,parent的區別之二self篇
此篇我們就self的用法進行講解
首 先我們要明確一點,self是指向類本身,也就是self是不指向任何已經實例化的對象,一般self使用來指向類中的靜態變數。假如我們使用類裡面靜態 (一般用關鍵字static)的成員,我們也必須使用self來調用。還要注意使用self來調用靜態變數必須使用 :: (域運算符號),見實例。
class counter //定義一個counter的類
{
//定義屬性,包括一個靜態變數$firstCount,並賦初值0 語句①
private static $firstCount = 0;
private $lastCount;
//構造函數
function __construct()
{
$this->lastCount = ++self::$firstCount; //使用self來調用靜態變數 語句②
}
//列印lastCount數值
function printLastCount()
{
print( $this->lastCount );
}
}
//實例化對象
$obj = new Counter();
$obj->printLastCount(); //執行到這里的時候,程序輸出 1
?>
這 里要注意兩個地方語句①和語句②。我們在語句①定義了一個靜態變數$firstCount,那麼在語句②的時候使用了self調用這個值,那麼這時候我們 調用的就是類自己定義的靜態變數$frestCount。我們的靜態變數與下面對象的實例無關,它只是跟類有關,那麼我調用類本身的的,那麼我們就無法使 用this來引用,因為self是指向類本身,與任何對象實例無關。然後前面使用的this調用的是實例化的對象$obj,大家不要混淆了。
關於self就說到這里,結合例子還是比較方便理解的。第二篇結束。
{三}PHP中this,self,parent的區別之三parent篇
此篇我們就parent的用法進行講解。
首先,我們明確,parent是指向父類的指針,一般我們使用parent來調用父類的構造函數。實例如下:
//建立基類Animal
class Animal
{
public $name; //基類的屬性,名字$name
//基類的構造函數,初始化賦值
public function __construct( $name )
{
$this->name = $name;
}
}
//定義派生類Person 繼承自Animal類
class Person extends Animal
{
public $personSex; //對於派生類,新定義了屬性$personSex性別、$personAge年齡
public $personAge;
//派生類的構造函數
function __construct( $personSex, $personAge )
{
parent::__construct( "PBPHome" ); //使用parent調用了父類的構造函數 語句①
$this->personSex = $personSex;
$this->personAge = $personAge;
}
//派生類的成員函數,用於列印,格式:名字 is name,age is 年齡
function printPerson()
{
print( $this->name. " is " .$this->personSex. ",age is " .$this->personAge );
}
}
//實例化Person對象
$personObject = new Person( "male", "21");
//執行列印
$personObject->printPerson(); //輸出結果:PBPHome is male,age is 21
?>
里 面同樣含有this的用法,大家自己分析。我們注意這么個細節:成員屬性都是public(公有屬性和方法,類內部和外部的代碼均可訪問)的,特別是父類 的,這是為了供繼承類通過this來訪問。關鍵點在語句①: parent::__construct( "heiyeluren" ),這時候我們就使用parent來調用父類的構造函數進行對父類的初始化,這樣,繼承類的對象就都給賦值了name為PBPHome。我們可以測試下, 再實例化一個對象$personObject1,執行列印後name仍然是PBPHome。
總結:this是指向對象實例的一個指針,在實例化的時候來確定指向;self是對類本身的一個引用,一般用來指向類中的靜態變數;parent是對父類的引用,一般使用parent來調用父類的構造函數。
㈨ PHP里$_SERVER['HTTP_HOST']和$_SERVER['PHP_SELF']區別
兩者的區別在於含義不同:
假如命令行的地址是:xxx
那麼:$_SERVER['HTTP_HOST']=='www..com'$_SERVER['PHP_SELF']=='/index.php'所以前者是主機地址,後者是腳本文件的絕對路徑。
(9)php類self擴展閱讀:
1、新對象模式
*構造函數和析構函數* 對象的引用 * 對象的克隆 * 對象中的私有、公共及受保護模式 * 介面 (Interfaces)
* 抽象類 * __call * __set 和 __get * 靜態成員
2、構造函數和析構函數
在 PHP4 中,當函數與對象同名時,這個函數將成為該對象的構造函數,並且在 PHP4 中沒有析構函數的概念。
在 PHP5 中,構造函數被統一命名為 __construct,並且引入了析構函數的概念,被統一命名為 __destruct。
3、對象的引用
在PHP4中,傳遞變數給一個函數或方法,實際是把這個變數做了一次復制,也就意味著你傳給函數或方法的是這個變數的一個副本,除非你使用了引用符號「&;」 來聲明是要做一個引用,而不是一個 Copy。在 PHP5中,對象總是以引用的形式存在的,對象中的賦值操作同樣也都是一個引用操作。
4、對象的克隆
當一個對象始終以引用的形式來被調用時,如果我想得到該對象的一個副本,該怎麼辦呢?PHP5 提供了一個新的功能,就是對象的克隆,語法為 __clone。
5、抽象類
抽象類不能被實例化。
抽象類與其它類一樣,允許定義變數及方法。
抽象類同樣可以定義一個抽象的方法,抽象類的方法不會被執行,不過將有可能會在其派生類中執行。
6、__call
PHP5 的對象新增了一個專用方法 __call(),這個方法用來監視一個對象中的其它方法。如果你試著調用一個對象中不存在的方法,__call 方法將會被自動調用。
參考資料:網路——PHP