站长资讯网
最全最丰富的资讯网站

实例讲解PHP7扩展开发之传参与返回值

前言

这次,我们将演示如何在PHP扩展中接受传入的参数和输出返回值。

<?php     function default_value ($type, $value = null) {         if ($type == "int") {             return $value ?? 0;         } else if ($type == "bool") {             return $value ?? false;         } else if ($type == "str") {             return is_null($value) ? "" : $value;         }         return null;     }       var_dump(default_value("int"));     var_dump(default_value("int", 1));     var_dump(default_value("bool"));     var_dump(default_value("bool", true));     var_dump(default_value("str"));     var_dump(default_value("str", "a"));     var_dump(default_value("array")); ?>

我们将在扩展中实现default_value方法。【推荐:《PHP7教程》】

代码

实现default_value方法

default_value方法的PHP扩展源码:

PHP_FUNCTION(default_value) {     zend_string     *type;         zval            *value = NULL;   #ifndef FAST_ZPP     /* Get function parameters and do error-checking. */     if (zend_parse_parameters(ZEND_NUM_ARGS(), "S|z", &type, &value) == FAILURE) {         return;     }     #else     ZEND_PARSE_PARAMETERS_START(1, 2)         Z_PARAM_STR(type)         Z_PARAM_OPTIONAL         Z_PARAM_ZVAL_EX(value, 0, 1)     ZEND_PARSE_PARAMETERS_END(); #endif           if (ZSTR_LEN(type) == 3 && strncmp(ZSTR_VAL(type), "int", 3) == 0 && value == NULL) {         RETURN_LONG(0);     } else if (ZSTR_LEN(type) == 3 && strncmp(ZSTR_VAL(type), "int", 3) == 0 && value != NULL) {         RETURN_ZVAL(value, 0, 1);      } else if (ZSTR_LEN(type) == 4 && strncmp(ZSTR_VAL(type), "bool", 4) == 0 && value == NULL) {         RETURN_FALSE;     } else if (ZSTR_LEN(type) == 4 && strncmp(ZSTR_VAL(type), "bool", 4) == 0 && value != NULL) {         RETURN_ZVAL(value, 0, 1);      } else if (ZSTR_LEN(type) == 3 && strncmp(ZSTR_VAL(type), "str", 3) == 0 && value == NULL) {         RETURN_EMPTY_STRING();     } else if (ZSTR_LEN(type) == 3 && strncmp(ZSTR_VAL(type), "str", 3) == 0 && value != NULL) {         RETURN_ZVAL(value, 0, 1);      }      RETURN_NULL(); }

代码说明

获取参数

在PHP7中提供了两种获取参数的方法。zend_parse_parameters和FAST ZPP方式。

zend_parse_parameters

在PHP7之前一直使用zend_parse_parameters函数获取参数。这个函数的作用,就是把传入的参数转换为PHP内核中相应的类型,方便在PHP扩展中使用。
参数说明:
第一个参数,参数个数。一般就使用ZEND_NUM_ARGS(),不需要改变。
第二个参数,格式化字符串。这个格式化字符串的作用就是,指定传入参数与PHP内核类型的转换关系。

代码中 S|z 的含义就是:
S 表示参数是一个字符串。要把传入的参数转换为zend_string类型。
| 表示之后的参数是可选。可以传,也可以不传。
z 表示参数是多种类型。要把传入的参数转换为zval类型。

除此之外,还有一些specifier,需要注意:
!如果接收了一个PHP语言里的null变量,则直接把其转成C语言里的NULL,而不是封装成IS_NULL类型的zval。
/ 如果传递过来的变量与别的变量共用一个zval,而且不是引用,则进行强制分离,新的zval的is_ref__gc==0, and refcount__gc==1.

赞(0)
分享到: 更多 (0)