関数・クラス解説

define

version:PHP 4, PHP 5, PHP 7 (公式)

名前を指定して定数を定義する

公式リファレンス

書式

define ( string $name , mixed $value [, bool $case_insensitive = FALSE ] ) : bool

説明

実行時に、名前を指定して定数を定義します。

パラメータ

name
定数の名前。
注意: 予約語や無効な名前を使っていても、定数を define() できてしまいます。これらの値はを取得するには、 constant() 関数を使うこと(だけ)しかできません。 しかしながら、こういったことをするのは推奨されません。
value
定数の値。PHP 5 では、value は スカラー値 (int、 float、string、bool あるいは NULL) でなければいけません。PHP 7 では配列を使うこともできます。
警告 リソース型の定数を定義することもできますが、 推奨できません。予期せぬ振る舞いをする可能性があります。
case_insensitive
TRUE を指定すると、定数は大文字小文字を区別しないようになります。 デフォルトでは大文字小文字を区別します。つまり CONSTANT と Constant は別の値を表すわけです。
警告 大文字小文字を区別する定数を定義するのは、 PHP 7.3.0 以降では推奨されなくなりました。
注意: 大文字小文字を区別しないときは、定数は小文字で格納されます。

返値

成功した場合に TRUE を、失敗した場合に FALSE を返します。

注意

警告 リソース型の定数を定義することもできますが、 推奨できません。予期せぬ振る舞いをする可能性があります。

更新履歴

バージョン 説明
7.3.0 case_insensitive は非推奨になりました。 8.0.0 で削除される予定です。
7.0.0 array が使えるようになりました。

サンプル

例1 定数の定義

define("CONSTANT", "Hello world."); echo CONSTANT; // "Hello world." を出力します echo Constant; // "Constant" を出力し、警告が発生します define("GREETING", "Hello you.", true); echo GREETING; // "Hello you." を出力します echo Greeting; // "Hello you." を出力します // PHP 7 以降で動作します define('ANIMALS', array(     'dog',     'cat',     'bird' )); echo ANIMALS[1]; // "cat" を出力します

例2 予約された名前を定数にする

マジック定数 と同じ名前の定数を定義できる 可能性 を示します。 しかしながら、結果として起きる振る舞いは明らかに混乱を招くため、 こんなことを実際にすることは推奨されません。

var_dump(defined('__LINE__')); var_dump(define('__LINE__', 'test')); var_dump(constant('__LINE__')); var_dump(__LINE__);

上の例の出力は以下となります。

bool(false) bool(true) string(4) "test" int(5)

参考

  • defined() - 指定した名前の定数が存在するかどうかを調べる
  • constant() - 定数の値を返す
  • 定数の節
  • ワード検索


    ※入力キーワードが、関数名・説明文・タグに含まれるものを検索

    関数名アルファベット別

    A B C D E F G H I J
    K L M N O P Q R S T
    U V W X Y Z _

    最終更新一覧

    stristr
     大文字小文字を区別せず文字列を検索し、ヒット箇所以降(あるいは以前)の文字列を返却

    stripslashes
     バックスラッシュでエスケープされた文字列から、バックスラッシュを取り除く

    stripos
     大文字小文字を区別せずに文字列が最初に現れる位置を取得する

    stripcslashes
     addcslashes() でクォートされた文字列をアンクォートする

    strip_tags
     文字列から HTML と PHP のタグを除去して返却

    strcspn
     指定した文字が最初に現れる位置を調べる

    strcoll
     ロケールに基づいて2つの文字列を比較し同じか(あるいは大小)を判定する

    strcmp
     2つの文字列を比較し同じか(あるいは大小)を判定する

    strchr
     strstr() のエイリアス

    strcasecmp
     2つの文字列を比較(大文字小文字を区別せず同じとみなす)

    カテゴリー一覧

    PHP の振る舞いの変更
    音声フォーマットの操作
    認証サービス
    コマンドライン関連
    圧縮およびアーカイブ
    暗号
    データベース関連
    日付および時刻関連
    ファイルシステム
    自然言語および文字エンコーディング
    画像処理および作成
    メール関連
    数学
    テキスト以外の MIME 型
    プロセス制御
    その他の基本モジュール
    その他のサービス
    検索エンジン用の拡張モジュール
    サーバー固有のモジュール
    セッション関連
    テキスト処理
    変数・データ型関連
    ウェブサービス
    Windows 用のモジュール
    XML 操作
    GUI用の拡張モジュール