ホームページ > バックエンド開発 > PHPチュートリアル > PHP7拡張開発におけるHello Wordの実装方法を詳しく解説

PHP7拡張開発におけるHello Wordの実装方法を詳しく解説

jacklove
リリース: 2023-04-02 07:54:01
オリジナル
1654 人が閲覧しました

この記事では、PHP7 拡張機能開発における hello word の実装方法を主に紹介します。PHP7 拡張機能開発の具体的な手順と関連する操作テクニックを例の形式で分析します。PHP の基礎となるソース コードの修正とコンパイルが含まれます。必要な友達は、次のリンクを参照してください。

この記事の例では、PHP7 拡張機能開発における hello word の実装方法について説明します。参考までに皆さんと共有してください。詳細は次のとおりです。

ここでは PHP7 に基づいて、PHP 拡張機能を最初から作成する方法を説明します。この記事では主に拡張機能を作成する基本的な手順を説明します。この例では、次の関数を実装します:

<?php
echo say();
?>
ログイン後にコピー

# 出力内容:

$ php ./test.php
$ hello word
ログイン後にコピー

拡張機能にsayメソッドを実装し、sayメソッドを呼び出すとhello wordが出力されます。

ステップ 1: コードの生成

PHP は、基本コード

ext_skel を生成するツールを提供します。このツールは、PHP ソース コードの ./ext ディレクトリにあります。

$ cd php_src/ext/
$ ./ext_skel --extname=say
ログイン後にコピー

extname パラメータの値は拡張機能の名前です。 ext_skelコマンドを実行すると、カレントディレクトリに同じ拡張子のディレクトリが生成されます。

2 番目のステップは、config.m4 構成ファイルを変更することです。

config.m4 の機能は、phpize ツールと連携して、設定ファイルを生成します。構成ファイルは環境の検出に使用されます。拡張機能のコンパイルと実行に必要な環境が満たされているかどうかを確認してください。次に、config.m4 ファイルの変更を開始します。

$ cd ./say
$ vim ./config.m4
ログイン後にコピー

config.m4 ファイルを開くと、次の段落が表示されます。

dnl If your extension references something external, use with:
dnl PHP_ARG_WITH(say, for say support,
dnl Make sure that the comment is aligned:
dnl [ --with-say       Include say support])
dnl Otherwise use enable:
dnl PHP_ARG_ENABLE(say, whether to enable say support,
dnl Make sure that the comment is aligned:
dnl [ --enable-say      Enable say support])
ログイン後にコピー

このうち、dnlはコメント記号です。上記のコードは、作成した拡張機能が他の拡張機能または lib ライブラリに依存している場合、

PHP_ARG_WITH 関連コードのコメントを削除する必要があることを示しています。それ以外の場合は、PHP_ARG_ENABLE 関連コード セグメントからコメントを削除します。私たちが作成する拡張機能は、他の拡張機能や lib ライブラリに依存する必要はありません。したがって、PHP_ARG_ENABLE の前のコメントを削除します。コメントを削除した後のコードは次のとおりです。

dnl If your extension references something external, use with:
 dnl PHP_ARG_WITH(say, for say support,
 dnl Make sure that the comment is aligned:
 dnl [ --with-say       Include say support])
 dnl Otherwise use enable:
 PHP_ARG_ENABLE(say, whether to enable say support,
 Make sure that the comment is aligned:
 [ --enable-say      Enable say support])
ログイン後にコピー

3 番目のステップ、コードの実装

Say.c ファイルを変更します。 Say メソッドを実装します。

Find
PHP_FUNCTION(confirm_say_compiled)、その上に次のコードを追加します:

PHP_FUNCTION(say)
{
    zend_string *strg;
    strg = strpprintf(0, "hello word");
    RETURN_STR(strg);
}
ログイン後にコピー

Find

PHP_FE(confirm_say_compiled 上に次のコードを追加します:

PHP_FE(say, NULL)
ログイン後にコピー

変更されたコードは次のとおりです:

const zend_function_entry say_functions[] = {
   PHP_FE(say, NULL)    /* For testing, remove later. */
   PHP_FE(confirm_say_compiled,  NULL)    /* For testing, remove later. */
   PHP_FE_END /* Must be the last line in say_functions[] */
 };
 /* }}} */
ログイン後にコピー

4 番目のステップ、コンパイルとインストール

拡張機能をコンパイルする手順は次のとおりです:

$ phpize
$ ./configure
$ make && make install
ログイン後にコピー

php.ini ファイルを変更し、次のコードを追加します:

[say]
extension = say.so
ログイン後にコピー

次に、

php -m を実行します。出力コンテンツには、「say」という単語が表示されます。

The 5 番目のステップは、テストを呼び出すことです

自分でスクリプトを作成します出力を見てください 期待を満たしていますか?

興味があるかもしれない記事:

使用方法の詳細な説明PHP 拡張機能開発の関数に基づく lib ライブラリ

Ajax 操作における thinkphp の volist タグの特殊性

## thinkphp の volist タグの詳細説明


以上がPHP7拡張開発におけるHello Wordの実装方法を詳しく解説の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート