PHP双冒号::的用法

2024-03-25 02:32
文章标签 php 用法 冒号

本文主要是介绍PHP双冒号::的用法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

双冒号操作符即作用域限定操作符Scope Resolution Operator可以访问静态、const和类中重写的属性与方法。

在类定义外使用的话,使用类名调用。在PHP 5.3.0,可以使用变量代替类名。

Program List:用变量在类定义外部访问

 

view source print ?

<?php

class Fruit {

    const CONST_VALUE = 'Fruit Color' ;

}

 

$classname = 'Fruit' ;

echo $classname ::CONST_VALUE; // As of PHP 5.3.0

 

echo Fruit::CONST_VALUE;

?>

Program List:在类定义外部使用::

 

view source print ?

<?php

class Fruit {

    const CONST_VALUE = 'Fruit Color' ;

}

 

class Apple extends Fruit

{

    public static $color = 'Red' ;

 

    public static function doubleColon() {

        echo parent::CONST_VALUE . "/n" ;

        echo self:: $color . "/n" ;

    }

}

 

Apple::doubleColon();

?>

程序运行结果:

view source print ?

Fruit Color Red

Program List:调用parent方法

 

view source print ?

<?php

class Fruit

{

    protected function showColor() {

        echo "Fruit::showColor()/n" ;

    }

}

 

class Apple extends Fruit

{

    // Override parent's definition

    public function showColor()

    {

        // But still call the parent function

        parent::showColor();

        echo "Apple::showColor()/n" ;

    }

}

 

$apple = new Apple();

$apple ->showColor();

?>

程序运行结果:

view source print ?

Fruit::showColor()

Apple::showColor()

Program List:使用作用域限定符

 

view source print ?

<?php

    class Apple

    {

        public function showColor()

        {

            return $this ->color;

        }

    }

 

    class Banana

    {

        public $color ;

 

        public function __construct()

        {

            $this ->color = "Banana is yellow" ;

        }

 

        public function GetColor()

        {

            return Apple::showColor();

        }

    }

 

    $banana = new Banana;

    echo $banana ->GetColor();

?>

程序运行结果:

view source print ?

Banana is yellow

Program List:调用基类的方法

 

view source print ?

<?php

 

class Fruit

{

    static function color()

    {

        return "color" ;

    }

 

    static function showColor()

    {

        echo "show " . self::color();

    }

}

 

class Apple extends Fruit

{

    static function color()

    {

        return "red" ;

    }

}

 

Apple::showColor();

// output is "show color"!

 

?>

程序运行结果:

view source print ?

show color

这篇关于PHP双冒号::的用法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/843585

相关文章

bytes.split的用法和注意事项

当然,我很乐意详细介绍 bytes.Split 的用法和注意事项。这个函数是 Go 标准库中 bytes 包的一个重要组成部分,用于分割字节切片。 基本用法 bytes.Split 的函数签名如下: func Split(s, sep []byte) [][]byte s 是要分割的字节切片sep 是用作分隔符的字节切片返回值是一个二维字节切片,包含分割后的结果 基本使用示例: pa

UVM:callback机制的意义和用法

1. 作用         Callback机制在UVM验证平台,最大用处就是为了提高验证平台的可重用性。在不创建复杂的OOP层次结构前提下,针对组件中的某些行为,在其之前后之后,内置一些函数,增加或者修改UVM组件的操作,增加新的功能,从而实现一个环境多个用例。此外还可以通过Callback机制构建异常的测试用例。 2. 使用步骤         (1)在UVM组件中内嵌callback函

这些ES6用法你都会吗?

一 关于取值 取值在程序中非常常见,比如从对象obj中取值 const obj = {a:1b:2c:3d:4} 吐槽: const a = obj.a;const b = obj.b;const c = obj.c;//或者const f = obj.a + obj.b;const g = obj.c + obj.d; 改进:用ES6解构赋值

PHP原理之内存管理中难懂的几个点

PHP的内存管理, 分为俩大部分, 第一部分是PHP自身的内存管理, 这部分主要的内容就是引用计数, 写时复制, 等等面向应用的层面的管理. 而第二部分就是今天我要介绍的, zend_alloc中描写的关于PHP自身的内存管理, 包括它是如何管理可用内存, 如何分配内存等. 另外, 为什么要写这个呢, 因为之前并没有任何资料来介绍PHP内存管理中使用的策略, 数据结构, 或者算法. 而在我们

php中json_decode()和json_encode()

1.json_decode() json_decode (PHP 5 >= 5.2.0, PECL json >= 1.2.0) json_decode — 对 JSON 格式的字符串进行编码 说明 mixed json_decode ( string $json [, bool $assoc ] ) 接受一个 JSON 格式的字符串并且把它转换为 PHP 变量 参数 json

如何将文件夹里的PHP代码放到一个文件里

find ./dir -name "*.php" -exec 'cat' {} \; > dir.out

PHP抓取网站图片脚本

方法一: <?phpheader("Content-type:image/jpeg"); class download_image{function read_url($str) { $file=fopen($str,"r");$result = ''; while(!feof($file)) { $result.=fgets($file,9999); } fclose($file); re

PHP防止SQL注入详解及防范

SQL 注入是PHP应用中最常见的漏洞之一。事实上令人惊奇的是,开发者要同时犯两个错误才会引发一个SQL注入漏洞。 一个是没有对输入的数据进行过滤(过滤输入),还有一个是没有对发送到数据库的数据进行转义(转义输出)。这两个重要的步骤缺一不可,需要同时加以特别关注以减少程序错误。 对于攻击者来说,进行SQL注入攻击需要思考和试验,对数据库方案进行有根有据的推理非常有必要(当然假设攻击者看不到你的

PHP防止SQL注入的方法(2)

如果用户输入的是直接插入到一个SQL语句中的查询,应用程序会很容易受到SQL注入,例如下面的例子: $unsafe_variable = $_POST['user_input'];mysql_query("INSERT INTO table (column) VALUES ('" . $unsafe_variable . "')"); 这是因为用户可以输入类似VALUE”); DROP TA

PHP防止SQL注入的方法(1)

(1)mysql_real_escape_string – 转义 SQL 语句中使用的字符串中的特殊字符,并考虑到连接的当前字符集 使用方法如下: $sql = "select count(*) as ctr from users where username ='".mysql_real_escape_string($username)."' and password='". mysql_r