发现原来是php5.3新增的,PHP中预先定义好的常量

作者: 编程  发布:2019-11-23

PHP中预先定义好的常量: __FILE__ 当前正在处理的脚本文件名。如果使用在一个被包含的文件中,那么它的值就是这个被包含的文件,而不是包含它的文件名。 __LINE__ 正在处理的文件的当前行数。 PHP_VERSION 表示PHP处理器的当前版本,如:'3.0.8-dev'。 PHP_OS PHP处理器所在的操作系统名字,如:'Linux'。 TRUE 真值 FALSE 假值 可以用DEFINE函数定义更多的常量。 如,定义常量: <?php define("CONSTANT", "Hello world."); echo CONSTANT; // outputs "Hello world." ?> 用 __FILE__ 和 __LINE__ 的举例 <?php function report_error($file, $line, $message) { echo "An error occured in $file on line $line: $message."; } report_error(__FILE__,__LINE__, "Something went wrong!"); ?>

PHP预先定义了几个常量,并提供了一种机制在运行时自己定义。常量和变量基本上是一样的,不同的是:常量必须用DEFINE函数定义,常量一旦定义好,就不能被重新定义了。
 
PHP中预先定义好的常量:
__FILE__
当前正在处理的脚本文件名。如果使用在一个被包含的文件中,那么它的值就是这个被包含的文件,而不是包含它的文件名。
 
__LINE__
正在处理的文件的当前行数。
 
PHP_VERSION
表示PHP处理器的当前版本,如:'3.0.8-dev'。
 
PHP_OS
PHP处理器所在的操作系统名字,如:'Linux'。
 
TRUE
真值
FALSE
假值

在PHP中定义常量是通过define()函数来完成的,但在类中定义常量不能使用define(),而需要使用const修饰符。类中的常量使用const定义后,其访问方式和静态成员类似,都是通过类名或在成员方法中使用self访问,但在PHP 5.3.0之后也可以使用对象来访问。被const定义的常量不能重新赋值,如果在程序中试图改变它的值将会出现错误。

今天看到一个魔术变量,是以前没见过的,__DIR__,我查了查,发现原来是php5.3新增的,顺便举几个例子,解释一下php的魔术变量

可以用DEFINE函数定义更多的常量。
 
如,定义常量:
<?php
define("CONSTANT", "Hello world.");
echo CONSTANT; // outputs "Hello world."
?>
用 __FILE__ 和 __LINE__ 的举例
<?php
function report_error($file, $line, $message) {
echo "An error occured in $file on line $line: $message.";
}
report_error(__FILE__,__LINE__, "Something went wrong!");
?>

 代码如下

系统常量

<?php 

__FILE__ 当前文件名
__LINE__ 当前行数
__9159.com,FUNCTION__ 当前函数名
__CLASS__ 当前类名
__METHOD__ 当前对象的方法名

     class MyClass { 

详细分析

           const CONSTANT = 'CONSTANT value' ; //使用const声明一个常量,并直接赋上初使值 

1,__FILE__

              function showConstant() {                

文件的完整路径和文件名。如果用在被包含文件中,则返回被包含的文件名。自 PHP 4.0.2 起,__FILE__ 总是包含一个绝对路径(如果是符号连接,则是解析后的绝对路径),而在此之前的版本有时会包含一个相对路径。 
PHP 常量dirname(__file__) 
__FILE__ :被称为PHP魔术常量,返回当前执行PHP脚本的完整路径和文件名,包含一个绝对路径 
1)dirname(__FILE__) 函数返回的是脚本所在在的路径。 更新网络 
比如文件 b.php 包含如下内容:  

                   echo  self ::CONSTANT ."<br>" ;//使用self访问常量,注意常量前不要加“$” 

 代码如下

             } 

<?php  
$basedir = dirname(__FILE__);  
echo $basedir 
//将在页面打印出一个这个文件所在绝对路径! 
?>  

      } 

 
