【php 扩展开发】扩展生成器

什么是扩展生成器每个php扩展都包含一些非常公共的并且非常单调的结构和文件,这些文件对所有扩展来说都是通用的。当开始一个新扩展开发的时候,如果这些公共的结构已经存在,而不需要费力去复制每个文件的内容, 我们只需考虑填充功能代码那心情一定会愉快很多。扩展生成器就是实现这些功能的脚本,帮助我们完成初始化工作。 PHP 源码中提供一个自带的生成器 ext_skel。他在 ext 目录下。ext_skel./ext_skel –help它提示了我们脚本的命令行格式和支持的参数./ext_skel –extname=module [–proto=file] [–stubs=file] [–xml[=file]] [–skel=dir] [–full-xml] [–no-help] –extname=module 扩展名称,全为小写字母的标识符,仅包含字母和下划线,保证在 php 源码 ext 目录下的文件夹名唯一 –proto=file 允许开发人员指定一个头文件,由此创建一系列 PHP 函数,表面上看就是要开发基于一个函数库的扩展,很少用 –stubs=file 仅生成文件中的函数存根,生成 IDE 提示文件可能有用 –xml generate xml documentation to be added to phpdoc-svn 没用 –skel=dir path to the skeleton directory 指定扩展骨架目录,如果你想在 ext 目录以外的地方生成,那这个有用 –full-xml generate xml documentation for a self-contained extension (not yet implemented) 没用 –no-help don’t try to be nice and create comments in the code and helper functions to test if the module compiled 去除生成测试函数和注释等内容,除非你很熟练,不建议操作示例/usr/local/src/php-7.2.15/ext/ext_skel –extname=twinkle_log –skel=/usr/local/src/php-7.2.15/ext/skeleton/ ...

March 5, 2019 · 1 min · jiezi

【PHP 扩展开发】Hello World

前面两篇介绍了 Zephir ,从此可以开发自己的扩展了,可毕竟是通过转换而来,虽然很方便,可对于扩展还是一知半解,也无法判断其好坏,所以还是要了解下用原生的方法是怎么开发一个 PHP 扩展的。本文以 php-7.2.15 为例创建扩展骨架# 源码路径cd /usr/local/src/php-7.2.15/ext ./ext_skel –extname=twinkle_log提示如下提示已创建好基础文件,如果想使用这个新扩展,需要噼里啪啦这么些布骤,先记着就好。修改config.m4cd twinkle_logvi config.m4这两块注释选一个先打开,具体含义后面文章再说明,我们选下面的创建自己的方法vi twinkle_log.c声明该方法注意大小写敏感编译安装/usr/local/php72/bin/phpize./configure –with-php-config=/usr/local/php72/bin/php-configmake make install填加扩展vi /usr/local/php72/lib/php.ini# 填加扩展 extension=twinkle_log测试一下扩展安装成功<?php// test.phphello_world();执行脚本php -f test.php执行成功。这样我们就创建了一个非常简单的扩展,虽是很简单的扩展,可还是比 Zephir 复杂很多。当然他啥用也没有,没有涉汲到内存管理,没有使用指针,做了这一些操作,也不知道是啥意思,带着疑问,我们慢慢深入研究。

March 5, 2019 · 1 min · jiezi

【PHP 扩展开发】Zephir 基础篇

上一篇 《Zephir 简介》 简单介绍了环境搭建,编写了一个的简单示例。这一篇继续介绍 Zephir 基础。基本语法Zephir 中,每个文件都必须有且只有一个类,每个类都必须有一个命名空间,目录结构必须与所使用的类和命名空间的名称相匹配,这一点和 PSR4 的约定一致,但是它是强制的。空间名和类名首字母大写,文件名全部小写。变量Zephir 支持动态类型和静态类型。变量作为函数返回值时,必须声明为动态类型。动态变量与 PHP 中的变量基本完全相同,支持在使用时改变类型。与 PHP 不一样,变量名不需要带$符号,所有变量在使用前都需要先定义,动态类型通过 var 关键字声明。var a = 10,b,c;let b = 20;let c = a + b;与 PHP 不一样,字符串文字只能使用双引号指定,不能用单引号,也不支持变量解析,比如这样是不支持的。var a = “变量解析{$test}“静态变量静态类型一旦被声明,就不能更改。支持如下类型给静态类型变量赋值,会先尝试自动转换,转换失败抛出异常boolean a;let a = 0; // a = falselet a = “string”; // 抛出异常运算符Zephir 的运算符与 PHP 基本一致。比较运算符在运算时考虑变量类型,如果是动态变量与 PHP 一致。不支持太空船操作符、空合并运算符。特殊运算符 - FetchPHPif (isset($myArray[$key])) { $value = $myArray[$key]; echo $value;}Zephirif fetch value, myArray[key] { echo value;}控制结构Zephir 提供了 if/switch/while/loop/for 几种语句,前三种与 PHP 基本一致。Zephir 控制语句中括号是非必选的。loop 可以用来创建无限循环,相当于 while truelet n = 40;loop { let n -= 2; if n % 5 == 0 { break; } echo x, “\n”;}for 和 PHP 一样支持索引 value 和 key => valuefor item in [“a”, “b”, “c”, “d”] { echo item, “\n”;}let items = [“a”: 1, “b”: 2, “c”: 3, “d”: 4];for key, value in items { echo key, " “, value, “\n”;}还非常友好的提供了反方向遍历let items = [1, 2, 3, 4, 5];for value in reverse items { echo value, “\n”;}与 python 等语言一样,遍历一系列整数值,可以这么写:for i in range(1, 10) { echo i, “\n”;}异常处理异常处理与 PHP 类似,在try 语句中抛出异常,在 catch 中捕获。var e;try { throw new \Exception(“This is an exception”);} catch \Exception, e { echo e->getMessage();}与 PHP 不一致,Zephir try 语句可以没有 catch,表示忽略所有异常。即,这是合法的try { throw new \Exception(“This is an exception”);}捕获多个异常也非常方便var e;try { throw new \Exception(“This is an exception”);} catch \RuntimeException|\Exception, e { echo e->getMessage();}附件1官方文档 ...

March 1, 2019 · 1 min · jiezi