PHP-CPP是一个用于开发PHP扩展的C++库。本节讲解PHP输出和函数的实现。
上面的helloworld示例里,我们使用Php::out
进行输出,并使用了std::endl
换行刷新缓冲。Php::out
变量其实是std::ostream
类的一个实例,支持PHP中设置的所有输出缓冲。它与PHP脚本中的echo()
函数基本相同。
几个常用的方法说明:
std::flush
显示刷新缓冲;std::endl
输出换行并刷新缓冲;Php::out
输出内容到缓冲;Php::notice
生成一个PHP notice;Php::warning
生成一个PHP warning;Php::deprecated
生成一个PHP deprecated;Php::error
生成一个PHP error对于错误,通知和警告,我们不需要换行符,但我们仍然必须刷新缓冲区以实际生成输出。
Php::error
流有一些非常特殊的东西:当你刷新它时,PHP脚本以致命错误结束。
有了上面的几个方法,我们就可以实现PHP的标准输出功能。
使用输出必须引入
iostream
头文件。
上面的示例里其实我们已经实现了2个PHP函数。接下来,我们看看PHP-CPP如何实现以下4种函数:
得益于PHP-CPP封装的Php::Value
和Php::Parameters
类,我们可以很简单的实现上面这些函数。
Php::Value
可以认为是PHP的变量,内部封装了zval结构。通过对运算符的重载,C++里的变量支持自动转为Php::Value
类型。
1、无形参无返回值
void func(){}
2、无形参有返回值
Php::Value func(){}
3、有形参无返回值
void func(Php::Parameters ¶ms){}
4、有形参有返回值
Php::Value func(Php::Parameters ¶ms){}
示例:
/**
* User: 公众号: 飞鸿影的博客(fhyblog)
* Date: 2018/7
*/
Php::Value sum_n(Php::Parameters ¶ms)
{
int max = 0, sum = 0;
if(params.size() == 0){
Php::warning << "miss param" << std::flush;
return 0;
}
max = params[0];
if(params[0].type() != Php::Type::Numeric){
Php::warning << "param type must be numeric." << std::flush;
return 0;
}
for(int i = 1; i <= max; i++){
sum += i;
}
return sum;
}
该函数实现了有形参有返回值,其他几种改改就可以实现。函数里虽然返回的是C++的int类型变量,但是Php::Value
会自动转为PHP语言类型变量。
我们只需要在get_module()
里注册一下:
extension.add<sum_n>("sum_n");
tips: 最终暴露出来的函数名可以与C++里函数名不同,例如:
extension.add<sum_n>("sum_n2");
也是可以的。
重新编译即可:
$ sudo make clean && make && sudo make install
(未完待续)
想第一时间获取最新动态,欢迎关注关注飞鸿影的博客(fhyblog)
,不定期为您呈现技术干货。
原文:https://www.cnblogs.com/52fhy/p/9351830.html