我爱编程网小编给大家带来了php4的版本下cookie的设置与php5下的设置有什么区别??相关文章,一起来看一下吧。
本文目录一览:

析构函数会在何时被调用?
在PHP5中,引入了一个关键的构造函数概念,它在类的生命周期中扮演着类似C++中的角色。当对象的引用全部消失或对象被主动销毁时,析构函数便会被执行。示例如下:
php
class MyDestructableClass {
function __construct() {
print "In constructor/n";
$this-name = "MyDestructableClass";
}
function __destruct()
{
print "Destroying " . $this-name . "/n";
}
}
$obj = new MyDestructableClass();
与构造函数类似,PHP不会隐式调用父类的析构函数,需要在子类的析构函数中明确调用parent::__destruct()。析构函数在脚本结束时调用,所有头部信息已发送。
构造函数的声明与其他操作类似,但名称必须为__construct( [参数] ),这是PHP5的更改。PHP4中,构造函数名称需与类名相同,为向下兼容,若类中没有名为__construct( )的方法,PHP会搜索与类名匹配的方法。
在C#中,构造函数是创建对象时自动执行的类方法,如Taxi类的示例:
csharp
public class Taxi
{
public bool isInitialized;
public Taxi()
{
isInitialized = true;
}
}
而在Java中,构造函数用于初始化对象,如UserManagerImpl类:
java
public class UserManagerImpl implements UserManager {
private UserDao userDao;
public UserManagerImpl(UserDao userDao){
this.userDao = userDao;
}
public void save(String username, String password){
this.userDao.save(username, password);
}
}
构造函数的特点包括:
与类名相同,用于初始化对象。
可以重载,即可以定义多个不同参数列表的构造函数。
无返回类型,即使返回void也不行。
自动在对象创建时调用,不能显式调用。
扩展资料
构造函数 是一种特殊的方法 主要用来在创建对象时初始化对象 即为对象成员变量赋初始值,总与new运算符一起使用在创建对象的语句中 特别的一个类可以有多个构造函数 可根据其参数个数的不同或参数类型的不同来区分它们 即构造函数的重载
我爱编程网
PHP8中的魔术方法-PHP8知识详解
在PHP8中,魔术方法为开发者提供了更灵活的类行为定义方式,它们以两个下划线(__)开头。通过魔术方法,可以实现如对象创建、方法调用、属性访问与修改等行为。以下为一些常见魔术方法的简介:
__construct():
类的构造函数。当对象创建时自动调用。
__destruct():
类的析构函数。当对象销毁时自动调用。
__get($name):
在尝试读取不可访问属性值时自动调用。
__set($name, $value):
在给不可访问属性赋值时自动调用。
__isset($name):
在调用isset()或empty()函数检查不可访问属性时自动调用。
__unset($name):
在调用unset()函数删除不可访问属性时自动调用。
__call($name, $arguments):
在调用不存在或不可访问方法时自动调用。
__call static($name, $arguments):
在调用不存在或不可访问静态方法时自动调用。
__toString():
在将对象作为字符串输出时自动调用。
__invoke($arguments):
当尝试将对象作为函数调用时自动调用。
__clone():
当对象被克隆时自动调用。
__debugInfo():
在使用var_dump()函数输出对象信息时自动调用。
__serialize():
在对象被序列化时自动调用。
__unserialize($data):
在对象被反序列化时自动调用。
__sleep():
在对象被序列化时自动调用,返回要序列化的属性列表。
__wakeup():
在对象被反序列化时自动调用。
本文主要介绍两个魔术方法:__set()和__get()。面向对象设计原则强调封装性,不鼓励直接访问类属性。通过使用__set()和__get(),可以间接访问类属性,避免直接访问,提升代码的可维护性和安全性。
当尝试写入未定义或不可见的成员变量时,会触发__set()方法。该方法接收变量名称和值作为参数。
在调用未定义或不可见的成员变量时,会触发__get()方法。该方法接收要调用的变量名称作为参数。
以下为使用__set()和__get()的参考代码示例:
运行结果表明,尝试访问未定义成员变量时,会自动调用__set()和__get()方法,实现间接访问类属性的功能。
php4的版本下cookie的设置与php5下的设置有什么区别??
我爱编程网(https://www.52biancheng.com)小编还为大家带来php4的版本下cookie的设置与php5下的设置有什么区别??的相关内容。
PHP5 中的对象已经进行了较系统、较全面的调整,现在的样子可能看起来会有些类似于 Java。本小节着重讲述 PHP5 中新的对象模式,并举了一些较简易的例子来说明。就让本节成为你的 PHP5 之旅的一个新起点吧。:)* 构造函数和析构函数
* 对象的引用
* 对象的克隆
* 对象中的私有、公共及受保护模式
* 接口 (Interfaces)
* 抽象类
* __call
* __set 和 __get
* 静态成员
构造函数和析构函数在 PHP4 中,当函数与对象同名时,这个函数将成为该对象的构造函数,并且在 PHP4 中没有析构函数的概念。
在 PHP5 中,构造函数被统一命名为 __construct,并且引入了析构函数的概念,被统一命名为 __destruct。例一:构造函数和析构函数class foo {
var $x;
function __construct($x) {
$this->x = $x;
}
function display() {
print($this->x);
}
function __destruct() {
print("bye bye");
}
}
$o1 = new foo(4);
$o1->display();
?>
在上面的例子中,当你终止调用 foo 类的时候,其析构函数将会被调用,上例中会输出 “bye bye”。
对象的引用众所周知,在PHP4 中,传递变量给一个函数或方法,实际是把这个变量做了一次复制,也就意味着你传给函数或方法的是这个变量的一个副本,除非你使用了引用符号 “&” 来声明是要做一个引用,而不是一个 Copy。在 PHP5 中,对象总是以引用的形式存在的,对象中的赋值操作同样也都是一个引用操作。例二:对象的引用
class foo {
var $x;
function setX($x) {
$this->x = $x;
}
function getX() {
return $this->x;
}
}
$o1 = new foo;
$o1->setX(4);
$o2 = $o1;
$o1->setX(5);
if($o1->getX() == $o2->getX()) print("Oh my god!");
?>对象的克隆如上所述,当一个对象始终以引用的形式来被调用时,如果我想得到该对象的一个副本,该怎么办呢?PHP5 提供了一个新的功能,就是对象的克隆,语法为 __clone。例三:对象的克隆
class foo {
var $x;
function setX($x) {
$this->x = $x;
}
function getX() {
return $this->x;
}
}
$o1 = new foo;
$o1->setX(4);
$o2 = $o1->__clone();
$o1->setX(5); if($o1->getX() != $o2->getX()) print("Copies are independant");
?>
对象克隆的方法在其它很多应用程序语言中都是存在的,所以你不必担心它的稳定性。:)
对象中的私有、公共及保护模式PHP4 中,一个对象的所有方法和变量都是公共的,这意味着你可以在一个对象的外部操作其中的任意一个变量和方法。PHP5 引入了三种新的用来控制这种存取权限的模式,它们是:公共的(Public)、受保护的(Protected)及私有的(Private)。公共模式(Public):允许在对象外部进行操作控制。
私有模式(Private):只允许本对象内的方法对其进行操作控制。
受保护模式(Protected):允许本对象及其父对象对其进行操作控制。例四: 对象中的私有、公共及受保护模式class foo {
private $x;
public function public_foo() {
print("I'm public");
}
protected function protected_foo() {
$this->private_foo(); //Ok because we are in the same class we can call private methods
print("I'm protected");
}
private function private_foo() {
$this->x = 3;
print("I'm private");
}
}
class foo2 extends foo {
public function display() {
$this->protected_foo();
$this->public_foo();
// $this->private_foo(); // Invalid! the function is private in the base class
}
} $x = new foo();
$x->public_foo();
//$x->protected_foo(); //Invalid cannot call protected methods outside the class and derived classes
//$x->private_foo(); //Invalid private methods can only be used inside the class $x2 = new foo2();
$x2->display();
?>
提示:对象中的变量总是以私有形式存在的,直接操作一个对象中的变量不是一个好的面向对象编程的习惯,更好的办法是把你想要的变量交给一个对象的方法去处理。
接口 (Interfaces)众所周知,PHP4 中的对象支持继承,要使一个对象成为另一个对象的派生类,你需要使用类似 “class foo extends parent” 的代码来控制。 PHP4 和 PHP5 中,一个对象都仅能继承一次,多重继承是不被支持的。不过,在 PHP5 中产生了一个新的名词:接口,接口是一个没有具体处理代码的特殊对象,它仅仅定义了一些方法的名称及参数,此后的对象就可以方便的使用 'implement' 关键字把需要的接口整合起来,然后再加入具体的执行代码。例五:接口interface displayable {
function display();
}
interface printable {
function doprint();
}class foo implements displayable,printable {
function display() {
// code
} function doprint() {
// code
}
}
?>
这 对提高代码的可读性及通俗性有很大的帮助,通过上面的例子可以看到,对象 foo 包含了 displayable 和 printable 两个接口,这时我们就可以清楚的知道,对象 foo 一定会有一个 display() 方法和一个 print() 方法,只需要去了解接口部分,你就可以轻易的操作该对象而不必去关心对象的内部是如何运作的。抽象类抽象类不能被实例化。
抽象类与其它类一样,允许定义变量及方法。
抽象类同样可以定义一个抽象的方法,抽象类的方法不会被执行,不过将有可能会在其派生类中执行。例六:抽象类abstract class foo {
protected $x;
abstract function display();
function setX($x) {
$this->x = $x;
}
}
class foo2 extends foo {
function display() {
// Code
}
}
?>__callPHP5 的对象新增了一个专用方法 __call(),这个方法用来监视一个对象中的其它方法。如果你试着调用一个对象中不存在的方法,__call 方法将会被自动调用。例七:__callclass foo {
function __call($name,$arguments) {
print("Did you call me? I'm $name!");
}
} $x = new foo();
$x->doStuff();
$x->fancy_stuff();
?>
这个特殊的方法可以被用来实现“过载(overloading)”的动作,这样你就可以检查你的参数并且通过调用一个私有的方法来传递参数。例八:使用 __call 实现“过载”动作class Magic {
function __call($name,$arguments) {
if($name=='foo') {
if(is_int($arguments[0])) $this->foo_for_int($arguments[0]);
if(is_string($arguments[0])) $this->foo_for_string($arguments[0]);
}
} private function foo_for_int($x) {
print("oh an int!");
} private function foo_for_string($x) {
print("oh a string!");
}
} $x = new Magic();
$x->foo(3);
$x->foo("3");
?>__set 和 __get这是一个很棒的方法,__set 和 __get 方法可以用来捕获一个对象中不存在的变量和方法。例九: __set 和 __getclass foo {
function __set($name,$val) {
print("Hello, you tried to put $val in $name");
}
function __get($name) {
print("Hey you asked for $name");
}
}
$x = new foo();
$x->bar = 3;
print($x->winky_winky);
?>类型指示在 PHP5 中,你可以在对象的方法中指明其参数必须为另一个对象的实例。例十:类型指示class foo {
// code ...
}
class bar {
public function process_a_foo(foo $foo) {
// Some code
}
}
$b = new bar();
$f = new foo();
$b->process_a_foo($f);
?>
可以看出,我们可以显性的在参数前指明一个对象的名称,PHP5 会识别出这个参数将会要是一个对象实例。
以上就是我爱编程网小编给大家带来的php4的版本下cookie的设置与php5下的设置有什么区别??,希望能对大家有所帮助。更多相关文章关注我爱编程网:
www.52biancheng.com免责声明:文章内容来自网络,如有侵权请及时联系删除。