关于“php_static_初始化”的问题,小编就整理了【3】个相关介绍“php_static_初始化”的解答:
php高端功能?1.使用Per-Class常量。
用途:可以在不需要初始化该类的情况下使用:
例子:
class Man //定义Man类
{
const birthday = 19960101; //定义常量变量
}
//使用const修饰的变量,我们可以通过::操作符对其进行访问。例如:
echo Man::birthday;
//使用const修饰的变量是无法进行修改的,例如:
// Man::birthday=19990101;
//上面那句是会报语法错误的。
?>
执行结果:打印出变量值 也就是19960101
2.对静态方法的实现
用途:PHP可以在方法前面使用static关键字,该方法就可以在未初始化类的情况下通过类名::来进行调用,类似于上面。例如:
<?php
class Man //创建一个Man类
{
static function boy() //创建静态方法
{
return 'boy'; //函数返回字符串boy
}
}
echo Man::boy(); //打印函数的返回值,也就是boy
//但是在静态方法中,是不能使用this关键字的。因为可能会没有可以引用的对象实例
//通俗点说,就是一般我们调用函数是使用obj->method(),而$this就是当前的对象,但是因为
static变量什么时候初始化?只会执行一次
复现:
可以在Student类的构造函数里面加上 如:
运行会发现它只会打印一次
粗略原理:
static 变量是类变量,会在该类第一次使用时进行初始化,并且只会初始化一次,类加载器内部会有锁去控制避免一个类被初始化多次,静态field和静态代码块 都是只会执行一次,在编译器的角度来说,编译器在编译时会按顺序收集静态field和静态代码块 然后放到一个生成的<cinit>特殊方法中,类初始化的时候会调用 <cinit>方法。
应用:
static变量只会加载一个的这个特性可以被应用在单例的实现中,如这里(
单例模式 | 菜鸟教程
基于 classloader 机制避免了多线程的同步问题 。
对于你的疑问:
对于第三种情况, 当前线程等上一个线程初始化后, 再执行一次初始化? 那岂不是跟第四种情况冲突?
等上一个线程初始化后,判断一下有有没成功初始化,直接拿结果就好
对于第三种情况, 当前线程等上一个线程初始化后, 不会再初始化, 但是有可能拿到一个只有部分域初始化的不完全对象? 这里的初始化 只是申请了一块内存, 赋值了指针?
你这个疑问有点意思,上一个线程初始化可以说是拿了锁,然后执行了加锁代码,当退出锁时,加锁代码的结果会完全同步,这是锁的一个特性(好像叫内存可见性什么的)。然后下一个现场拿到的结果就是正常的结果
static所有形式?static静态类型,程序运行就会进行初始化和分配内存地址,只有一个实例,是单例模式的饿汉模式。
到此,以上就是小编对于“php_static_初始化”的问题就介绍到这了,希望介绍关于“php_static_初始化”的【3】点解答对大家有用。