PHP 类的一些知识点
1.类的定义
<code class="hljs" xml=""><!--?php class Cart{ var $items; function add_item($artnr,$num){ $this--->items[$artnr += $num; } }</code>
不能将一个类分开定义在多个文件,也不能将类定义分到多个PHP块(函数内部可以分)。
不能定义名为以下的类:
stdClass
__sleep
__wakeup
事实上不要以__开头定义类。
2.构造函数
<code class="hljs" php="">class Cart { var $todays_date; var $name; var $owner; var $items = array(VCR, TV); function Cart() { $this->todays_date = date(Y-m-d); $this->name = $GLOBALS['firstname']; /* etc. . . */ } }</code>
类如果没有构造函数,将调用基类构造函数。
构造函数参数可以赋默认值
<code class="hljs" xml=""><!--?php class Constructor_Cart extends Cart { function Constructor_Cart($item = 10, $num = 1) { $this--->add_item ($item, $num); } } // 买些同样的无聊老货 $default_cart = new Constructor_Cart; // 买些实在货... $different_cart = new Constructor_Cart(20, 17); ?></code>
@new 可以抑制发生在构造函数中的错误。
3.类的使用
<code class="hljs" lasso="">$cart = new Cart; $cart->add_item(10, 1);</code>
类内部使用$this代表自身。
4.类相关函数
__autoload — 尝试加载未定义的类
call_user_method_array — 调用一个用户方法,同时传递参数数组(已废弃)
call_user_method — 对特定对象调用用户方法(已废弃)
class_alias — 为一个类创建别名
class_exists — 检查类是否已定义
get_called_class — 后期静态绑定(”Late Static Binding”)类的名称
get_class_methods — 返回由类的方法名组成的数组
get_class_vars — 返回由类的默认属性组成的数组
get_class — 返回对象的类名
get_declared_classes — 返回由已定义类的名字所组成的数组
get_declared_interfaces — 返回一个数组包含所有已声明的接口
get_declared_traits — 返回所有已定义的 traits 的数组
get_object_vars — 返回由对象属性组成的关联数组
get_parent_class — 返回对象或类的父类名
interface_exists — 检查接口是否已被定义
is_a — 如果对象属于该类或该类是此对象的父类则返回 TRUE
is_subclass_of — 如果此对象是该类的子类,则返回 TRUE
method_exists — 检查类的方法是否存在
property_exists — 检查对象或类是否具有该属性
trait_exists — 检查指定的 trait 是否存在
5.继承
<code class="hljs" php=""><!--?php class Named_Cart extends Cart { var $owner; function set_owner ($name) { $this--->owner = $name; } } ?></code>
PHP不支持多继承。
6.静态方法
<code class="hljs" php=""><!--?php class A { function example() { echo I am the original function A::example().<br /--> ; } } class B extends A { function example() { echo I am the redefined function B::example(). ; A::example(); } } // A 类没有对象,这将输出 // I am the original function A::example(). A::example(); // 建立一个 B 类的对象 $b = new B; // 这将输出 // I am the redefined function B::example(). // I am the original function A::example(). $b->example(); ?></code>
7.基类引用 parent
<code class="hljs" php=""><!--?php class A { function example() { echo I am A::example() and provide basic functionality.<br /--> ; } } class B extends A { function example() { echo I am B::example() and provide additional functionality. ; parent::example(); } } $b = new B; // 这将调用 B::example(),而它会去调用 A::example()。 $b->example(); ?></code>
8.序列化
<code class="hljs" php=""><!--?php // classa.inc: class A { var $one = 1; function show_one() { echo $this--->one; } } // page1.php: include(classa.inc); $a = new A; $s = serialize($a); // 将 $s 存放在某处使 page2.php 能够找到 $fp = fopen(store, w); fwrite($fp, $s); fclose($fp); // page2.php: // 为了正常解序列化需要这一行 include(classa.inc); $s = implode(, @file(store)); $a = unserialize($s); // 现在可以用 $a 对象的 show_one() 函数了 $a->show_one(); ?></code>
9.魔术函数 __sleep __wakeup
10.允许数组方式访问对象属性
方法1
function obj2array(obj){
return new ArrayObject(obj, ArrayObject::ARRAY_AS_PROPS);
}
这个方法比较简单,另一个方法要继承ArrayAccess要复杂一点。
11.数组转对象
<code class="hljs" php=""> /** * 数组转对象 * @param unknown $e * @return void|StdClass */ public static function arrayToObject($e){ if( gettype($e)!='array' ) return; foreach($e as $k=>$v){ if( gettype($v)=='array' || getType($v)=='object' ) $e[$k]=(object)arrayToObject($v); } return (object)$e; }</code>
12 自己实现的序列化与反序列化
用在redis时比较方便:
<code class="hljs" php=""> /** * 序列化对象,返回$json字符串 */ public static function serialize($model){ //return serialize($model); if(!$model)return '{}'; $json='{'; foreach($model as $key2=>$value2){ if($json!='{')$json.=','; $json.=$key2:$value2; } $json.='}'; return $json; } public static function unserialize($json){ $json=str_replace('{', '', $json); $json=str_replace('}','',$json); $array=explode(',', $json); $result=[]; foreach($array as $key =>$value){ $temparr=explode(',',$value); $temparr1=explode(':',$temparr[0]); if(count($temparr1)==0)continue; $result[$temparr1[0]]=trim( $temparr1[1],''); } //$obj= (object)($result); return obj2array($result); //return $result; }</code>

长URL(通常用关键字和跟踪参数都混乱)可以阻止访问者。 URL缩短脚本提供了解决方案,创建了简洁的链接,非常适合社交媒体和其他平台。 这些脚本对于单个网站很有价值

在Facebook在2012年通过Facebook备受瞩目的收购之后,Instagram采用了两套API供第三方使用。这些是Instagram Graph API和Instagram Basic Display API。作为开发人员建立一个需要信息的应用程序

Laravel使用其直观的闪存方法简化了处理临时会话数据。这非常适合在您的应用程序中显示简短的消息,警报或通知。 默认情况下,数据仅针对后续请求: $请求 -

这是有关用Laravel后端构建React应用程序的系列的第二个也是最后一部分。在该系列的第一部分中,我们使用Laravel为基本的产品上市应用程序创建了一个RESTFUL API。在本教程中,我们将成为开发人员

Laravel 提供简洁的 HTTP 响应模拟语法,简化了 HTTP 交互测试。这种方法显着减少了代码冗余,同时使您的测试模拟更直观。 基本实现提供了多种响应类型快捷方式: use Illuminate\Support\Facades\Http; Http::fake([ 'google.com' => 'Hello World', 'github.com' => ['foo' => 'bar'], 'forge.laravel.com' =>

PHP客户端URL(curl)扩展是开发人员的强大工具,可以与远程服务器和REST API无缝交互。通过利用Libcurl(备受尊敬的多协议文件传输库),PHP curl促进了有效的执行

您是否想为客户最紧迫的问题提供实时的即时解决方案? 实时聊天使您可以与客户进行实时对话,并立即解决他们的问题。它允许您为您的自定义提供更快的服务

2025年的PHP景观调查调查了当前的PHP发展趋势。 它探讨了框架用法,部署方法和挑战,旨在为开发人员和企业提供见解。 该调查预计现代PHP Versio的增长


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

禅工作室 13.0.1
功能强大的PHP集成开发环境

记事本++7.3.1
好用且免费的代码编辑器

SecLists
SecLists是最终安全测试人员的伙伴。它是一个包含各种类型列表的集合,这些列表在安全评估过程中经常使用,都在一个地方。SecLists通过方便地提供安全测试人员可能需要的所有列表,帮助提高安全测试的效率和生产力。列表类型包括用户名、密码、URL、模糊测试有效载荷、敏感数据模式、Web shell等等。测试人员只需将此存储库拉到新的测试机上,他就可以访问到所需的每种类型的列表。

ZendStudio 13.5.1 Mac
功能强大的PHP集成开发环境

EditPlus 中文破解版
体积小,语法高亮,不支持代码提示功能