具备相同属性(特征)和方法(行为)的一系列个体的集合,类是一个抽象的概念。php
从类中,拿到的具备具体属性值的个体,称为对象。对象是一个具体的个体。
eg:人类;张三数组
class 类名{ 访问修饰符 $属性[=默认值]; [访问修饰符] function 方法(){} }
class SimpleClass { // property declaration public $var = 'a default value'; // method declaration public function displayVar() { echo $this->var; } }
class
修饰,类名后面必定不能有();$对象名 = new 类名(); //()能够不带
函数
$对象名 -> $属性名; //使用->调用属性时,属性名不能带$符号
this
$this -> $属性名;
spa
构造函数是类中的一个特殊函数,当咱们使用new关键字实例化对象时,至关于调用了类的构造函数。code
实例化对象时,自动调用,用于给对象的属性赋初值!orm
[public] function Person($name){ $this -> name = $name; }
__construct
[public] function __construct($name){ $this -> name = $name; }
new Person()
;new Person()
;Person
后面的()
中的参数列表,必须符合构造函数的要求!!!!__construct
。__destruct()
:PHP中,给咱们提供一系列用__
开头的函数,这些函数无需本身手动调用,
会在合适的时机自动调用,这类函数称为魔术称为魔术函数。
eg:function __construct(){}
在类new一个对象时自动调用
function __destruct(){}
在对象被销毁时自动调用,咱们要求,除了魔术方法以外,自定义的函数与方法不能使用__
开头。最后,通常对于功能比较复杂的类,咱们会单独的写到一个类文件中。类文件的命名,同一小写,使用"类名小写.class.php"
的方式命名。在其余文件中使用这个类时,可使用include导入这个".class.php"
文件。对象
经过访问修饰符,将类中不须要外部访问的属性和方法进行私有化处理,以实现访问控制。继承
注意:是实现访问控制,而不是拒绝访问。也就是说,咱们私有化属性后,须要提供对应的方法,让用户经过咱们提供的方法处理属性。接口
set/get
方法)对于一些只在类内部使用的方法,而不像对外部提供使用,那么,这样的方法咱们可使用private进行私有化处理。
private function formatName(){} //这个方法仅仅能在类内部使用$this调用 function showName(){ $this->formatName(); }
set/get
方法为了控制属性的设置以及读取,能够将属性进行私有化处理,并要求用户经过咱们提供的set/get
方法进行设置
private $age; //set方法 function setAge($age){ $this->age=$age; } //get方法 function getAge(){ return $this->age; } $对象->getAge(); $对象->setAge(12);
__get( -> __set(, ->= } $对象->age; //访问对象私有属性时,自动调用__get()魔术方法,而且将访问的属性名传给__get()方法; $对象->age=12; //设置对象私有属性时,自动调用__set()魔术方法,而且将设置的属性名以及属性值传给__set()方法;
注意:在魔术方法中,可使用分支结构,判断$key的不一样,进行不一样操做。
__set($key,$value)
:给类私有属性赋值时自动调用,调用时给方法传递两个参数:须要设置的属性名,属性值。__get($key,$value)
:读取类私有属性时自动调用,调用时给方法传递一个参数,须要读取的属性名;__isset($key)
:外部使用isset()
函数检测私有属性时,自动调用。
类外部使用isset();检测私有属性,默认是检测不到的。false
因此,咱们可使用__isset();函数,在自动调用时,返回内部检测结果。
function __isset($key){return isset($this -> $key);}
当外部使用isset($对象名->私有属性);检测时,将自动调用上述__isset()返回的结果!
__unset($key)
:外部使用unset()
函数删除私有属性时,自动调用;
function __unset($key){unset($this -> $key);}
当外部使用unset($对象名->私有属性);删除属性时,自动将属性名传给__unset(),并交由这个魔术方法处理。
给子类使用extends
关键字,让子类继承父类;
class Student extends Person{}
class Person{} class Adult extends Person{} class Student extends Adult{} //Student 类就同时具备了Adult类和Person类的属性和方法
子类重写父类已有方法
符合上述两个条件,称为方法覆盖。覆盖以后,子类调用方法,将调用子类本身的方法。
一样,除了方法覆盖,子类也能够具备与父类同名的属性,进行属性覆盖。
若是,子类重写了父类方法,如何在子类中调用父类同名方法?
partent::方法名();
因此,当子类继承父类时,需在子类的构造中的第一步,首先调用父类构造进行复制。
function __construct($name,$sex,$school){ partent::__construct($name,$sex); $this -> school = $school; }
final
修饰类,此类为最终类,不能被继承!final
修饰方法,此方法为最终方法,不能被重写!final
不能修饰属性。静态属性,静态方法,只能使用类名直接调用。
使用"类名::\(静态属性" , "类名::静态方法()" `Person::\)sex; Person::say();`
静态方法中,不能调用非静态属性或方法;
非静态方法,能够调用静态属性和方法。 (由于静态属性和方法在类装载时已经产生,而非静态的属性方法,此时尚未实例化诞生)
self
关键字,代指本类名。class Person{ static $sex = "nan"; function say(){ echo self::$sex; } }
在类中声明常量,不能是define()
函数!必须使用const
关键字。与define()
声明类似,const
关键字声明常量不能带$
,必须所有大写!
常量一旦声明,不能改变。调用时与static
同样,使用类名调用Person::常量
。
检测一个对象,是不是某一个类的实例。(包括爹辈,爷爷辈,太爷爷辈……)
$zhangsan instanceof Person;
【小总结】几种特殊操做符:
.
只能链接字符串; "".""
=>
声明数组时,关联键与值["key"=>"value"]
->
对象($this new
出的对象)调用成员属性,成员方法;::
使用parent
关键字,调用父类中的同名方法:parent::say();
,使用类名(和self
)调用类中的静态属性,静态方法,以及常量。__construct()
:构造函数,new一个对象时,自动调用。__destruct()
:析构函数,当一个对象被销毁前,自动调用。__get()
:访问类中私有属性时,自动调用。传递读取的属性名,返回$this->属性名
__set()
:给类的私有属性赋值时,自动调用。传递须要设置的属性名和属性值;__isset()
:使用isset()
检测对象私有属性时,自动调用。传递检测的属性名,返回isset($this -> 属性名);
__unset()
:使用unset()
删除对象私有属性时,自动调用。传递删除的属性名,方法中执行unset($this -> 属性名);
__toString(
):使用echo
打印对象时,自动调用。返回想要在打印对象时,显示的内容;返回必须是字符串;__call()
:调用一个类中未定义或未公开的方法时,自动调用。传递被调用的函数名,和参数列表数组;__clone()
:当使用clone
关键字,克隆一个对象时,自动调用。做用是为新克隆的对象进行初始化赋值;__sleep()
:对象序列化时,自动调用。返回一个数组,数组中的值就是能够序列化的属性;__wakeup()
:对象反序列化时,自动调用。为反序列化新产生的对象,进行初始化赋值;__autoload()
:须要在类外部声明函数。当实例化一个未声明的类时,自动调用。传递实例化的类名,可使用类名自动加载对应的类文件。{}
的方法,必须使用abstract
关键字修饰。这样的方法,咱们称为抽象方法。abstract function say(); //抽象方法
使用abstract
关键字修饰的类就是抽象类。
abstract class Person{}
接口是一种规范,提供了一组实现接口的类所必须实现的方法组合。
接口使用interface
关键字声明;
interface Inter{}
abstract
修饰。接口使用extends继承接口,能够实现多继承。
interface int1 extends Inter,Inter2{}
implements
关键字!类使用implements
实现接口,可同时实现多个接口,多个接口间逗号分隔;
abstract class Person implements Inter,Inter2{}
一个类实现一个或多个接口,那么这个类,必须实现全部接口中的全部抽象方法!
除非,这个类是抽象类。
interface
关键字,抽象类使用abstract class
。extends
继承抽象类,使用implements
实现接口。extends
接口)、多实现(类implements
接口)abstract
关键字修饰,接口中抽象方法不能带修饰词。若是,这个类的某个方法,在多个子类中,表现出不一样的功能,咱们称这种行为为多态。