如何使用Zephir輕松構建PHP擴展

簡介

比如,在 PHP 中需要與 SQLite3 交互,我們可以自己寫方法與之進行連接,再寫 SQL 語句請求數據。然而,這都是些既瑣碎又重復度相當高的工作,因此,所有開發者對插件的需求呼之欲出。

現在,這款插件已經誕生瞭。你隻需像安裝其他擴展一樣進行安裝,然後在 ‘php.ini’ 文件執行 ‘extension=sqllite3.so’,就可以在你的 php 項目裡對 sqlite3 進行訪問瞭。

你該安裝的第一個擴展

Zephir

官網文檔給出的定義是:

一種開源的高級語言,旨在簡化 PHP 擴展的創建和可維護性,重點關註類型和內存安全性。

特點:

  • 類型:動態 / 靜態。
  • 內存安全性:不允許指針或者直接內存管理。
  • 編譯模式:提前編譯。
  • 內存模型:本地任務垃圾回收機制。

工作原理?

把你寫好的 php 代碼編譯成 c,然後你可以將其以擴展的形式添加到 ‘php.ini’ 文件中。

下面是編譯方案的例子:

編譯方案

讓我們從 Hello world 的擴展開始吧。

Zephir 安裝

配置要求:

  • gcc >= 4.x/clang >= 3.x
  • re2c 0.13 or later
  • gnu make 3.81 or later
  • autoconf 2.31 or later
  • automake 1.14 or later
  • libpcre3
  • php development headers and tools
  • re2c
  • php-zephir-parser

如果你是用 Ubuntu, 可以采取如下方式安裝:

sudo apt-get update
sudo apt-get install git gcc make re2c php7.0 php7.0-json php7.0-dev libpcre3-dev

參考下圖命令,確認安裝瞭較新的 PHP 版本:

參考下圖命令,確認有 PHP 開發庫:

然後

git clone https://github.com/phalcon/zephir

cd zephir

./install -c

驗證是否安裝正確:

zephir help

如果一切就緒,你應該能在你的屏幕上看到以下幫助信息:

擴展初始化:

zephir init helloworld

然後,一個名字為 “helloworld” 的目錄在當前工作目錄中被創建:

擴展目錄結構:

  • ext:包含被編譯器用來生成擴展的代碼。
  • helloworld:這個目錄與我們的擴展同名。我們在這個目錄中放置 Zephir 代碼。
  • config.json:這個文件包含我們可用於更改 Zephir 與 / 或此擴展的行為的配置

添加我們的第一個類:

在 helloworld 目錄中.

Zephir 的設計初衷是用來生成面對對象的擴展,接下來我們先添加一個初始類。

我們先來在擴展中創建一個 helloworld 類,使用此類來渲染Hello World!。

helloworld/helloworld/greeting.zep

namespace HelloWorld;

class Greeting
{

    public static function say()
    {
        echo "Hello World!";
    }
}

接下來命令行執行以下命令來編譯擴展:

zephir build

第一次運行以上命令時,會初始化一些東西。如果一些順利的話,會輸出以下內容:

zephir build output

檢測下是否安裝成功:

在 PHP 代碼中測試:

zephir_helloworld.php

<?php
echo HelloWorld\Greeting::say()."\n";

接下來運行命令:

php zephir_helloworld.php

你可以可以看到輸出

Hello World!

結語

如果你是 PHP 軟件工程師,對內存管理等底層語言的編程方式不是特別熟悉,可以嘗試從 Zephir 開始寫一些簡單的擴展。

Zephir 內部已經做好瞭內存管理,但是基於其內存安全的設計,你無法使用 C 語言的強大手動內存管理功能,如果你是 C 程序員,你會覺得 Zephir 更加簡單易用,但是在有些地方可能不夠強大。

以上就是如何使用Zephir輕松構建PHP擴展的詳細內容,更多關於使用Zephir輕松構建PHP擴展的資料請關註WalkonNet其它相關文章!

推薦閱讀: