ホームページ >バックエンド開発 >PHPチュートリアル >ディスカッション: PHP 拡張機能の書き方_PHP チュートリアル
C/C++ で PHP を拡張する利点と欠点:
利点:
効率、効率性
PHP スクリプトの複雑さを軽減する 極端な場合には、PHP スクリプト関数で拡張実装を呼び出すだけで済みます。そうすれば、すべての機能が拡張され実装されます
デメリットも明らかです:
複雑な開発
保守性の低下
開発サイクルが長くなる 最も単純な例は、PHP スクリプトを使用する場合です。判定条件が間違っている場合は、この行を修正して保存するだけですぐに反映されます。 C/C++ で書かれた PHP 拡張機能の場合は、ソース コードを変更し、再コンパイルして PHP にリロードし、効果を確認するために Apache を再起動する必要があります。
C に精通している場合、PHP 拡張機能を作成するのはそれほど難しくありません。 PHP 自体は、開発を簡素化するためのフレームワークを提供します。
PHP 拡張機能の開発を開始する最も簡単な方法は、PHP が提供する拡張機能フレームワーク ウィザード ext_skel を使用することです。これを使用するには、まず PHP ソース コードをダウンロードする必要があります。 、または開発パッケージで、PHP ソース コードの ext ディレクトリに入ると、このツールが見つかります。
拡張機能を生成します:
./ext_skel --extname=myext
/myext と入力し、拡張機能の種類を選択します:
vi config.m4
次の 2 つのタイプのいずれかを選択するだけです:
//または //(外部ライブラリに依存しない) dnl PHP_ARG_ENABLE(myext, myext サポートを有効にするかどうか,dnl コメントが整列していることを確認してください:dnl [ --enable-myext myext サポートを有効にする])//dnl を削除します
ヘッダー ファイルを変更します php_myext.h:
//PHP_FUNCTION(confirm_myext_compiled); /* テスト用に後で削除します */
//
PHP_FUNCTION(myext) に変更します /* テスト用に後で削除します */
. c:
//Will
//zend_function_entry myext_functions[] = {
// PHP_FE(confirm_myext_compiled, NULL) /* テスト用に後で削除します */
// {NULL, NULL, NULL} /* である必要があります。 myext_functions[] の最後の行 */
//};
//
zend_function_entry myext_functions[] = {
PHP_FE(myext, NULL) /* テストのため、後で削除します */
{NULL, NULL, NULL} / * myext_functions[] の最後の行である必要があります */
};
//ファイルの最後に独自の関数を追加します
PHP_FUNCTION(myext)
{
zend_printf("Hello World!n");
}
独自の php をインストールします myext を拡張します:
/usr/local/php/bin/phpize
./configure --with-php-config=/usr/local/php/bin/php-config
make
make install
新しいテスト php ファイルを作成します:
myext();
このファイルを実行すると、おなじみの「Hello World!」が表示されます。