<ruby id="bdb3f"></ruby>

    <p id="bdb3f"><cite id="bdb3f"></cite></p>

      <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
        <p id="bdb3f"><cite id="bdb3f"></cite></p>

          <pre id="bdb3f"></pre>
          <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

          <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
          <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

          <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                <ruby id="bdb3f"></ruby>

                ThinkChat2.0新版上線,更智能更精彩,支持會話、畫圖、視頻、閱讀、搜索等,送10W Token,即刻開啟你的AI之旅 廣告
                # 11.1 PHP中的面向對象(二) 為了操作一個對象,我們需要先獲取這個對象的實例,而這肯定會涉及調用對象的構造方法。有關如何在擴展中調用PHP的函數與對象的方法這里不展開描述了。 首先我們先了解下一個object在PHP內核中到底是如何實現的。 ````c typedef struct _zend_object_value { zend_object_handle handle; zend_object_handlers *handlers; } zend_object_value; //此外再回顧一下zval的值value的結構。 typedef union _zvalue_value { long lval; /* long value */ double dval; /* double value */ struct { char *val; int len; } str; HashTable *ht; /* hash table value */ zend_object_value obj; } zvalue_value; ```` 如果我們有一個zval *tmp,那么tmp->value.obj來訪問到最終保存對象實例的zend_object_value結構體,它包含兩個成員: <ul> <li>zend_object_handle handle:最終實現是一個unsigned int值,Zend會把每個對象放進數組里,這個handle就是此實例的索引。所以我們在把對象當作參數傳遞時,只不過是傳遞的handle罷了,這樣對性能有利,同時也是對象的引用機制的原理。</li> <li>zend_object_handlers *handlers:這個里面是一組函數指針,我們可以通過它來對對象進行一些操作,比如:添加引用、獲取屬性等。此結構體在Zend/zend_object_handlers.h里定義。</li> </ul> 下面我給出這個類的PHP語言實現,讓我們在擴展中實現它,并生成它。 ````php <?php class baby { public function __construct() { echo "a new baby!\n"; } public function hello() { echo "hello world!\n"; } } function test_call() { $obj = new baby(); $obj->hello(); } ```` 下面我們在擴展中實現以上test_call函數。 **Note:**關于下面walu_call_user_function()的說明:內核中并不存在該函數,可以在[這里](https://github.com/wosiwo/clinq/blob/41c2c32e1837a23231c3b124dd84c29d03922e97/alinq.c)找到該函數的定義,直接拷貝過來用即可。 ````c zend_class_entry *baby_ce; ZEND_FUNCTION(test_call) { zval *obj; MAKE_STD_ZVAL(obj); object_init_ex(obj, baby_ce); //如果確認此類沒有構造函數就不用調用了。 walu_call_user_function(NULL, obj, "__construct", ""); walu_call_user_function(NULL, obj, "hello", ""); zval_ptr_dtor(&obj); return; } ZEND_METHOD(baby, __construct) { printf("a new baby!\n"); } ZEND_METHOD(baby, hello) { printf("hello world!!!!!\n"); } static zend_function_entry baby_method[]={ ZEND_ME(baby, __construct, NULL, ZEND_ACC_PUBLIC|ZEND_ACC_CTOR) ZEND_ME(baby, hello, NULL, ZEND_ACC_PUBLIC) {NULL, NULL, NULL} }; ZEND_MINIT_FUNCTION(test) { zend_class_entry ce; INIT_CLASS_ENTRY(ce, "baby", baby_method); baby_ce = zend_register_internal_class(&ce TSRMLS_CC); return SUCCESS; } ```` 重新編譯,執行命令查看是否生效~ ```` php -r "test_call();" ```` ## links * 11 [PHP中的面向對象(二)](<11.md>) * 11.2 [讀寫對象的屬性](<11.2.md>)
                  <ruby id="bdb3f"></ruby>

                  <p id="bdb3f"><cite id="bdb3f"></cite></p>

                    <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
                      <p id="bdb3f"><cite id="bdb3f"></cite></p>

                        <pre id="bdb3f"></pre>
                        <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

                        <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
                        <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

                        <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                              <ruby id="bdb3f"></ruby>

                              哎呀哎呀视频在线观看