这篇文章给大家分享的是有关如何解析Zephir写PHP扩展的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。众所周知 要写php扩展需要用c或者c++ 语言 配合 ext_skel 实现这样对一个没接触过c++的PH
这篇文章给大家分享的是有关如何解析Zephir写PHP扩展的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。
众所周知 要写php扩展需要用c或者c++ 语言 配合 ext_skel 实现
这样对一个没接触过c++的PHPer很不友好 于是就有了Zephir
zephir
的口号是:会写php
,就会写php
扩展
要构建PHP扩展并使用Zephir,需要满足以下要求:
Zephir parser >= 1.3.0
A C编译器,例如 GCc
re2c 0.13.6 或更高版本
PHP development headers and tools 对于基于 linux 的系统, 您还需要:
GNU make 3.81 or later
autoconf 2.31 或更高版本
automake 1.14 或更高版本
libpcre3
所有编译安装完PHP 还需要 安装一些依赖
yum install git gcc make re2c php php-JSON php-dev libpcre3-dev build-essential
先要安装 解释器
https://GitHub.com/phalcon/php-zephir-parser
git clone git://github.com/phalcon/php-zephir-parser.git
cd php-zephir-parser
phpize
./configure
make
没有安装 re2c
手动安装下
wget Http://sourceforge.net/projects/re2c/files/0.16/re2c-0.16.tar.gz tar zvxf re2c-0.16.tar.gz cd re2c-0.16 ./configure && make && make install
tar zvxf re2c-0.16.tar.gz
cd re2c-0.16 ./configure && make && make install
sudo make install
再 编辑下 ini 加上
extension=zephir_parser.so
安装 zephir.phar
wget https://github.com/zephir-lang/zephir/releases/download/0.13.0-alpha-1/zephir.pha
安装成功
安装好Zephir 就可以进行coding阶段
想实现一个 array_where 扩展方法来实现 数组过滤 筛选
$array = [];$array[0]['name'] = 'zhangsan';$array[0]['chinese'] = '89';$array[0]['math'] = '95';$array[0]['english'] = '88';$array[1]['name'] = 'lisi';$array[1]['chinese'] = '91';$array[1]['math'] = '86';$array[1]['english'] = '90';$where=array( array('k'=>'name','conditions'=>'=','v'=>'zhangsan'), array('k'=>'chinese','conditions'=>'>','v'=>'86'))$new_array = array_where(array,$where);var_dump($new_array);
类似于mysql中的 多条件查询 过滤。
如果用原生的PHP写法 那就是循环foreach 效率很低。
感谢各位的阅读!关于“如何解析Zephir写PHP扩展”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!
--结束END--
本文标题: 如何解析Zephir写PHP扩展
本文链接: https://www.lsjlt.com/news/279886.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
下载Word文档到电脑,方便收藏和打印~
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0