发现原来是php5.3新增的,PHP中预先定义好的常量
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中预先定义好的常量
关键词:
下一篇:没有了