首頁 後端開發 php教程 PHP常數詳解

PHP常數詳解

Apr 05, 2017 am 11:33 AM

一、聲明和使用常數

       常數可以理解為不變的量。常數被定義後,在腳本的其他任何地方都不能改變。一個常量由英文字母、底線和數學組成。但數字不能作為首字母出現。

       在PHP中使用define()函數定義常數,語法格式如下:

 define(string constant_name,mixed value,case_sensitive=true)
登入後複製

      參數說明:

 常量名稱,即標識符。

      value      必選參數。常量的值。

      case_sensitive   選用參數。指定是否大小寫敏感,設定為true,表示不敏感。

取得常數有兩種方法:一種是使用常數直接取得;另一種是使用constant()函數,constant()函數和直接使用常數名輸出效果一樣。但函數可以動態輸出不同常數,在使用上更靈活方便。函數語法格式為:

   mixde constant(string const_name)
登入後複製

       參數const_name為要取得常數的名稱,也可為儲存常數名的

變數。如果取得成功則傳回常數值,否則提示錯誤訊息常數沒有被定義。

要判斷一個常數是否已經被定義,可以使用define()函數。函數語法格式為:

  bool defined(string constant_name)
登入後複製

      參數constant_name為要取得常數的名稱,成功回傳true,否則回傳false。

實例:

為了更好的理解如何定義常數,這裡給出一個定義常數實例。實例中使用上述的define()函數、constant()函數和defined()函數3個函數。使用defined()函數來定義一個常數,使用constant()函數來動態取得常數的值,並使用define()函數來判斷常數是否被定義。程式碼如下:

<?php
/define("变量名",值,是否模糊大小写)
define("MESSAGE","能看到一次");
echo MESSAGE."<br >";
echo Message."<br >";    //输出Message,表示没有该常量
define("COUNT","能看到多次",true);
echo COUNT."<br >";
echo CoUnT."<br >";      //输出COUNT,设定大小写不敏感
$name = "count";
//通过constant()函数获取常量
echo constant($name)."<br >";
//是否存在常量 "MESSAGE"
echo (defined("MESSAGE"))."<br >";  //如果常量被定义,则返回true,使用echo输出显示1。
登入後複製

輸出結果:

能看到一次
Notice: Use of undefined constant Message - assumed &#39;Message&#39; in 编辑器代码错误位置。
Message
能看到多次
能看到多次
能看到多次
1
登入後複製

二、預定義常數

php中可以使用預先定義常數來取得php中的資訊。預定義常數如下:

常數名說     明__FILE__ 預設量,是預設量常數,是PHP 程式行數PHP_OS內建常量,指執行PHP 解析器的操作系統名稱PHP_VERSION內建常量,是PHP 程序的版本TRUE該常量是一個真值FALSE該常數是一個假值NULL一個null值E_ERROR_o php腳本運行終止解析錯誤,由程式解析器報告非關鍵的錯誤,例如變數未初始化說明:以E_開頭的預定義常數,是PHP的錯誤調試部分。 實例:預定義常數與使用者自訂常數在使用上沒什麼差別。下面使用預定義常數輸出PHP中的資訊。
<?php
echo "PHP程序当前文件路径名:".FILE;
echo "<br >PHP程序当前行数:".LINE;
echo "<br >当前PHP程序的版本:".PHP_VERSION;
echo "<br >当前操作系统:".PHP_OS;
登入後複製
PHP程序当前文件路径名:D:\phpStudy\www\index.php
PHP程序当前行数:3
当前PHP程序的版本:5.6.27
当前操作系统:WINNT
登入後複製
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Java教學
1677
14
CakePHP 教程
1431
52
Laravel 教程
1334
25
PHP教程
1280
29
C# 教程
1257
24
如果session_start()被多次調用會發生什麼? 如果session_start()被多次調用會發生什麼? Apr 25, 2025 am 12:06 AM

多次調用session_start()會導致警告信息和可能的數據覆蓋。 1)PHP會發出警告,提示session已啟動。 2)可能導致session數據意外覆蓋。 3)使用session_status()檢查session狀態,避免重複調用。

作曲家:通過AI的幫助開發PHP 作曲家:通過AI的幫助開發PHP Apr 29, 2025 am 12:27 AM

AI可以幫助優化Composer的使用,具體方法包括:1.依賴管理優化:AI分析依賴關係,建議最佳版本組合,減少衝突。 2.自動化代碼生成:AI生成符合最佳實踐的composer.json文件。 3.代碼質量提升:AI檢測潛在問題,提供優化建議,提高代碼質量。這些方法通過機器學習和自然語言處理技術實現,幫助開發者提高效率和代碼質量。

session_start()函數的意義是什麼? session_start()函數的意義是什麼? May 03, 2025 am 12:18 AM

session_start()iscucialinphpformanagingusersessions.1)ItInitiateSanewsessionifnoneexists,2)resumesanexistingsessions,and3)setsasesessionCookieforContinuityActinuityAccontinuityAcconActInityAcconActInityAcconAccRequests,EnablingApplicationsApplicationsLikeUseAppericationLikeUseAthenticationalticationaltication and PersersonalizedContentent。

如何使用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帶來了五個關鍵改進:1.語義化標籤提升了代碼清晰度和SEO效果;2.多媒體支持簡化了視頻和音頻嵌入;3.表單增強簡化了驗證;4.離線與本地存儲提高了用戶體驗;5.畫布與圖形功能增強了網頁的可視化效果。

作曲家:PHP開發人員的軟件包經理 作曲家:PHP開發人員的軟件包經理 May 02, 2025 am 12:23 AM

Composer是PHP的依賴管理工具,通過composer.json文件管理項目依賴。 1)解析composer.json獲取依賴信息;2)解析依賴關係形成依賴樹;3)從Packagist下載並安裝依賴到vendor目錄;4)生成composer.lock文件鎖定依賴版本,確保團隊一致性和項目可維護性。

怎樣在C  中使用type traits? 怎樣在C 中使用type traits? Apr 28, 2025 pm 08:18 PM

typetraits在C 中用於編譯時類型檢查和操作,提升代碼的靈活性和類型安全性。 1)通過std::is_integral和std::is_floating_point等進行類型判斷,實現高效的類型檢查和輸出。 2)使用std::is_trivially_copyable優化vector拷貝,根據類型選擇不同的拷貝策略。 3)注意編譯時決策、類型安全、性能優化和代碼複雜性,合理使用typetraits可以大大提升代碼質量。

MySQL的字符集和排序規則如何配置 MySQL的字符集和排序規則如何配置 Apr 29, 2025 pm 04:06 PM

在MySQL中配置字符集和排序規則的方法包括:1.設置服務器級別的字符集和排序規則:SETNAMES'utf8';SETCHARACTERSETutf8;SETCOLLATION_CONNECTION='utf8_general_ci';2.創建使用特定字符集和排序規則的數據庫:CREATEDATABASEexample_dbCHARACTERSETutf8COLLATEutf8_general_ci;3.創建表時指定字符集和排序規則:CREATETABLEexample_table(idINT

See all articles
E_PARSE
E_NOTICE
,而不是一條"_"。
輸出類似如下的結果:注意:根據每個使用者所使用的作業系統和軟體版本不同,所得結果也不一定相同。