-
- class サンプル実装 iterator{
- private $var = array(1,2,3,4,5);
- public function __construct(){}
- public function rewind(){reset($ this->var);}
- public function current(){return current($this->var);}
- public function key(){return key($this->var);}
- public function next (){return next($this->var);}
- public function valid(){return ($this->current()!==false);}
- }
- $s = new Sample();
- foreach($s as $k=>$v){ echo $k.'='.$v.'
';}
- ?>
コードをコピー
3. PHPのガベージコレクションの仕組みを簡単に説明します。
変数には参照カウントがあり、カウントが 0 に達すると変数は破棄されます。
4. オブジェクトを配列のようにループできるようにするには、プロパティをプライベートにする必要があります。
(PHP5 の Iterator モードの実装。Iterator インターフェイスを実装するクラスを作成します)
オブジェクトは foreach またはリフレクションを使用することもできることを覚えています。 本当に反復パターンを実装したい場合は、設計パターンまたは Java での記述方法を確認してください。
5. 複数のプロセスが同じファイルに同時に正常に書き込むことができるようにするための php コードを作成してください。
コード:
-
関数 writeData($path, $mode, $data){
- $fp = fopen($path, $mode)
- $retries = 0;
- $max_retries = 100; do {
- if ($retries > 0) {
- usleep(rand(1, 10000));
- }
- $retries += 1;
- }while (!flock($fp, LOCK_EX) and $retries <= $max_retries);
if ($retries == $max_retries) {
- return false;
- }
-
- fwrite($fp, "$datan");
- flock($fp, LOCK_UN) );
- fclose($fp);
- return true
- }
-
-
-
コードをコピーします
6. PHP スクリプトの実行効率 (通常はスクリプト実行時間) とデータベース SQL 効率 (通常はデータベース クエリ時間) をチェックし、スクリプト実行とデータベース クエリのボトルネックを特定して分析するには、どのような方法を使用しますか?
PHPスクリプトの実行効率
1. コードスクリプト内のタイミング。
2. xdebug は、関数の実行数と分析にかかる特定の時間をカウントします。 、winCacheGrind 分析ツールを使用するのが最善です。
3. オンライン システムは strace を使用して、関連プロセスの特定のシステム コールを追跡します。
データベース SQL の効率
SQL の Explain(mysql) を使用すると、スロー クエリ ログを使用してスロー クエリを記録できます。
通常、それはデータベース設計が合理的であるかどうか、要件が合理的であるかどうかなどによって決まります。
テンセントQQに参加したいですか?上記の面接の質問をすべてマスターしてから、必需品を持ってテンセントに行きましょう(笑)! !
|