検索
ホームページバックエンド開発PHPチュートリアルPHP_PHP チュートリアルにおける一重引用符と二重引用符の違いの詳細な紹介

この記事では、PHP におけるシングルクォーテーションとダブルクォーテーションの違いについて詳しく紹介しています。詳しく知りたい学生は参照してください。

1.文字列を定義します
PHP では、一重引用符または二重引用符を使用して文字列を定義できます。ただし、文字列を定義するには同じ一重引用符または二重引用符を使用する必要があります。たとえば、「He​​llo」と「Hello」は無効な文字列定義です。
文字列を定義する場合、一重引用符または二重引用符の 1 種類の引用符のみが区切り文字とみなされます。したがって、文字列が二重引用符で始まる場合は、二重引用符のみがパーサーによって解析されます。このようにして、二重引用符で囲まれた文字列内に他の文字 (一重引用符も含む) を含めることができます。次の引用符文字列はすべて有効です:

PHPコード

$s = "私は二重引用符文字列内の「一重引用符文字列」です";

$s = '私は一重引用符文字列内の「二重引用符文字列」です';

$s = "私は二重引用符文字列内の「一重引用符文字列」です";

$s = '私は一重引用符文字列内の「二重引用符文字列」です';

「なぜ「これ」は機能しないのですか?」という文字列は 3 つの段落に分割されます。この文字列で二重引用符を表現したい場合は、エスケープ文字「" (バックスラッシュ) を使用して、「なぜ "this" は機能しないのですか?」 のようにすることができます。

2. 文字列変数内の単一引用符と二重引用符

PHP では、二重引用符で囲まれた文字列に文字列変数を直接含めることができます。次の 2 つの文字列の処理結果が同じであることがわかります。

$full_name = $first_name . $last_name;

$full_name = "$first_name $last_name"

一重引用符文字列と二重引用符文字列は、PHP では異なる方法で処理されます。二重引用符で囲まれた文字列の内容は解釈して置換できますが、一重引用符で囲まれた文字列の内容は常に通常の文字とみなされます。例:

PHPコード

$foo = 2;

echo "foo is $foo"; // 結果を出力: foo は 2

echo 'foo is $foo'; // 結果を出力: foo は $foo

echo "foo is $foon"; // 出力結果: foo は 2 (改行あり)

echo 'foo is $foon'; // 結果を出力: foo は $foon

$foo = 2;

echo "foo is $foo"; // 結果を出力: foo は 2

echo 'foo is $foo'; // 結果を出力: foo は $foo

echo "foo is $foon"; // 出力結果: foo は 2 (改行あり)

echo 'foo is $foon'; // 結果を出力: foo は $foon

ご覧のとおり、一重引用符文字列では、バックスラッシュでさえその拡張された意味を失います (挿入されたバックスラッシュと挿入された一重引用符 ' を除く)。したがって、変数置換を実行し、文字列に n (改行) などのエスケープ シーケンスを含める場合は、二重引用符を使用する必要があります。一重引用符文字列は他の場所でも使用できます。スクリプト内で一重引用符文字列を使用すると、処理速度が速くなります。これは、PHP パーサーが一重引用符文字列を比較的単純な方法で処理する一方で、二重引用符の処理には文字列内の解析も必要となるためです。したがって、より複雑になり、処理が若干遅くなります。

文字列内の変数の複雑な組み合わせを参照するときにいくつかの問題が発生する可能性がありますが、次のコードは正常に機能します:

PHPコード

エコー "値 = $foo";

エコー "値 = $a[$i]";

エコー "値 = $foo";

エコー "値 = $a[$i]"

次のコードでは、必要な結果が得られません:

echo "value = $a[$i][$j]"; //二次元配列 $a の要素を出力したい。

これらの文字列の使用における潜在的な問題を回避するために、通常は次のように複雑な変数を文字列から分離します: echo 'value = ' . $a[$i][$j];//文字 接続にはドット (.) を使用します。文字列

もう 1 つの方法は、構文アナライザーがそれらを正しく識別できるように、複雑な変数を中括弧で囲むことです。

echo "value = {$a[$i][$j]}" //二次元配列$aの要素を出力する

このようにして、新たな問題が発生します。文字列内で中括弧文字自体を引用したい場合は、エスケープ文字を使用することを忘れないでください:

PHPコード

$var = 3;

echo "value = {$var}" // 結果を出力 "value = 3"

echo "value = {$var}" // 結果を出力 "value = {3}"

$var = 3;

echo "value = {$var}" // 結果を出力 "value = 3"

echo "value = {$var}" // 結果を出力 "value = {3}"

3. SQL ステートメント内

これはよく発生する問題で、データベースに挿入される SQL ステートメントでは文字列の定義に一重引用符が使用されており、一重引用符を含む文字列をデータベースに挿入すると、SQL ステートメントが間違ってしまいます。

例: $sql="insert into userinfo (username,password) Values('O'Kefee','123456')"

このとき、SQL文にエスケープ文字のバックスラッシュを追加する方法もあります

つまり:...Values('O'Kefee',...

もちろん、addslashes() 関数を使用することもできます。この関数の機能はエスケープ文字を追加することです。

つまり: $s =addslashes("O'Kefee") ……Values('".$s."',…… )

もう 1 つの方法は、php.ini で Magic-quotes オプションを設定することです。このオプションがオンになっている場合、フォームから送信された情報に一重引用符が含まれている場合、エスケープ文字が自動的に追加されます。したがって、他の機能を使用する必要はありません。

補足: これは二重引用符と一重引用符の役割から始まります。二重引用符で囲まれたフィールドはコンパイラによって解釈されて HTML コードとして出力されますが、一重引用符で囲まれたフィールドは解釈する必要がなく、直接出力されます。 。

例:

$abc='愛しています';

echo $abc //結果は次のとおりです: 愛しています

echo '$abc' //結果は次のようになります: $abc

echo "$abc" //結果は次のようになります: 愛しています

そのため、データベース内の SQL ステートメントに値を割り当てるときは、二重引用符を使用する必要があります。 SQL="select a,b,c from..." ただし、フィールド名を引用するために SQL ステートメント内に一重引用符が含まれます。

例: select * from table where user='abc';

ここでの SQL ステートメントは SQL="select * from table where user='abc'" として直接書くことができます

しかし、次のような場合:

$user='abc';

SQL1="select * from table where user=' ".$user." ' "; 比較してください

SQL2="select * from table where user=' abc ' "

一重引用符と二重引用符の間にもう少しスペースを追加しました。より明確に見えることを願っています。

つまり、「abc」を「.$user.」にすべて一重引用符で囲んで置き換えます。 SQL 文字列全体を分割するだけです。 SQL1 は次の 3 つの部分に分類できます

1: "user=' のテーブルから * を選択します

2:$user

3:「」

文字列を接続するには . を使用します

http://www.bkjia.com/PHPjc/629102.htmlwww.bkjia.comtru​​ehttp://www.bkjia.com/PHPjc/629102.html技術記事この記事では、PHP におけるシングルクォーテーションとダブルクォーテーションの違いについて詳しく紹介しています。詳しく知りたい学生は参考にしてください。 1. 文字列を定義する PHP では、文字列を定義できます...
声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
PHPアプリケーションをより速くする方法PHPアプリケーションをより速くする方法May 12, 2025 am 12:12 AM

tomakephpapplicationsfaster、followthesesteps:1)useopcodecachinglikeopcacheTostoredscriptbytecode.2)最小化abasequeriesecachingingindexing.3)leveragephp7機能forbettercodeefficiency.4)

