PHP源码分析-常量
来源:互联网 发布:雀巢优麦怎么样知乎 编辑:程序博客网 时间:2024/06/05 07:38
2.5 常量
常量是一个简单值的标识符(名字)。如同其名称所暗示的,在脚本执行期间该值不能改变。常量默认为大小写敏感。通常常量标识符总是大写的。
常量名和其它任何 PHP 标签遵循同样的命名规则。合法的常量名以字母或下划线开始,后面跟着任何字母,数字或下划线。
PHP中的常量通过define()
函数定义:
define('CONST_VAR_1', 1234);
2.5.1 常量的存储
在内核中常量存储在EG(zend_constant)
哈希表中,访问时也是根据常量名直接到哈希表中查找,其实现比较简单。
常量的数据结构:
typedef struct _zend_constant { zval value; //常量值 zend_string *name; //常量名 int flags; //常量标识位 int module_number; //所属扩展、模块} zend_constant;
常量的几个属性都比较直观,这里只介绍下flags,它的值可以是以下三个中任意组合:
#define CONST_CS (1<<0) //大小写敏感#define CONST_PERSISTENT (1<<1) //持久化的#define CONST_CT_SUBST (1<<2) //允许编译时替换
介绍下三种flag代表的含义:
* CONST_CS: 大小写敏感,默认是开启的,用户通过define()定义的始终是区分大小写的,通过扩展定义的可以自由选择
* CONST_PERSISTENT: 持久化的,只有通过扩展、内核定义的才支持,这种常量不会在request结束时清理掉
* CONST_CT_SUBST: 允许编译时替换,编译时如果发现有地方在读取常量的值,那么编译器会尝试直接替换为常量值,而不是在执行时再去读取,目前这个flag只有TRUE、FALSE、NULL三个常量在使用
2.5.2 常量的销毁
非持久化常量在request请求结束时销毁,具体销毁操作在:php_request_shutdown()->zend_deactivate()->shutdown_executor()->clean_non_persistent_constants()
。
void clean_non_persistent_constants(void){ if (EG(full_tables_cleanup)) { zend_hash_apply(EG(zend_constants), clean_non_persistent_constant_full); } else { zend_hash_reverse_apply(EG(zend_constants), clean_non_persistent_constant); }}
然后从哈希表末尾开始向前遍历EG(zend_constants),将非持久化常量删除,直到碰到第一个持久化常量时,停止遍历,正常情况下所有通过扩展定义的常量一定是在PHP中通过define定义之前,当然也并非绝对,这里只是说在所有常量均是在MINT阶段定义的情况。
持久化常量是在php_module_shutdown()
阶段销毁的,具体过程与上面类似。
转载:https://github.com/pangudashu/php7-internal
- PHP源码分析-常量
- PHP源码-常量
- php源码-常量
- kudu源码分析之一常量constants
- find_fufei.php源码分析
- php源码分析
- php 源码 分析
- php源码分析 (第一章)
- PHP源码分析-数组
- PHP源码分析-数组
- php数组源码分析
- PHP源码分析-数组
- PHP源码分析
- PHP源码分析
- php源码分析指引
- php-fpm源码分析
- PHP源码分析-变量
- PHP源码分析-数组
- UIBUtton图片和文字的位置关系封装
- Java 使用POI 实现Excel 的导出
- 一位ACMer过来人的心得
- JNI日志调试中文乱码
- c语言中strcat函数的作用
- PHP源码分析-常量
- 安卓平台下ARM Mali OpenCL编程-GPU信息检测
- 欢迎使用CSDN-markdown编辑器
- mysql出现unblock with 'mysqladmin flush-hosts' 解决方法
- DP--LCS
- Vue 使用Spread.js没有层级关系(隐藏与显示)
- vim 的使用方法
- android jni 中文乱码,该怎么解决
- Linux上Weblogic服务域的创建与部署