ホームページ バックエンド開発 PHPチュートリアル 変数のアクティブ スコープ_PHP チュートリアル

変数のアクティブ スコープ_PHP チュートリアル

Jul 13, 2016 pm 05:26 PM
php コンテクスト 変数 意味 活動 範囲 一部

変数のスコープは、変数が定義されているコンテキストに制限されます。ほとんどのセクションでは、すべての PHP 変数に対してスコープが 1 つだけあります。ただし、ユーザー定義関数では、ローカル関数スコープの概念が導入されます。この関数で使用される変数は、デフォルトでは関数のローカル スコープに制限されます。例:

$a = 1; /* グローバルスコープ */
Function Test () {
echo $a; /* ローカルスコープ変数への参照 */ }

このスクリプトは Any を引き起こしません。変数 "$a" の宣言がローカル変換に送信され、変数にはアクティブ スコープ内の値が割り当てられていないため、出力が得られます。これは、関数内で別途指定しない限り、グローバル変数が自動的に使用可能になる C とは少し異なることに気づくでしょう。グローバル変数の値を誤って変更してしまう可能性があるため、これによりプログラムで多くの問題が発生する可能性があります。 PHP では、この関数でグローバル変数を使用する場合は、関数内でグローバル変数を宣言する必要があります。例は次のとおりです。
$a = 1;
$b = 2;
global $a, $b;
Sum (); echo $ b;

上記のスクリプトでは「3」が出力されます。グローバル変数 $a と $b は関数内で宣言されており、これら 2 つの変数への参照はすべてグローバル変数に割り当てられます。関数が操作できるグローバル変数の数に制限はありません。
グローバル変数を受け入れる 2 番目の方法は、PHP の特殊な定義配列 $GLOBALS を使用することです。
$a = 1;
$b = 2; = $GLOBALS["a"] + $GLOBALS["b"];
Sum ();

$GLOBALS 配列は、変数の名前として「global」を使用します。グローバル変数は、この変数配列内の要素の値となります。






変数スコープに関するもう 1 つの重要な機能は、「静的変数」です。静的変数はローカル関数のアクティブなスコープ内にのみ存在しますが、プログラムがこのスコープを離れてもその値は失われません。次の例を参照してください:

Function Test () {
$a = 0;

$a++; } }
この関数は、変数 $a を 0 に設定して出力します。 「0」なので、ほとんど効果がありません。式「$a++」は変数の値をインクリメントしますが、変数 $a は関数が終了するたびに消えます。現在の計算を失わずにカウント関数を使用するには、次の例に示すように、変数 $a を static に設定します。 a++;
これで、Test() 関数が呼び出されるたびに、変数 $a とその時点でインクリメントされた後の値が出力されます。
関数が再帰的に呼び出される場合、静的変数の使用は非常に重要な方法です。再帰関数は、それ自体を呼び出すことができる関数です。再帰関数を作成するときは、考えられるループ定義に注意する必要があります。この再帰的なプロセスを中断する適切な方法が必要です。次の例は 10 回再帰します。 ;
}





http://www.bkjia.com/PHPjc/531939.html

www.bkjia.com

本当

http://www.bkjia.com/PHPjc/531939.html

技術記事

変数のスコープは、変数が定義されているコンテキストに制限されます。ほとんどのセクションでは、すべての PHP 変数に対してスコープが 1 つだけあります。ただし、ユーザー定義関数では、次のようになります...





このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

session_start()が複数回呼び出されるとどうなりますか? session_start()が複数回呼び出されるとどうなりますか? Apr 25, 2025 am 12:06 AM

session_start()への複数の呼び出しにより、警告メッセージと可能なデータ上書きが行われます。 1)PHPは警告を発し、セッションが開始されたことを促します。 2)セッションデータの予期しない上書きを引き起こす可能性があります。 3)session_status()を使用してセッションステータスを確認して、繰り返しの呼び出しを避けます。

作曲家:AIを介したPHP開発の援助 作曲家:AIを介したPHP開発の援助 Apr 29, 2025 am 12:27 AM