PHP依存性インジェクション:コードのテスト可能性を改善しますPHP依存性インジェクション:コードのテスト可能性を改善しますMay 12, 2025 am 12:03 AM

依存性注入(DI)は、明示的に推移的な依存関係によりPHPコードのテスト可能性を大幅に改善します。 1)DI分離クラスと特定の実装により、テストとメンテナンスが柔軟になります。 2)3つのタイプのうち、コンストラクターは、状態を一貫性に保つために明示的な式依存性を注入します。 3)DIコンテナを使用して複雑な依存関係を管理し、コードの品質と開発効率を向上させます。

PHPパフォーマンスの最適化:データベースクエリの最適化PHPパフォーマンスの最適化:データベースクエリの最適化May 12, 2025 am 12:02 AM

DatabaseQueryoptimizationInpholvesseveralstrategESTOEnhancePerformance.1)selectonlynlynlyndorycolumnStoredatedataTransfer.2)useindexingtospeedupdataretrieval.3)revenmecrycachingtostoreres sultsoffrequent queries.4)

簡単なガイド:PHPスクリプトで電子メールを送信します簡単なガイド:PHPスクリプトで電子メールを送信しますMay 12, 2025 am 12:02 AM

phpisusededemingemailsduetoitsbuilt-inmail()functionandsupportiveLibrarieslikephpmailerandswiftmailer.1)usethemail()functionforbasicemails、butithaslimitations.2)emploadforadvancedfeatureSlikelikelivableabableabuses.3)雇用

PHPパフォーマンス:ボトルネックの識別と修正PHPパフォーマンス:ボトルネックの識別と修正May 11, 2025 am 12:13 AM

PHPパフォーマンスボトルネックは、次の手順で解決できます。1)パフォーマンス分析にXdebugまたはBlackfireを使用して問題を見つける。 2)データベースクエリを最適化し、APCUなどのキャッシュを使用します。 3)array_filterなどの効率的な関数を使用して、配列操作を最適化します。 4)bytecodeキャッシュ用のopcacheを構成します。 5)HTTP要求の削減や写真の最適化など、フロントエンドを最適化します。 6)パフォーマンスを継続的に監視および最適化します。これらの方法により、PHPアプリケーションのパフォーマンスを大幅に改善できます。

PHPの依存関係注射:簡単な要約PHPの依存関係注射:簡単な要約May 11, 2025 am 12:09 AM

依存関係(di)inphpisadesignpatternativats anducesclassodulencies、拡張測定性、テスト可能性、および維持可能性。

PHPパフォーマンスの向上:キャッシュ戦略と技術PHPパフォーマンスの向上:キャッシュ戦略と技術May 11, 2025 am 12:08 AM

cachingemprovesppperformancebystring of computationsorquickretrieval、還元装置の削減は、reducingerloadendenhancersponseTimes.efcectivestrategiesInclude:1)opcodecaching、compiledphpscriptsinmemorytoskipcompilation;

See all articles

ホット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 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

SublimeText3 Linux 新バージョン

SublimeText3 Linux 新バージョン

SublimeText3 Linux 最新バージョン

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強力な PHP 統合開発環境

SecLists

SecLists

SecLists は、セキュリティ テスターの究極の相棒です。これは、セキュリティ評価中に頻繁に使用されるさまざまな種類のリストを 1 か所にまとめたものです。 SecLists は、セキュリティ テスターが必要とする可能性のあるすべてのリストを便利に提供することで、セキュリティ テストをより効率的かつ生産的にするのに役立ちます。リストの種類には、ユーザー名、パスワード、URL、ファジング ペイロード、機密データ パターン、Web シェルなどが含まれます。テスターはこのリポジトリを新しいテスト マシンにプルするだけで、必要なあらゆる種類のリストにアクセスできるようになります。

WebStorm Mac版

WebStorm Mac版

便利なJavaScript開発ツール

PhpStorm Mac バージョン

PhpStorm Mac バージョン

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