PHPとの取引では、自分でPHP拡張機能を書くことを検討するようになるかもしれません。私がそうする動機を考えることができるいくつかの理由があります:
-
非常に特定の使用法(数学、統計、幾何学など)のためにPHP機能を拡張するため。
- 純粋なPHP実装と比較して、パフォーマンスと効率が高くなる
- 別の以前に把握した言語でプログラミングから得られた迅速さを活用する(私にとって、c)。
- PHP拡張機能を構築するツールを選択することになると、2つの異なるアプローチが表示されます。
Zephirのようなより多くのPRO-PHPセマンティクスを使用します この記事で説明するPHP-CPPなど、より多くのPro-C/Cセマンティクスを使用します。
-
私にとって、2番目のアプローチを選択するメインドライブは簡単です。C/Cでプログラミングの趣味を始めたので、C/Cでこれらの低レベルのモジュールを書くことがより快適に感じられます。 PHP-CPPの公式サイトには、他にもいくつかの理由があります。
- キーテイクアウト
- PHP-CPPは、C開発者がZend APIと直接連携する複雑さなしにPHP拡張機能を記述できるようにするPHP拡張機能を開発するためのライブラリです。 C 11で書かれており、十分に文書化されたユーザーフレンドリーなクラスのコレクションを提供しています。
PHP-CPPには、Main.cppファイル、拡張機能をコンパイルするためのMakeファイル、および拡張ロード用の.iniファイルを含むスケルトン拡張プロジェクト、拡張機能を含むスケルトン拡張プロジェクトが提供されます。スケルトンプロジェクトは、個々のニーズに合わせてカスタマイズし、「make && sudo make install」コマンドでコンパイルおよびインストールできます。
PHP-CPPは、PHPから呼び出される4種類の関数署名をサポートし、アレイ形式の値でパラメーターを渡すことができます。また、関数のエクスポート/登録、関数パラメータータイプの仕様、およびオブジェクト指向の拡張機能の作成も可能です。インストールと構成
- PHP-CPPは急速に進化しています。この記事の執筆時点では、バージョン0.9.1(約2日前に0.9.0がリリースされています)にあります。そのドキュメントによると、「これは今後のV1.0バージョンの準備をする機能フリーズリリースです」ので、すぐに1.0のメジャーリリースが見られると確信しています。 したがって、少なくともこの暫定期間中は、Gitを使用してリポジトリをクローンし、後でGit Pullを使用して最新のアップデートを取得することをお勧めします。
注:インストールに関するPHP-CPPドキュメントでは、当面は「内部的にはZend Engineが非常に奇妙なシステムを使用してスレッドの安全性を確保する」ため、「単一スレッドPHPのインストールのみをサポートする」と述べています。将来のリリースは、マルチスレッドのPHPインストールをサポートする可能性がありますが、今のところこれを念頭に置いて、現在の制限に固執しましょう。幸いなことに、「シングルスレッドPHPインストール」は、PHPのほとんどのインストールのほとんどの場合に当てはまるはずです。
php-cppはc 11で記述されています。したがって、私のubuntu 12.04 LTSにインストールされている古いバージョンのgはサポートしていません。 Gコンパイラを上記のバージョン4.8.xにアップグレードする必要があります。アップグレードを行う手順を詳述する記事があります。そこに記載されている指示に従ってください。また、PHP-CPPコンピレーションでは、PHP.Hヘッダーファイルを使用します。このファイルは通常、PHP-DEVがインストールされていない限り、Ubuntuボックスにありません。このコマンドを発行して、PHP5関連の開発ファイルをインストールできます。
Gをアップグレードして必要なヘッダーファイルをインストールした後、次のコマンドを発行して、PHP-CPPライブラリファイル(libphpcpp.so)をコンパイルしてインストールできます。
<span>sudo apt-get install php5-dev</span>コンピレーションは非常に高速になります。インストール後、libphpcpp.soファイルは/usr/libにコピーされ、すべてのphp-cppヘッダーファイルが/usr/includedおよび/usr/include/phpcppフォルダーにコピーされます。
PHP-CPP LIBの設置が完了しました。それは非常に簡単で、プログラミング部分に進むことができます。
<span>make && sudo make install</span>それを行う前に、PHP-CPPで使用されるいくつかの重要な概念と用語について説明します。完全なドキュメントは公式サイトにあり、実際のプログラミングを行う前に誰もがそれを読むことをお勧めします。
skeleton(空)拡張プロジェクトファイル
PHP-CPPは、次の3つのファイルを含むスケルトン拡張プロジェクトを提供します。
main.cpp:get_module関数を含むメインCPPファイル(後で詳細に説明します)
makefile:サンプルは、拡張機能をコンパイルするためのファイルを作成します
yourextension.ini:拡張ロードのための1行のみが含まれています
- makefile
- *nix開発に精通している場合、このmakefileに精通しています。このファイルをカスタマイズして、ニーズに合わせていくつかのわずかな変更を加える必要があります。
- 名前を変更= yourextensionは、name = skeletonのように、より意味のあるものになります。
これらはすべて私が行った変更です。メイクファイルの残りの部分はそのまま保持できます。
- yourextension.ini
- このファイルをskeleton.iniに変更し、このファイルの唯一の行を変更しました。
<span>sudo apt-get install php5-dev</span>
main.cpp
php-cppが提供する空のプロジェクトでは、このファイルには1つの関数のみが含まれています。Get_module()。
<span>make && sudo make install</span>今のところ、この行を変更して、作成する拡張子名と一致させましょう。
get_module()は、後者が必要なライブラリをロードしようとするときにPHPによって呼び出されます。 LIBのエントリポイントと見なされます。 get_module()関数のphp lib要件に準拠するために、extern "c"修飾子を使用して宣言されます。また、get_module()が公開されていることを確認するマクロphpcpp_exportを使用しています。したがって、php。
<span>extension=skeleton.so</span>これまでのところ、私たちは私たちのニーズに合わせて空のプロジェクトにいくつかの変更を加えました。このプロジェクトをコンパイルしてインストールして、拡張機能をインストールできます。
次に、必要なファイルを適切なフォルダーにコピーする必要があります。
(skeleton.iniが上記で変更したファイルであることを思い出してください。
「ネイティブ機能を登録する」に関するPHP-CPPドキュメントによると、PHPから呼び出される4種類の関数署名をサポートしています。
この場合、2番目の署名を使用しており、パラメーターはArrayフォーム(PHP機能)の値で渡されます。
作成したばかりの関数をテストするための簡単なスクリプトを書くことができます: 出力を見てください:
参照による関数パラメーター
main.cppでは、もう1つの関数swap():
また、パラメーターの数とそのタイプを指定することにより、関数をエクスポートします。
があります
2回目の呼び出しは何らかの形で予想外です。PHPに、2つの数字を交換することを伝えました!しかし、それは渡された2番目のパラメーターが文字列であり、とにかくスワッピングを行うという事実を無視するだけです!
3回目の呼び出しが機能します。最初のvar_dumpにはDateTimeオブジェクトが表示され、2番目のオブジェクトが整数が表示されます。これはどういうわけか非常に予想外です(少なくとも私にとって)。結局のところ、オブジェクトは数/文字列とはまったく異なります。しかし、この「スワップ」動作もPHPで実行可能であると考えた後、PHPの奇妙さに合っています。 では、「タイプ」の仕様が影響を与えないことを意味しますか?あまり。これをさらに詳しく説明するために、3番目の関数を作成します:
この機能を次のように登録します:
<span><span>#include <phpcpp.h></phpcpp.h></span>
</span>
<span>/**
</span><span> * tell the compiler that the get_module is a pure C function
</span><span> */
</span><span>extern "C" {
</span>
<span>/**
</span><span> * Function that is called by PHP right after the PHP process
</span><span> * has started, and that returns an address of an internal PHP
</span><span> * strucure with all the details and features of your extension
</span><span> *
</span><span> * @return void* a pointer to an address that is understood by PHP
</span><span> */
</span> PHPCPP_EXPORT <span>void *get_module()
</span> <span>{
</span> <span>// static(!) Php::Extension object that should stay in memory
</span> <span>// for the entire duration of the process (that's why it's static)
</span> <span>static Php::Extension extension("yourextension", "1.0");
</span>
<span>// @todo add your own functions, classes, namespaces to the extension
</span>
<span>// return the extension
</span> <span>return extension;
</span> <span>}
</span><span>} </span>
次に、拡張機能がPHPによってCLIにロードされていることを確認できます-i |グレップスケルトン、および端末には次のようなものが表示されます。
<span>static Php::Extension extension("skeleton", "1.0"); // To be humble, we can change the version number to 0.0.1</span>
最初に作成する関数は、「Hello、World」のわずかに変更されたバージョンになります。 Main.cppの完全なコードを最初に見てみましょう
get_module()関数では、拡張変数を宣言した後、エクスポート(helloworld())を希望する関数を追加し、phpスクリプト(helloworld)に表示できる名前を割り当てます。 <span>make && sudo make install</span>
<span>cp -f skeleton.so /usr/lib/php5/20121212
</span><span>cp -f skeleton.ini /etc/php5/cli/conf.d</span>
次に、参照によってパラメーターを渡す別の関数、SWAP()関数が表示されます。この関数では、パラメーターの数とそのタイプを指定しようとします。 <span>sudo apt-get install php5-dev</span>
明示的にそれを言っています:<span>make && sudo make install</span>
2つのパラメーター(aとb);
最初の呼び出し(スワップ($ a、$ b))は、期待される結果を示しています:20 | 10。関数は、渡された2つの数値を交換します
<span>extension=skeleton.so</span>
<span><span>#include <phpcpp.h></phpcpp.h></span> </span> <span>/** </span><span> * tell the compiler that the get_module is a pure C function </span><span> */ </span><span>extern "C" { </span> <span>/** </span><span> * Function that is called by PHP right after the PHP process </span><span> * has started, and that returns an address of an internal PHP </span><span> * strucure with all the details and features of your extension </span><span> * </span><span> * @return void* a pointer to an address that is understood by PHP </span><span> */ </span> PHPCPP_EXPORT <span>void *get_module() </span> <span>{ </span> <span>// static(!) Php::Extension object that should stay in memory </span> <span>// for the entire duration of the process (that's why it's static) </span> <span>static Php::Extension extension("yourextension", "1.0"); </span> <span>// @todo add your own functions, classes, namespaces to the extension </span> <span>// return the extension </span> <span>return extension; </span> <span>} </span><span>} </span>
結論
この記事では、PHP環境で動作するようにPHP-CPPを準備する手順を示しました。また、PHP-CPP(およびCセマンティクス)を使用してPHP拡張機能を作成するためのいくつかの基本的な手順についても説明しました。拡張プロジェクトファイル、関数署名、関数のエクスポート/登録、および関数パラメータータイプをカバーしました。
次の記事では、PHP-CPPのいくつかの重要な機能をさらに詳しく説明し、PHP-CPP。 PHP拡張開発に関するよくある質問(FAQ)
PHP-CPPとは何ですか?PHPとどのように異なりますか?
PHP-CPPは、PHP拡張機能を開発するためのライブラリです。十分に文書化されたユーザーフレンドリーなクラスのコレクションを提供し、C開発者はZend APIと直接連携する複雑さなしにPHP拡張機能を記述できるようにします。解釈された言語であるPHPとは異なり、PHP-CPPを使用すると、コンパイルされた言語であるCでコードを記述できます。これにより、コンパイルされたコードは通常解釈コードよりも速く実行されるため、パフォーマンスの改善につながる可能性があります。 GitHubからPHP-CPPリポジトリをクローンする必要があります。クローニング後、ディレクトリに移動して「make」コマンドを実行します。ビルドプロセスが完了したら、[インストール]コマンドを使用してライブラリをインストールします。ライブラリをインストールするには、ルート権限が必要です。PHP-CPPを使用して基本的なPHP拡張機能を作成するにはどうすればよいですか?
PHP-CPPを使用してPHP拡張機能を作成するには、いくつかのステップが含まれます。まず、拡張機能のためのディレクトリを作成し、ナビゲートする必要があります。次に、拡張機能用の「makefile」とcソースファイルを作成します。 「MakeFile」には拡張機能を構築するための手順が含まれ、Cソースファイルには拡張機能の実際のコードが含まれます。コードを書いた後、「Make」コマンドを使用して拡張機能を構築できます。コンパイルされた言語を扱う。ただし、GDB(GNUデバッガー)などのツールを使用して、拡張機能をデバッグできます。 GDBを使用すると、ブレークポイントを設定し、コードをステップスループし、バグを追跡しようとするときに非常に役立つ変数を検査できます。はい、PHP-CPPはPHP 7と互換性があります。ただし、PHP-CPPの最新バージョンを使用していることを確認する必要があります。 7.
php-cppで例外を処理するにはどうすればよいですか?
php-cppは、php :: exceptionというクラスを提供します。これは、cコードから例外をスローするために使用できます。これらの例外は、他のPHP例外と同様に、PHPコードでキャッチして処理できます。PHP-CPPを使用してオブジェクト指向のエクステンションを作成できますか?
はい、PHP-CPPはオブジェクト指向のプログラミングをサポートしています。 Cコードでクラスを定義でき、これらのクラスをPHPコードで使用できます。これにより、メンテナンスが簡単なクリーンでモジュラーコードを書き込むことができます。 CコードからPHP関数を呼び出すことができます。これにより、拡張機能内のPHPの組み込み関数のパワーを活用できます。
以上がPHP-CPP経由のPHP拡張開発の開始の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

Laravelは、直感的なフラッシュメソッドを使用して、一時的なセッションデータの処理を簡素化します。これは、アプリケーション内に簡単なメッセージ、アラート、または通知を表示するのに最適です。 データは、デフォルトで次の要求のためにのみ持続します。 $リクエスト -

PHPクライアントURL(CURL)拡張機能は、開発者にとって強力なツールであり、リモートサーバーやREST APIとのシームレスな対話を可能にします。尊敬されるマルチプロトコルファイル転送ライブラリであるLibcurlを活用することにより、PHP Curlは効率的なexecuを促進します

これは、LaravelバックエンドとのReactアプリケーションの構築に関するシリーズの2番目と最終部分です。シリーズの最初の部分では、基本的な製品上場アプリケーションのためにLaravelを使用してRESTFUL APIを作成しました。このチュートリアルでは、開発者になります

Laravelは簡潔なHTTP応答シミュレーション構文を提供し、HTTP相互作用テストを簡素化します。このアプローチは、テストシミュレーションをより直感的にしながら、コード冗長性を大幅に削減します。 基本的な実装は、さまざまな応答タイプのショートカットを提供します。 Illuminate \ support \ facades \ httpを使用します。 http :: fake([[ 'google.com' => 'hello world'、 'github.com' => ['foo' => 'bar']、 'forge.laravel.com' =>

顧客の最も差し迫った問題にリアルタイムでインスタントソリューションを提供したいですか? ライブチャットを使用すると、顧客とのリアルタイムな会話を行い、すぐに問題を解決できます。それはあなたがあなたのカスタムにより速いサービスを提供することを可能にします

この記事では、Laravel Webフレームワークの通知システムを検討します。 Laravelの通知システムを使用すると、さまざまなチャネルでユーザーに通知を送信できます。今日は、通知ovを送信する方法について説明します

記事では、PHP 5.3で導入されたPHPの後期静的結合(LSB)について説明し、より柔軟な継承を求める静的メソッドコールのランタイム解像度を可能にします。 LSBの実用的なアプリケーションと潜在的なパフォーマ

PHPロギングは、Webアプリケーションの監視とデバッグ、および重要なイベント、エラー、ランタイムの動作をキャプチャするために不可欠です。システムのパフォーマンスに関する貴重な洞察を提供し、問題の特定に役立ち、より速いトラブルシューティングをサポートします


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

AtomエディタMac版ダウンロード
最も人気のあるオープンソースエディター

MantisBT
Mantis は、製品の欠陥追跡を支援するために設計された、導入が簡単な Web ベースの欠陥追跡ツールです。 PHP、MySQL、Web サーバーが必要です。デモおよびホスティング サービスをチェックしてください。

Dreamweaver Mac版
ビジュアル Web 開発ツール

PhpStorm Mac バージョン
最新(2018.2.1)のプロフェッショナル向けPHP統合開発ツール

Safe Exam Browser
Safe Exam Browser は、オンライン試験を安全に受験するための安全なブラウザ環境です。このソフトウェアは、あらゆるコンピュータを安全なワークステーションに変えます。あらゆるユーティリティへのアクセスを制御し、学生が無許可のリソースを使用するのを防ぎます。

ホットトピック