我做的测试得到结果: E:websiteothertestcms 
这个相当于, asp中的server.mappth的用法 
如果b.php被其他目录里的a.php文件require 或者 include 去引用的话。 变量$basedir 的内容还是b.php所在的那个文件夹的路径。 而不是变成a.php文件所在的目录。 
2)dirname(__FILE__) 一般会返回文件所的当前目录到系统根目录的一个目录结构。 
不会返回当前的文件名称。 dirname(__FILE__) 也可能返回一个 . (当前目录) [原因是 b.php 文件在 http.conf 或者 PHP 配置开发环境的默认WEB目录下

      echo MyClass:: CONSTANT . "<br>" ; //在类外部使用类名称访问常量,也不要加”$” 

 

      $class = new MyClass();                      

 代码如下

     $class->showConstant();                       

<?php
/**
在你的公用的配置文件中,来设置你的根目录,这样就不用担心经常搬家了。
*/
define(‘ROOT_PATH’, dirname(__FILE__) . DIRECTORY_SEPARATOR);
echo ROOT_PATH;
echo “<br>”;
echo __FILE__;
echo “<br>”;
echo dirname(__FILE__);
echo “<br>”;
echo dirname(dirname(__FILE__));
?>

      echo $class ::CONSTANT;  // PHP 5.3.0之后 

2,__LINE__

?>

文件中的当前行号。这个变量在调试错误的时候,还是比较有作用的,其他的时候,没什么用处,纯属个人观点。

关注细节:使用const定义的常量名称前不需要使用“$“符号,且常量名称通常都是大写的。

 代码如下

试图为const定义的常量赋值,将会出现错误。

<?php
echo __LINE__;  //显示,__LINE__所在的行号
?>

 代码如下

3,__CLASS__

<?php 

类的名称,PHP5返回的结果是区分大小写的

  class MyClass { 

 代码如下

           const CONSTANT = 'CONSTANT value' ;   

<?php
class base_class
{
function say_a()
{
echo “‘a’ – said the ” . __CLASS__ . “<br/>”;
}
function say_b()
{
echo “‘b’ – said the ” . get_class($this) . “<br/>”;
}
}
class derived_class extends base_class
{
function say_a()
{
parent::say_a();
echo “‘a’ – said the ” . __CLASS__ . “<br/>”;
}
function say_b()
{
parent::say_b();
echo “‘b’ – said the ” . get_class($this) . “<br/>”;
}
}
$obj_b = new derived_class();
$obj_b->say_a();
echo “<br/>”;
$obj_b->say_b();
?>
结果为:
‘a’ – said the base_class
‘a’ – said the derived_class
‘b’ – said the  derived_class
‘b’ – said the derived_class

               function setCONSTANT(){ 

有的时候,我们可以用get_class来代替__CLASS__

                self ::CONSTANT  = 'news CONSTANT' ;//程序运行结果将会出错。 

4,__FUNCTION__和__METHOD__

     }                                                                                  

__FUNCTION__:函数名称,php5中返回的结果是区分大小写的
__METHOD__:方法中的函数名称,php5中返回的结果是区分大小写的

      } 

二个都是取得方法的名称,有什么不同呢?

      echo MyClass:: CONSTANT ;                                                     

 代码如下

?>

<?php
class test
{
function a()
{
echo __FUNCTION__;
echo “<br>”;
echo __METHOD__;
}
}
function good (){
echo __FUNCTION__;
echo “<br>”;
echo __METHOD__;
}
$test = new test();
$test->a();
echo “<br>”;
good();
?>
返回结果:
a
test::a
good
good

程序运行结果将会出错。

相对于孤立的函数来说,二个都可以取出函数名,没什么区别,如果是class中的方法时,__FUNCTION__只能取出class的方法名,而__METHOD__不光能取出方法名,还能取出class名

使用const修饰的常量更其它的常量 有点不同的地方就是:常量名前不要使用”$”,切记!当然这个常量值也是不能修改的,一旦定义就不能程序的任何地方进行“人为”的修改。这跟使用 define定义是一样,还有就是使用const来定义当然也遵守其它常量的命名规则

5,__DIR__

扩展阅读:

文件所在的目录。如果用在被包括文件中,则返回被包括的文件所在的目录。它等价于 dirname(__FILE__)。除非是根目录,否则目录中名不包括末尾的斜杠。(PHP 5.3.0中新增)

常量前面没有美元符号($);
常量只能用 define() 函数定义,而不能通过赋值语句;
常量可以不用理会变量范围的规则而在任何地方定义和访问;
常量一旦定义就不能被重新定义或者取消定义;
常量的值只能是标量;
常量只能包含标量数据(boolean,integer,float 和 string),不要定义 resource常量.
可以用函数 constant() 来读取常量的值.get_defined_constants()可以获得所有已定义的常量列表.
如果使用了一个未定义的常量,PHP 假定想要的是该常量本身的名字,如同用字符串调用它一样(CONSTANT 对应 “CONSTANT”),此时将发出一个 E_NOTICE 级的错误.
PHP 的“魔术常量”.

如果在5.3以前的版本中想用__DIR__的话,可以这样

名称

 代码如下

说明

<?php
if(!defined(‘__DIR__’)) {
$iPos = strrpos(__FILE__, “/”);
define(“__DIR__”, substr(__FILE__, 0, $iPos) . “/”);
}
?>

__LINE__

6,__NAMESPACE__

文件中的当前行号。

当前命名空间的名称(大小写敏感)。这个常量是在编译时定义的(PHP 5.3.0 新增)

__FILE__

7,__STATIC__

文件的完整路径和文件名。如果用在包含文件中,则返回包含文件名。自 PHP 4.0.2 起,__FILE__ 总是包含一个绝对路径,而在此之前的版本有时会包含一个相对路径。

当你调用class的静态方法时,返回class名称,区分大小写。如果在继承中调用的话,不管在继承中有没有定义,都能返回继承的class名。

__FUNCTION__

 代码如下

函数名称(PHP 4.3.0 新加)。自 PHP 5 起本常量返回该函数被定义时的名字(区分大小写)。在 PHP 4 中该值总是小写字母的。

<?php
//php5.3
class Model
{
public static function find()
{
echo __STATIC__;
}
}
class Product extends Model {}
class User extends Model {}
Product::find(); // “Product”
User::find(); // “User”
?>

__CLASS__

补充:php中魔术方法

类的名称(PHP 4.3.0 新加)。自 PHP 5 起本常量返回该类被定义时的名字(区分大小写)。在 PHP 4 中该值总是小写字母的。

__construct() 当实例化一个对象的时候,这个对象的这个方法首先被调用。
__destruct() 当删除一个对象或对象操作终止的时候,调用该方法。
__get() 当试图读取一个并不存在的属性的时候被调用。
__set() 当试图向一个并不存在的属性写入值的时候被调用。
__call() 当试图调用一个对象并不存在的方法时,调用该方法。
__toString() 当打印一个对象的时候被调用
__clone() 当对象被克隆时,被调用
__isset()
__unset()
__autoload($classname)
__sleep()
__wakeup()

__METHOD__

类的方法名(PHP 5.0.0 新加)。返回该方法被定义时的名字(区分大小写)。

本文由9159.com发布于编程,转载请注明出处:发现原来是php5.3新增的,PHP中预先定义好的常量

关键词:

上一篇:服务端会首先对页面中的PHP命令进行处理
下一篇:没有了