AIは、作曲家の使用を最適化するのに役立ちます。特定の方法には次のものが含まれます。1。依存関係管理の最適化:AIは依存関係を分析し、最適なバージョンの組み合わせを推奨し、競合を減らします。 2。自動コード生成:AIは、ベストプラクティスに準拠したComposer.jsonファイルを生成します。 3.コードの品質を改善する:AIは潜在的な問題を検出し、最適化の提案を提供し、コードの品質を向上させます。これらの方法は、開発者が効率とコードの品質を向上させるのに役立つ機械学習および自然言語処理技術を通じて実装されています。

session_start()関数の重要性は何ですか? session_start()関数の重要性は何ですか? May 03, 2025 am 12:18 AM

session_start()iscrucialinphpformangingusersions.1)itInitiateSanewsessionifnoneExists、2)resumesanexistingsession、および3)SetSessionCookieforcontinuityAcrossRequests、ApplicationslicationSliviseSlikeUserauthicationAnticatent。

データ処理と計算にMySQL関数を使用する方法 データ処理と計算にMySQL関数を使用する方法 Apr 29, 2025 pm 04:21 PM

MySQL関数は、データ処理と計算に使用できます。 1.基本的な使用には、文字列処理、日付計算、数学操作が含まれます。 2。高度な使用法には、複数の関数を組み合わせて複雑な操作を実装することが含まれます。 3.パフォーマンスの最適化では、Where句での機能の使用を回避し、GroupByおよび一時テーブルを使用する必要があります。

H5:HTML5の重要な改善 H5:HTML5の重要な改善 Apr 28, 2025 am 12:26 AM

HTML5は5つの重要な改善をもたらします。1。セマンティックタグにより、コードの明確性とSEO効果が向上します。 2.マルチメディアサポートは、ビデオとオーディオの埋め込みを簡素化します。 3。フォームエンハンスメントは、検証を簡素化します。 4.オフラインおよびローカルストレージにより、ユーザーエクスペリエンスが向上します。 5。キャンバスとグラフィック機能は、Webページの視覚化を強化します。

作曲家:PHP開発者のパッケージマネージャー 作曲家:PHP開発者のパッケージマネージャー May 02, 2025 am 12:23 AM

Composerは、PHPの依存関係管理ツールであり、Composer.jsonファイルを介してプロジェクトの依存関係を管理しています。 1)依存関係情報を取得するためのComposer.jsonを解析する。 2)依存関係を解析して、依存性ツリーを形成します。 3)PackagistからVendorディレクトリへの依存関係をダウンロードしてインストールします。 4)Composer.Lockファイルを生成して、依存関係バージョンをロックして、チームの一貫性とプロジェクトの保守性を確保します。

mysqlの文字セットと照合ルールを構成する方法 mysqlの文字セットと照合ルールを構成する方法 Apr 29, 2025 pm 04:06 PM

MySQLで文字セットと照合を構成する方法は次のとおりです。1。サーバーレベルでの文字セットとコレクションの設定:setNames'utf8 '; setCharacterSetutf8; setCollat​​ion_connection = 'utf8_general_ci'; 2。特定の文字セットと照合を使用するデータベースを作成します:createdatabaseexample_dbcharactersetutf8collat​​eutf8_general_ci; 3.テーブルを作成するときに文字セットとコレクションを指定:createTableExample_table(idint

cでタイプの特性を使用する方法は? cでタイプの特性を使用する方法は? Apr 28, 2025 pm 08:18 PM

Typetraitsは、Cでコンパイル時間タイプのチェックと操作に使用され、コードの柔軟性とタイプの安全性が向上します。 1)タイプの判断は、STD :: iS_integralおよびstd :: is_floating_pointを介して実行され、効率的なタイプチェックと出力を達成します。 2)std :: is_triviely_copyableを使用して、ベクトルコピーを最適化し、タイプに従って異なるコピー戦略を選択します。 3)コンパイル時間の意思決定、タイプの安全性、パフォーマンスの最適化、コードの複雑さに注意してください。タイプトライトの合理的な使用は、コードの品質を大幅に改善できます。

See all articles