PHP7扩展开发之依赖其他扩展

2024-09-08 14:08
文章标签 依赖 开发 扩展 php7

本文主要是介绍PHP7扩展开发之依赖其他扩展,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言

有的时候,我们的扩展要依赖其他扩展。比如,我们PHP的mysqli扩展就依赖mysqlnd扩展。这中情况下,我们怎么使用其他扩展呢?这个就是本文讲述的内容。
我们新建立一个扩展,名字叫 demo_dep , 依赖之前的say扩展。
demo_dep扩展中,我们实现demo_say方法。这个方法调用say扩展的say方法。

代码

基础代码

确保say扩展的头文件正确安装到了php的include文件夹。使用以下命令查看:

$ ls /usr/local/php7/include/php/ext/say/
php_say.h

如果输出内容是php_say.h,那么就是已经正常安装了。
如果没有正常安装,请进行如下操作进行安装。修改say扩展的config.m4文件。增加以下代码:

PHP_INSTALL_HEADERS(ext/say, [php_say.h])

然后,编译安装扩展。make install后,你会看到输出中有:

Installing header files:          /usr/local/php7/include/php/

上面的/usr/local/php7/是我本机的php安装路径。

另外,必须确认,我们要调用的方法,是否在头文件中有声明。

代码实现

第一步:修改config.m4文件。增加依赖声明。增加代码如下:

PHP_ADD_EXTENSION_DEP(demo_dep, say)

第二步:在demo_dep.c文件指定依赖say扩展。
zend_module_entry demo_dep_module_entry之上增加代码:

static const  zend_module_dep demo_dep_deps[] = {ZEND_MOD_REQUIRED("mysqlnd")ZEND_MOD_END
};

然后,把demo_dep_module_entry中的STANDARD_MODULE_HEADER修改为:

zend_module_entry demo_dep_module_entry = {// 以下两行是新加的STANDARD_MODULE_HEADER_EX, NULL,demo_dep_deps,"demo_dep",demo_dep_functions,PHP_MINIT(demo_dep),PHP_MSHUTDOWN(demo_dep),PHP_RINIT(demo_dep),        /* Replace with NULL if there's nothing to do at request start */PHP_RSHUTDOWN(demo_dep),    /* Replace with NULL if there's nothing to do at request end */PHP_MINFO(demo_dep),PHP_DEMO_DEP_VERSION,STANDARD_MODULE_PROPERTIES
};

第三步:实现say方法
先增加头文件。代码如下:

#include "ext/say/php_say.h"

然后调用say方法,实现demo_say方法。代码如下:

PHP_FUNCTION(demo_say)
{zif_say(INTERNAL_FUNCTION_PARAM_PASSTHRU);
}

代码解读

config.m4中的PHP_INSTALL_HEADERS是用于指定把头文件安装到php的头文件目录。
* 第一个参数:安装目录
* 第二个参数:要安装的头文件名。多个头文件名用空格分割

config.m4中的PHP_ADD_EXTENSION_DEP是用于指定此扩展依赖的扩展。把此扩展静态编译进PHP时,会做检测。检测自己依赖的扩展是否被安装。

在第二步增加的依赖,主要作用是在PHP启动时,做扩展依赖检测。如果,自己依赖的扩展不能正常被加载,则报错。报错信息如下:

PHP Warning:  Cannot load module 'demo_dep' because required module 'say' is not loaded in Unknown on line 0

你可以把say扩展在ini文件的配置注释掉,就可以看到报错信息了。

第三步实现代码中我们调用的是zif_say。这个zif_say就是 PHP_FUNCTION(say) 展开后的方法名。

INTERNAL_FUNCTION_PARAM_PASSTHRU宏的使用,就是把传递给PHP_FUNCTION(demo_say)的参数,原样传递给PHP_FUNCTION(say)

源码下载

tar.gz格式下载
zip格式下载

原文链接:PHP7扩展开发之依赖其他扩展

这篇关于PHP7扩展开发之依赖其他扩展的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1148325

相关文章

Spring核心思想之浅谈IoC容器与依赖倒置(DI)

《Spring核心思想之浅谈IoC容器与依赖倒置(DI)》文章介绍了Spring的IoC和DI机制,以及MyBatis的动态代理,通过注解和反射,Spring能够自动管理对象的创建和依赖注入,而MyB... 目录一、控制反转 IoC二、依赖倒置 DI1. 详细概念2. Spring 中 DI 的实现原理三、

Java中的Opencv简介与开发环境部署方法

《Java中的Opencv简介与开发环境部署方法》OpenCV是一个开源的计算机视觉和图像处理库,提供了丰富的图像处理算法和工具,它支持多种图像处理和计算机视觉算法,可以用于物体识别与跟踪、图像分割与... 目录1.Opencv简介Opencv的应用2.Java使用OpenCV进行图像操作opencv安装j

基于Qt开发一个简单的OFD阅读器

《基于Qt开发一个简单的OFD阅读器》这篇文章主要为大家详细介绍了如何使用Qt框架开发一个功能强大且性能优异的OFD阅读器,文中的示例代码讲解详细,有需要的小伙伴可以参考一下... 目录摘要引言一、OFD文件格式解析二、文档结构解析三、页面渲染四、用户交互五、性能优化六、示例代码七、未来发展方向八、结论摘要

在 VSCode 中配置 C++ 开发环境的详细教程

《在VSCode中配置C++开发环境的详细教程》本文详细介绍了如何在VisualStudioCode(VSCode)中配置C++开发环境,包括安装必要的工具、配置编译器、设置调试环境等步骤,通... 目录如何在 VSCode 中配置 C++ 开发环境:详细教程1. 什么是 VSCode?2. 安装 VSCo

python中poetry安装依赖

《python中poetry安装依赖》本文主要介绍了Poetry工具及其在Python项目中的安装和使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随... 目录前言1. 为什么pip install poetry 会造成依赖冲突1.1 全局环境依赖混淆:1

C#图表开发之Chart详解

《C#图表开发之Chart详解》C#中的Chart控件用于开发图表功能,具有Series和ChartArea两个重要属性,Series属性是SeriesCollection类型,包含多个Series对... 目录OverviChina编程ewSeries类总结OverviewC#中,开发图表功能的控件是Char

鸿蒙开发搭建flutter适配的开发环境

《鸿蒙开发搭建flutter适配的开发环境》文章详细介绍了在Windows系统上如何创建和运行鸿蒙Flutter项目,包括使用flutterdoctor检测环境、创建项目、编译HAP包以及在真机上运... 目录环境搭建创建运行项目打包项目总结环境搭建1.安装 DevEco Studio NEXT IDE

Python开发围棋游戏的实例代码(实现全部功能)

《Python开发围棋游戏的实例代码(实现全部功能)》围棋是一种古老而复杂的策略棋类游戏,起源于中国,已有超过2500年的历史,本文介绍了如何用Python开发一个简单的围棋游戏,实例代码涵盖了游戏的... 目录1. 围棋游戏概述1.1 游戏规则1.2 游戏设计思路2. 环境准备3. 创建棋盘3.1 棋盘类

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

Hadoop企业开发案例调优场景

需求 (1)需求:从1G数据中,统计每个单词出现次数。服务器3台,每台配置4G内存,4核CPU,4线程。 (2)需求分析: 1G / 128m = 8个MapTask;1个ReduceTask;1个mrAppMaster 平均每个节点运行10个 / 3台 ≈ 3个任务(4    3    3) HDFS参数调优 (1)修改:hadoop-env.sh export HDFS_NAMENOD