類中類外訪問靜態成員和普通成員 - PHP面向對象編程(OOP)

    在php中的訪問常量和靜態量的方法總結

    范圍解析操作符 (::)

    理解

    類外使用

    靜態成員

    • $obj::$member1;//訪問實例中的靜態變量
    • ClassName::member3_visit2();//訪問ClassName類中的靜態方法

    普通成員

    • echo $obj->member1;//訪問實例中的變量
    • $obj->member2();//訪問實例中的方法

    常量

    • echo $obj::member1;//訪問實例中的常量

    類內使用

    靜態成員

    • self::$member2;//訪問類中靜態變量
    • ClassName::$member2;//訪問類中靜態變量(不建議使用)
    • self::member2;//訪問類中靜態方法

    普通成員

    • echo $this->member2;//訪問類中的變量
    • echo $this->member3();//方法中訪問其他方法

    常量

    • echo self::member2;//方法中訪問常量

    訪問大綱

    訪問又分為靜態成員的訪問和普通成員訪問

    1:靜態成員

    • 類內訪問
    self::$靜態屬性名 
    self::$類常量名 

    (其實類內頁可以使用類外訪問的類名的訪問方式,不過考慮到了后期類名的更改,self就很方便的解決了這個問題)

    • 類外訪問
    類名::$靜態屬性名 
    類名::$類常量名

    2:普通成員

    • 類內訪問
    $this->屬性名 
    $this->方法名
    • 類外訪問
    $對象名->屬性名 
    $對象名->方法名 ($對象名 指的是實例化后的對象)

    實戰演示

    一:靜態成員屬性的訪問

    1: 靜態外部訪問

    <?php 
        class ClassName {
            //必須帶“$”,否則是常量
            public static $member1 = '成員1';
        }
        $obj = new ClassName;
        //注意這里的“::”
        echo $obj::$member1;
    ?>

    輸出:

    成員1

    2:靜態內部訪問?(要知道,在類內部訪問類成員必須定義一個方法來訪問)

    <?php 
        class ClassName {
            //必須帶“$”,否則是常量
            public static $member2 = '成員2 <br />';
            
            public function member2() {
                echo self::$member2;
                //下面這條效果與上條相同,但不推薦使用(考慮繼承中。類名會變的因素)
                echo ClassName::$member2;
            }
        }
    
        $obj = new ClassName;
    
        //類內訪問類中靜態成員
        $obj->member2();
    ?>

    輸出:

    成員2
    成員2
    • 1:類內訪問類內成員首先要定義一個方法在方法內訪問;
    • 2:最開始介紹到:類內其實可以使用類名的訪問方式(echo ClassName::$member2;),考慮到項目后期可能會有類名更改問題,類內最好使用self來代替

    (不過也正好證明了在類內訪問其實就是使用類(名)進行指定類內的成員,講這個是因為不同于普通成員中的類內訪問方式--$this)

    二:靜態成員方法的訪問

    1:在類外訪問類內靜態方法

    <?php 
        class ClassName {
    
            //靜態方法
            public static function member3() {
                echo __METHOD__;//打印當前方法的方法名
            }
    
        }
    
        //類外訪問類內靜態方法
        ClassName::member3();
        
    ?>

    輸出:

    ClassName::member3

    在類外使用 類名::類中的方法名。 (__METHOD__指的是當前方法的方法名

    2:在類內訪問類內靜態方法

    <?php 
        class ClassName {
    
            //靜態方法
            public static function member3() {
                echo __METHOD__.'<br />';//打印當前方法的方法名
            }
    
            //方法訪問靜態方法
            public function member3_visit1() {
                self::member3();
            }
    
            //靜態方法訪問靜態方法
            public static function member3_visit2() {
                self::member3();
            }
    
        }
    
        $obj = new ClassName;
    
        $obj->member3_visit1();
    
        ClassName::member3_visit2();
        
    ?>

    輸出

    ClassName::member3
    ClassName::member3
    • 類內訪問靜態方法,同樣需要在方法內訪問,
    • 定義的方法可以使用普通方法進行訪問,
    • 也可以定義一個同樣是靜態方法的方法來訪問其他靜態方法。。
    • (可能這句話有些繞,直接分析代碼就行)

    三:普通成員的屬性訪問

    1:在類外訪問

    <?php 
        class ClassName {
            public  $member1 = '成員1 ';
        }
    
        $obj = new ClassName();
    
        //注意這里,不是“$member1”
        echo $obj->member1;
        
    ?>

    輸出:

    成員1

    這里有個重點,記得看后面

    2:在類內訪問

    <?php 
        class ClassName {
    
            public  $member2 = '成員2 ';
    
            function member2() {
                echo $this->member2;
            }
        }
    
        $obj = new ClassName();
    
        $obj->member2();
        
    ?>

    輸出:

    成員2

    你可能已經發現了,為什么在最開始靜態訪問演示的時候,

            function member2() {
                echo $this->member2;
            }
    $obj->member2();

    上面變量名都有$符號,而這里卻沒有。
    要知道這里面php里面有個可變屬性和可變方法。下面來演示一下。

    類中類外訪問靜態成員和普通成員 - PHP面向對象編程(OOP)

    在外面如果不帶$,就是代表著取obj這個對象中進行訪問查找 為此名字的成員。

    一旦加上$,因為在類外部,就會被當做變量來找,所以就會報錯。當然可以這樣寫 ?

    <?php 
        class ClassName {
            public  $member1 = '成員1 ';
            public  $member2 = '成員2 ';
    
            function member2() {
                echo $this->member2;
            }
        }
    
        $obj = new ClassName();
    
        $member1 = 'member1';
    
        echo $obj->$member1;
    
        $obj->member2();
        
    ?>

    輸出:

    成員1 成員2

    (其中一個值當作另一個的名)當obj進行指向訪問的時候 $member就會被解析為 member

    四:普通成員的方法訪問

    1:類外訪問

    <?php 
        class ClassName {
            
            public  $member2 = '成員2,<br /> ';
    
            function member2() {
                echo $this->member2;
            }
    
            public function member3() {
                echo __METHOD__;//打印當前方法的方法名
            }
    
        
        }
    
        $obj = new ClassName();
    
        $obj->member2();
    
        $obj->member3();
    
        
    ?>

    輸出

    成員2,
    ClassName::member3

    2:類內訪問

    <?php 
        class ClassName {
    
            public function member3() {
                echo __METHOD__.'<br />';//打印當前方法的方法名
            }
    
            public function member4() {
                echo $this->member3();
    
                //與上面一行代碼同樣的意思
                $member3 = 'member3';
                echo $this->$member3();
            }
    
        }
    
        $obj = new ClassName();
    
        $member4 = 'member4';
        $obj->$member4();
    
        
    ?>

    輸出:

    ClassName::member3
    ClassName::member3

    再次直接寫了 可變的 形式,方法同樣適用。

    思考(這樣的好處,以后比如前臺頁面的訪問可以都給定 一個頁面,頁面中定義好類,類中定義好各個對象,通過頁面點擊傳遞要制定的對象名也就是方法名,然后使用可變的形式,來隨時替換到變量,而調用只需要調用一次 $obj->變量名)

    五:類常量的訪問

    首先:類常量就是const定義的常量。

    要記住:類常量只能用const來定義

    1:類外訪問

    <?php 
        class ClassName {
            const member1='類常量1<br />';
        }
    
        $obj = new ClassName;
    
        echo $obj::member1;
    
    ?>

    輸出:

    類常量1

    2:類內訪問

    <?php 
        class ClassName {
    
            const member2='類常量2<br />';
    
            public function visit() {
                echo self::member2;
            }
        }
    
        $obj = new ClassName;
    
        $obj->visit();
    
    ?>

    輸出

    類常量2

    跟靜態方式其實一樣,但唯一的差別就是最前面中的 注釋,變量名在類內聲明的時候沒有 $

    注意:(至于可變的形式,在常量中類內或者類外訪問都不可以

    <?php 
    //以下代碼采用可變方法訪問常量,會報錯
        class ClassName {
    
            const member1='類常量1<br />';
        }
    
        $obj = new ClassName;
    
        //可變方法
        $member1 = 'member1';
        echo $obj::$member1;
    
    ?>

    不過在調用方法的時候可以使用可變的形式,畢竟跟常量也沒太大關系。

    類與對象的內存關系

    我們上面都知道,靜態訪問和類常量都是使用 類名來訪問,而其他都是通過實例化的對象來訪問。

    其實:

    在類內部,是分空間的,靜態成員一般保存在類空間里,而像其他的 普通屬性都是保存在對象的空間里(這里的對象指的是實例化的對象)

    而唯一特殊的就是 成員方法,它按我們的訪問方式是通過 對象來訪問的,但是它并不存儲在對象的空間里,相反存儲在了類的空間里

    我們來使用前面的代碼 證明一下:

    <?php 
        class ClassName {
            public  $member1 = '成員1 ';
            public  $member2 = '成員2,<br /> ';
            function member2() {
                echo $this->member2;
            }
    
    
            //兩個成員方法的訪問
            public function member3() {
                echo __METHOD__.'<br />';//打印當前方法的方法名
            }
    
    
            public function member4() {
                $member3 = 'member3';
                echo $this->member3();
            }
    
        }
    
        $obj = new ClassName();
    
        $obj->member1 = '成員5';
        echo $obj->member1;
    
        $member1 = 'member1';
        echo $obj->$member1;
        $obj->member2();
    
    
        $obj->member3();
    
    
        $member4 = 'member4';
        $obj->$member4();
    
    
        $obj1 = new ClassName;
        echo $obj1->member1;
        
    ?>

    輸出

    成員5成員5成員2,
    ClassName::member3
    ClassName::member3
    成員1

    可以看出 新聲明的obj1?明顯沒有被前面的 obj 改變的成員5 而改變!

    就算是這個特殊的成員方法雖然存在了類空間里,但是仍不會被改變。

    這樣的原因就是因為存儲在了 實例化的對象的空間里,一個實例化中的改變不會影響其他實例化對象的改變

    <?php 
        class ClassName {
            //兩個靜態屬性
            public static  $member1 = '靜態成員1 <br /> ';
            public static  $member2 = '靜態成員2 <br /> ';
    
            //兩個靜態方法
            public static function member3() {
                echo __METHOD__.'<br />';//打印當前方法的方法名
            }
    
            public function member3_visit1() {
                self::member3();
            }
    
            public static function member3_visit2() {
                self::member3();
            }
    
            public function member2() {
                echo ClassName::$member2;
            }
    
        }
    
        $obj = new ClassName();
    
        //類外訪問類中靜態屬性
        ClassName::$member1 = '11131313';
        echo ClassName::$member1;
    
        //類內訪問類中靜態屬性
        $obj->member2();
    
        //類外訪問類內靜態方法
        ClassName::member3();
    
        $obj->member3_visit1();
    
        ClassName::member3_visit2();
        
    
        $obj1 = new ClassName;
        echo ClassName::$member1;
    
        
        
    ?>

    而在類空間中除了不能改變的,常量外的靜態成員,只要被改變,其他的實例化對象同樣就會被調用。如上所顯示。

    參考文章

    php

    調用父類構造方法 - PHP面向對象編程(OOP)

    2022-8-25 14:56:51

    php

    里氏替換原則 - PHP面向對象編程(OOP)

    2022-8-26 17:03:09

    ??
    Npcink上的部份代碼及教程來源于互聯網,僅供網友學習交流,若您喜歡本文可附上原文鏈接隨意轉載。
    無意侵害您的權益,請發送郵件至 1355471563#qq.com 或點擊右側 私信:Muze 反饋,我們將盡快處理。
    0 條回復 A文章作者 M管理員
      暫無討論,說說你的看法吧
    ?
    個人中心
    購物車
    優惠劵
    今日簽到
    有新私信 私信列表
    搜索
    主站蜘蛛池模板: 加勒比精品久久一区二区三区| 无码人妻品一区二区三区精99| 精品一区二区三区无码视频| 狠狠色成人一区二区三区| 亚洲精品一区二区三区四区乱码| 亚洲一区日韩高清中文字幕亚洲| 人妻无码久久一区二区三区免费| 亚洲熟女乱综合一区二区| 国产精品亚洲综合一区在线观看| 久久久国产精品一区二区18禁| 成人无码AV一区二区| 福利视频一区二区牛牛| 国产一区高清视频| 国产精品无码一区二区三区不卡 | 亚洲日韩AV一区二区三区中文 | 激情内射亚洲一区二区三区| 亚洲AV成人精品日韩一区18p| 精品人妻少妇一区二区三区不卡 | 国产激情一区二区三区成人91 | 少妇无码AV无码一区| 日韩视频在线一区| 国产一区在线mmai| 亚洲熟女乱色一区二区三区| 成人区精品一区二区不卡亚洲| 国产韩国精品一区二区三区久久| 国产成人精品无码一区二区三区| 国产亚洲欧洲Aⅴ综合一区| 99久久精品费精品国产一区二区| 中文字幕永久一区二区三区在线观看 | 欧美激情一区二区三区成人| 亚洲码欧美码一区二区三区| 国产微拍精品一区二区| 国产传媒一区二区三区呀| 男人的天堂亚洲一区二区三区| 一区二区网站在线观看| 国产麻豆精品一区二区三区v视界 国产美女精品一区二区三区 | 亚洲av午夜福利精品一区| 日韩精品视频一区二区三区| 日本激情一区二区三区| 人妻少妇精品视频三区二区一区| 福利国产微拍广场一区视频在线|