>本文继续使用PHP-CPP探索建筑PHP扩展,重点是面向对象的功能。 我们将创建一个数字类来说明库的功能。
为了开始,我们将调整PHP-CPP项目模板。 重命名为Complex
>>>>,然后将其内容更新为
如下:yourtextension.ini
>
complex.ini
extension=complex.so
接下来,我们将定义Makefile
<code class="language-makefile">NAME = complex INI_DIR = /etc/php5/cli/conf.d</code>类
Complex
密钥概念:main.cpp
PHP-CPP使用熟悉的C语法简化了面向对象的PHP扩展。
类展示C和PHP风格的构造函数/破坏者,用于无缝集成。Complex
mod()
add()
>本文提供了配置,编译和测试PHP扩展的完整指南。__toString()
>,无返回类型,无参数)。 PHP使用>和。 PHP-CPP都支持:
~
重要点:__construct()
__destruct()
<code class="language-cpp">class Complex : public Php::Base { private: double r = 0, i = 0; public: Complex() {} virtual ~Complex() {} Php::Value getReal() { return r; } Php::Value getImage() { return i; } void __construct(Php::Parameters ¶ms) { if (params.size() == 2) { r = params[0]; i = params[1]; } else { r = 0; i = 0; } } // ... other methods ... };</code>>。
继承
C和PHP风格的构造函数均已实现。Php::Base
和getReal()
getImage()
记住要mod()
。 PHP-CPP支持特定的成员功能签名(有关详细信息,请参见文章)。
方法:
<code class="language-cpp">Php::Value mod() const { return (double)sqrt(r * r + i * i); }</code>
<cmath></cmath>
添加两个复数:sqrt()
对于将Aadd()
铸造到其基础C对象至关重要。
方法:
<code class="language-cpp">Php::Value add(Php::Parameters ¶ms) { Php::Value t = params[0]; Complex *a = (Complex *)t.implementation(); r += (double)a->getReal(); i += (double)a->getImage(); return this; }</code>
用于用户友好的输出:t.implementation()
Php::Value
用于字符串操纵。
__toString()
>功能注册:
注册课程及其方法:
<code class="language-cpp">Php::Value __toString() { std::ostringstream os; os << r; if (i >= 0) os << "+"; os << i << "i"; return os.str(); }</code>
<sstream></sstream>
> 编译并使用安装。 使用PHP代码进行测试(请参阅原始文章以获取示例)。
>>命名空间封装:
>将类包装在名称空间中(在本示例中trComplex
)需要最小的更改(有关详细信息,请参见原始文章)。 钥匙是在get_module()
>函数中调整名称空间,并使用PHP代码中的完全资格的名称。
结论:
以上是PHP扩展开发具有PHP-CPP:面向对象的代码的详细内容。更多信息请关注PHP中文网其他相关文章!