`
ythzjk
  • 浏览: 75722 次
  • 性别: Icon_minigender_1
  • 来自: 上海
最近访客 更多访客>>
社区版块
存档分类
最新评论

php_manual学习之翻译:第19章 类与对象(PHP5)(连载)

    博客分类:
  • php
阅读更多

发布时间:2006-9-26 14:46   作者: forest (木林森)   来源PHPCHIAN

php_manual学习之翻译:第19章 类与对象(PHP5)之一:Visibility(访问控制)

    由于php手册从这一章节开始没有翻译,都是英文,近来自己开始学习php5中的面向对象编程,
为方便学习和阅读,所以把其翻译之,发上来与大家分享,有不妥之处请大家批评指正!

    申请加精,我花了好长的时间来翻译的东西,呵呵~_~

     对属性或方法的访问控制,是通过在前面添加关键字 public、protected 或 private 来实现的。
由 public 所定义的类成员可以在任何地方被访问;由 protected 所定义的类成员则可以被其所在类
的子类和父类访问(当然,该成员所在的类也可以访问);而由 private 定义的类成员则只能被其所
在类访问。对类成员的访问控制类成员都必须使用关键字public、protected 或 private 进行定义
例 10.9. 声明类成员
复制PHP内容到剪贴板
PHP代码:

<?php
/**  Define MyClass  */
class MyClass
{  public $public 'Public';
   protected 
$protected 'Protected';
   private 
$private 'Private';
   function 
printHello()
   {   echo 
$this->public;
       echo 
$this->protected;
        echo 
$this->private;
   }
}
$obj = new MyClass();
echo 
$obj->public// // Works
echo $obj->protected// Fatal Error
echo $obj->private// Fatal Error
$obj->printHello();// Shows Public, Protected and Priv 
class MyClass2 extends MyClass  //Define MyClass2 
{// We can redeclare the public and protected method, but not private
    
protected $protected 'Protected2';
    function 
printHello()
   {   echo 
$this->public;
       echo 
$this->protected;
       echo 
$this->private;
   }
}
$obj2 = new MyClass2();
echo 
$obj->public// Works
echo $obj2->private// Undefined
echo $obj2->protected// Fatal Error
$obj2->printHello();// Shows Public, Protected2, not Private
?>

注意:
在 PHP 4 中使用 var 关键字对变量进行定义的方法在 PHP 5 的面向对象语法中不再使用。为了顾及兼容性,
在类中定义一个变量的话,该变量会被自动设为 public,并且产生一个 E_STRICT 警告。
对方法的访问控制类中的方法都必须使用关键字public、protected 或 private 进行定义。如果没有设置
这些关键字,则该方法会被设置成默认的 public。
例 10.10. 声明类中的方法
复制PHP内容到剪贴板
PHP代码:

<?php
class MyClass   //Define MyClass
{   public function __construct() { }
    public function 
MyPublic() { }
    protected function 
MyProtected() { }
    private function 
MyPrivate() { }
    function 
Foo()
   {   
$this->MyPublic();
       
$this->MyProtected();
       
$this->MyPrivate();
   }
}
$myclass = new MyClass;
$myclass->MyPublic(); // 
$myclass->MyProtected(); // 
$myclass->MyPrivate(); // 
$myclass->Foo();
class 
MyClass2 extends MyClass    //Define MyClass2
{  // This is public
   
function Foo2()
   {   
$this->MyPublic();
       
$this->MyProtected();
       
$this->MyPrivate();
   }
}
$myclass2 = new MyClass2;
$myclass2->MyPublic();
$myclass2->Foo2();
?>

[ 本帖最后由 forest 于 2006-5-4 22:06 编辑 ]

第19章 类与对象(PHP5)之二:范围解析操作符(::)--Scope Resolution Operator (::)

范围解析操作符(也可称作 Paamayim Nekudotayim)或者更简单地说是一对冒号,可以用于访问静态成员、
方法和常量,还可以用于覆盖类中的成员和方法。当在类的外部访问这些静态成员、方法和常量时,必须使用类的
名字。把 Paamayim Nekudotayim 选作该操作符的名字似乎有些奇怪。然而,这是Zend开发小组在写
Zend Engine 0.5(被用于 PHP 3 中)时所作出的决定。事实上这个词在希伯莱文就是双冒号的意思。
例 10.11. 在类的外部使用 :: 操作符
复制PHP内容到剪贴板
PHP代码:

<?php
class MyClass 
{   const CONST_VALUE 'A constant value';
}
echo 
MyClass::CONST_VALUE;
?>

self和parent这两个特殊的关键字是用于在类的内部对成员或方法进行访问的。
例 10.12. :: from inside the class definition
复制PHP内容到剪贴板
PHP代码:

<?php
class OtherClass extends MyClass
{   public static $my_static 'static var';
    public static function 
doubleColon() 
    {   echo 
parent::CONST_VALUE "\n";
       echo 
self::$my_static "\n";
   }
}
OtherClass::doubleColon();
?>

当一个子类覆盖其父类中的方法时,PHP不会再执行父类中已被覆盖的方法,直到子类中调用这些方法为止。这种机制也作用于构造函数和析构函数、重载及魔术函数。
例 10.13. 调用父类的方法
复制PHP内容到剪贴板
PHP代码:

<?php
class MyClass
{    protected function myFunc() {    echo"MyClass::myFunc()\n";   }
}
class 
OtherClass extends MyClass
{  // Override parent's definition
   
public function myFunc()
   {  
// But still call the parent function
       
parent::myFunc();
       echo 
"OtherClass::myFunc()\n";
   }
}
$class = new OtherClass();
$class->myFunc();
?>

第19章 类与对象(PHP5)之三:静态关键字(Static Keyword)

声明静态的类的成员和方法,使它不需要一个类的实例.一个static成员的声明不能通过一个类对象的实例来访问
(尽管一个静态方法可以)。静态声明必须在可见性声明之后。为了兼容PHP 4,如果没有可见性被声明,那么成员和
方法将被当作是已经声明为public。
由于静态方法可以调用非对象实例,伪变量$this不可以在声明为静态的方法中使用。
事实上static方法调用形式在编译时被确定。当使用必须要声明的类名时,方法是完全标识和无继承规则的应用。
当使用必须要声明的类名时,这种方法就被完全确认,而且没有使用继承的规则。
如果self已经被声明,那么self就被当前所属的类所解释。也不适用与继承规则。静态属性不能通过箭头操作符->.
访问非静态方法,这将产生一个E_STRICT 级的警告。
例子 19-13. 静态成员的例子
复制PHP内容到剪贴板
PHP代码:

<?php
class Foo
{   public static $my_static='foo';
    public function 
staticValue(){   return self::$my_static;   }
}
class 
Bar extends Foo
{   public function fooStatic(){   return parent::$my_static;   }
}
print 
Foo::$my_static."\n";
$foo = new Foo();
print 
$foo->staticValue()."\n";
print 
$foo->my_static."\n";// Undefined "Property" my_static 
// $foo::my_static is not possible
print Bar::$my_static."\n";
$bar = new Bar();
print 
$bar->fooStatic()."\n";
?>

例子 19-14.静态方法实例(Static method example)
复制PHP内容到剪贴板
PHP代码:

<?php
class Foo
{   public static function aStaticMethod() {    }
}
Foo::aStaticMethod();
?>

第19章 类与对象(PHP5)之四:类常量(Class Constants)


可以在每个基类中定义常量使它保持不变。在你不使用$符号去声明或使用它时,常量不同于普通变量。就象静态成员,常量值不能通过对象的实例来访问(而应使用$object::constant). 常量值必须是一个常量表达式,而不是一个变量,一个类的成员,一个数学表达式或函数调用的结果。
例子 19-15. 定义并使用一个常量
复制PHP内容到剪贴板
PHP代码:

<?php
class MyClass
{   const constant 'constant value';
    function 
showConstant() {   echo  self::constant."\n";   }
}
echo 
MyClass::constant."\n";
$class = new MyClass();
$class->showConstant();// echo $class::constant; is not allowed
?>

第19章 类与对象(PHP5)之五:抽象类(Class Abstraction)

PHP 5中引入了抽象类和抽象方法。不允许创建一个已经定义为abstract的类的一个实例。任何至少包含一个抽象方法的类也必须是抽象的。被定义为抽象的方法仅仅是声明方法的一个信号,并不能定义它们的实现。
当从一个抽象类继承时,在父类中所有抽象方法的标记的声明必须通过子类定义;另外,这些方法必须用定义相同的访问属性。例如,如果方法被定义为protected类型,执行函数必须定义为protected或public.
例子 19-16. 抽象类例子
复制PHP内容到剪贴板
PHP代码:

<?php
abstract class AbstractClass
{   // Force Extending class to define this method
    
abstract protected function getValue();
    abstract protected function 
prefixValue($prefix);
    public function 
printOut()  // Common method
    
{   
        print 
$this->getValue()."\n";
    }
}
class 
ConcreteClass1 extends AbstractClass
{   protected function getValue()
    {  
        return 
"ConcreteClass1";  
    }
    public function 
prefixValue($prefix)
    { 
        return 
"{$prefix}ConcreteClass1"
    }
}
class 
ConcreteClass2 extends AbstractClass
{   public function getValue()
    {  
        return 
"ConcreteClass2";  
    }
    public function 
prefixValue($prefix)
    { 
        return
"{$prefix}ConcreteClass2";
    }
}
$class1 = new ConcreteClass1;
$class1->printOut();
echo 
$class1->prefixValue('FOO_') ."\n";
$class2 = new ConcreteClass2;
$class2->printOut();
echo 
$class2->prefixValue('FOO_') ."\n";
?>

上例将输出:
复制内容到剪贴板
代码:
ConcreteClass1
FOO_ConcreteClass1
ConcreteClass2
FOO_ConcreteClass2
旧代码拥有非用户自定义的命名为abstract的类或函数将要运行如果没有被修改。

第19章 类与对象(PHP5)之六:对象接口(Object Interfaces)

对象接口允许你创建一个指定类的方法的执行代码,而不必说明这些方法是如何被操作(处理)的。
接口被用来定义接口关键字的使用,同样作为一个标准类,但没有任何方法有它们内容的定义。
在接口中所有的方法必须声明为public,这是接口的特性。
implements (执行,实现)
为了实现一个接口,使用了implements操作。在接口中所有的方法必须在一个类的内部实现;疏忽这些将导致
一个致命错误。如果渴望通过使用一个逗号分开每个接口,类可以实现多个接口。
例子 19-17. 接口实例
复制PHP内容到剪贴板
PHP代码:

<?php
// Declare the interface 'iTemplate'
interface iTemplate
{   public function setVariable($name$var);
    public function 
getHtml($template);
}
// Implement the interface . This will work
class Template implements iTemplate
{   private $vars = array();
    public function 
setVariable($name,$var){  $this->vars[$name]=$var;  }
    public function 
getHtml($template)
    {   foreach(
$this->vars as $name => $value
         {   
$template str_replace('{'.$name.'}',$value,$template);
        }
         return 
$template;
    }
}
//This will not work Fatal error:Class BadTemplate contains 1 abstract 
//methos and must therefore be declared abstract (iTemplate::getHtml)
class BadTemplate implements iTemplate
{   private $vars = array();
    public function 
setVariable($name,$var){  $this->vars[$name] = $var;  }

?>

第19章 类与对象(PHP5)之七:重载(Overloading)

方法调用和成员访问都能通过__call,__get和__set方法被加载。这些方法将只有当你试图访问不包括成员或方法的对象或继承对象时触发。不是所有的重载方法都必须被定义为static.
从PHP 5.1.0开始也可以通过__isset()和__unset()方法逐个重载isset()和unset()函数。
成员函数重载(Member overloading)
void __set ( string name, mixed value )
mixed __get ( string name )
bool __isset ( string name )
void __unset ( string name )
类成员可以通过定义这些指定的特定方法加载类中的自定义代码。$name参数被用来命名变量,这些变量必须是被设置的或返回的。__set()方法的$value参数指定设置$name的对象的值。
例子 19-18.使用__get,__set,__isset和__unset重载的例子
复制PHP内容到剪贴板
PHP代码:

<?php
class Setter
{   public $n;
    private 
$x = array("a" => 1"b" => 2"c" => 3);
    private function 
__get($nm)
    {   echo 
"Getting [$nm]\n";
        if (isset(
$this->x[$nm])) 
         {   
$r $this->x[$nm];
            print 
"Returning: $r\n";
            return 
$r;
        } else {   echo 
"Nothing!\n";   }
    }
    private function 
__set($nm$val)
    {   echo 
"Setting [$nm] to $val\n";
        if (isset(
$this->x[$nm])) 
         {   
$this->x[$nm] = $val;
            echo 
"OK!\n";
        } else {    echo 
"Not OK!\n";   }
    }
    private function 
__isset($nm)
    {   echo 
"Checking if $nm is set\n";
         return isset(
$this->x[$nm]);
    }
    private function 
__unset($nm)
    {   echo 
"Unsetting $nm\n";
        unset(
$this->x[$nm]);
    }
}
$foo = new Setter();
$foo->1;
$foo->100;
$foo->a++;
$foo->z++;
var_dump(isset($foo->a)); //true
unset($foo->a);
var_dump(isset($foo->a)); //false
// this doesn't pass through the __isset() method
because 'n' is a public property
var_dump
(isset($foo->n));
var_dump($foo);
?>

上例将输出:
复制内容到剪贴板
代码:
Setting [a] to 100
OK!
Getting [a]
Returning: 100
Setting [a] to 101
OK!
Getting [z]
Nothing!
Setting [z] to 1
Not OK!
Checking if a is set
bool(true)
Unsetting a
Checking if a is set
bool(false)
bool(true)
object(Setter)#1 (2) {
  ["n"]=>int(1)["x:private"]=>array(2) {
["b"]=>
    int(2)
    ["c"]=>
    int(3)
  }
}
方法重载(Method overloading)
mixed __call ( string name, array arguments )
类方法可以通过定义这些指定的特定方法加载类中的自定义代码。$name参数被用来命名那些被请求的函数名。Arguments在定义为array的函数的$arguments参数中将被传递。从__call()方法返回的值将被返回方法的访问者。
例子 19-19.使用__call重载的实例
复制PHP内容到剪贴板
PHP代码:

<?php
class Caller
{   private $x = array(123);
    public function 
__call($m$a)
    {   print 
"Method $m called:\n";
        
var_dump($a);
        return 
$this->x;
    }
}
$foo = new Caller();
$a $foo->test(1"2"3.4true);
var_dump($a);
?>

上例将输出:
复制内容到剪贴板
代码:
Method test called:
array(4) {
    [0]=>
    int(1)
    [1]=>
    string(1) "2"
    [2]=>
   float(3.4)
    [3]=>
    bool(true)
}
array(3) {
    [0]=>
    int(1)
    [1]=>
    int(2)
    [2]=>
    int(3)
}
[ 本帖最后由 forest 于 2006-5-4 18:15 编辑 ]

第19章 类与对象(PHP5)之八:对象迭代(Object Iteration)

PHP5提供一个为对象定义通过一连串的消息被重述的途径成为可能,例如使用一个foreach语句。默认地,所有可见的属性将用来迭代(反复)。
例子 19-20. 简单的对象迭代(Simple Object Iteration)
复制PHP内容到剪贴板
PHP代码:

<?php
class MyClass
{   public $var1 'value 1';
    public 
$var2 'value 2';
    public 
$var3 'value 3';
    protected 
$protected 'protected var';
    private   
$private   'private var';
    function 
iterateVisible() 
    {   echo 
"MyClass::iterateVisible:\n";
       foreach(
$this as $key => $value){  print "$key => $value\n";  }
    }
}
$class = new MyClass();
foreach(
$class as $key => $value){   print "$key => $value\n";  }
echo 
"\n";
$class->iterateVisible();
?>

var1 => value 1
var2 => value 2
var3 => value 3
MyClass::iterateVisible:
var1 => value 1
var2 => value 2
var3 => value 3
protected => protected var
private => private var

如输出显示,foreach重述能通过全部可见变量被访问。更进一步,你可以实现一个PHP5的指定的内在接口迭代器(Iterator)。允许对象描述什么是对象重述和对象如何被重述的。
例子 19-21. 迭代器实现对象迭代(Object Iteration implementing Iterator)
复制PHP内容到剪贴板
PHP代码:

<?php
class MyIterator implements Iterator
{   private $var = array();
    public function 
__construct($array)
    {   if (
is_array($array)){  $this->var $array; }
    }
    public function 
rewind() 
    {    echo 
"rewinding\n";
        
reset($this->var);
 }
    public function 
current()
    {   
$var current($this->var);
        echo 
"current: $var\n";
        return 
$var;
    }
    public function 
key() 
    {    
$var key($this->var);
        echo 
"key: $var\n";
        return 
$var;
    }
    public function 
next() 
    {    
$var next($this->var);
        echo 
"next: $var\n";
        return 
$var;
    }
    public function 
valid() 
    {    
$var $this->current() !== false;
        echo 
"valid: {$var}\n";
        return 
$var;
    }
}
$values = array(1,2,3);
$it = new MyIterator($values);
foreach (
$it as $a => $b) {  print "$a: $b\n";  }
?>

上例将输出:
复制内容到剪贴板
代码:
rewinding
current: 1
valid: 1
current: 1
key: 0
0: 1
next: 2
current: 2
valid: 1
current: 2
key: 1
1: 2
next: 3
current: 3
valid: 1
current: 3
key: 2
2: 3
next:
current:
valid:
在定义类时你也可以不必通过简单实现PHP5的IteratorAggregate接口定义所有的迭代器函数。
例19-22.IteratorAggregate对象迭代实现
复制PHP内容到剪贴板
PHP代码:

<?php
class MyCollection implements IteratorAggregate
{   private $items = array();
    private 
$count 0;
    
// Required definition of interface IteratorAggregate
    
public function getIterator() 
    {    return new 
MyIterator($this->items);
    }
     public function 
add($value
    {    
        
$this->items[$this->count++] = $value;
    }
}
$coll = new MyCollection();
$coll->add('value 1');
$coll->add('value 2');
$coll->add('value 3');
foreach (
$coll as $key => $val){  echo "key/value: [$key -> $val]\n\n";  }
?>

上例将输出:
复制内容到剪贴板
代码:
rewinding
current: value 1
valid: 1
current: value 1
key: 0
key/value: [0 -> value 1]
next: value 2
current: value 2
valid: 1
current: value 2
key: 1
key/value: [1 -> value 2]
next: value 3
current: value 3
valid: 1
current: value 3
key: 2
key/value: [2 -> value 3]
next:
current:
valid:
[ 本帖最后由 forest 于 2006-5-4 18:14 编辑 ]
分享到:
评论

相关推荐

    php_manual_zh

    《PHP_manual_zh》与《PHP5面向对象编程》这两份资源是PHP开发者的重要参考资料,它们涵盖了PHP语言的基础到高级的各个方面,特别是对于面向对象编程的深入理解。 PHP(Hypertext Preprocessor)是一种广泛使用的...

    PHP5.rar_php_manual_zh.c_php_manual_zh.chm

    《PHP5.rar_php_manual_zh.c_php_manual_zh.chm》是针对PHP5语言的一份中文学习资源,其中包含了PHP的官方中文手册。这个压缩包的主要文件是`php_manual_zh.chm`,这是一个帮助文件,通常用于离线查阅。CHM文件是...

    php_manual_zh_PHP中文手册

    这部分详尽地介绍了PHP的基本语法、变量、数据类型(如字符串、整型、浮点型、布尔型、数组、对象、NULL、资源等)、操作符(算术、比较、逻辑、位、赋值等)、流程控制(如条件语句、循环结构、跳转语句等)、函数...

    php_manual_zh .chm

    php_manual_zh .chm

    php_manual_zh.chm

    php_manual_zh.chm php的开发手册,用于php开发者,在平时的工作中方便查找相关php函数以及使用方法。

    php_manual_en.chm

    php_manual_en.chm php_manual_en.chm php_manual_en.chm php_manual_en.chm

    epaswmm5_apps_manual.zip

    《SWMM新手入门案例——深度解析epaswmm5_apps_manual》 EPASWMM5(Environmental Protection Agency Storm Water Management Model Version 5)是美国环保署开发的一款强大的城市雨水管理系统,广泛应用于暴雨径流...

    PHP使用手册php_manual_en.chm

    PHP使用手册,本视频来源于PHP100教程网站,仅供学习、交流使用。php_manual_en.chm

    php_manual_zh最新中文版20090215

    类与对象(PHP 5) 命名空间 异常处理 引用的解释 Predefined variables Predefined Exceptions Predefined Interfaces Context options and parameters 安全 简介 总则 以 CGI 模式安装时 以 Apache 模块安装时 ...

    php_pear_smarty_manual

    【标题】"php_pear_smarty_manual"是一个与PHP、PEAR(PHP Extension and Application Repository)以及Smarty相关的打包手册,提供了全面的PHP编程、PEAR库使用和Smarty模板引擎的指导资料。 【描述】...

    php_manual

    10. **PHP与Web服务器集成**:讲解如何在Apache、Nginx等Web服务器上配置和运行PHP,以及如何设置PHP的配置文件php.ini。 通过深入研读《PHP开发手册》,开发者不仅能掌握PHP语言的基础,还能了解到许多高级特性和...

    Quectel_EC20_AT_Commands_Manual_V1.0.pdf

    Quectel_EC20_AT_Commands_Manual_V1.0.pdfQuectel_EC20_AT_Commands_Manual_V1.0.pdf

    php_manual_en.tar.gz_linux manual

    4. **扩展与模块**:讲解了如何安装和使用各种PHP扩展,如MySQLi、PDO、gd等,以及PHP与Apache、Nginx等服务器的集成。 5. **错误与调试**:阐述了如何处理PHP运行时的错误和异常,以及如何进行调试,这对于优化...

    php_manual_zh_5.2 手册中文版

    1. **面向对象编程**:PHP 5.2显著增强了面向对象编程(OOP)的支持,包括类、对象、接口、抽象类、final关键字、魔术方法(__construct, __destruct, __call等)以及类常量和静态属性的引入。这些特性使得PHP更接近...

    php_manual_en.chm 英文版的

    php_manual_en.chm 最新。。

    SEC_Users_Manual_S5P4418_Users_Manual_Preliminary

    1. 文档基本信息:文件名“SEC_Users_Manual_S5P4418_Users_Manual_Preliminary”,并且明确指出这是一份标题为“SEC_Users_Manual_S5P4418_Users_Manual_Preliminary_Ver.0.10”的手册。这表明文档为一份初步版的...

    php_manual_en PHP官方文档

    php_manual_en PHP官方文档 2010-06-25

Global site tag (gtag.js) - Google Analytics