对像在 PHP 里面和整型、浮点型一样,也是一种数据类,都是存储不同类型数据用的,在运行的时候都要加载到内存中去用。
class Person
{
//下面是人的成员属性
var $name; //人的名字
var $sex; //人的性别
var $age; //人的年龄
//下面是人的成员方法
function say() //这个人可以说话的方法
{
echo "这个人在说话";
}
function run() //这个人可以走路的方法
{
echo "这个人在走路";
}
}
$p1=new Person();
$p2=new Person();
$p3=new Person();
$p1/$p2/$p3 是对象名称在 栈内存
里面,new Person()是真正的对象是在 堆内存
里面的。
从上图可以看出$p1=new Person();等号右边是真正的对象实例,在堆内存里面的实体,上图一共有 3 次 new Person(),所以会在堆里面开辟 3 个空间,产生 3 个实例对象,每个对象之间都是相互独立的,使用自己的空间,在 PHP 里面,只要有一个 new 这个关键字出现就会实例化出来一个对象,在堆里面开辟一块自己的空间。每个在堆里面的实例对象是存储属性的,比如说,现在堆里面的实例对象里面都存有姓名、性别和年龄。每个属性又都有一个地址。
$p1=new Person(); $p1
是一个引用变量,通过赋值运算符“=”把对象的首地址赋给 $p1
这个引用变量,所以 $p1
是存储对象首地址的变量,$p1 放在栈内存里边,$p1
相当于一个指针指向堆里面的对象,所以我们可以通过$p1 这个引用变量来操作对象,通常我们也称对象引用为对象。
参考文章:http://www.cnblogs.com/lln7777/archive/2012/03/14/2396164.html
栈内存与堆内存的区别
因为PHP本身也是C语言写的,所以在此介绍一下C语言中分配内存的原理:
内存从逻辑上说大体上是分为 4 段, 栈空间段
、堆空间段
、代码段
、初始化静态段
,程序里面不同的声明放在不同的内存段里面。
-
栈空间段
是存储占用相同空间长度并且占用空间小的数据类型的地方,比如说整型 1,10,
100,1000,10000,100000 等等,在内存里面占用空间是等长的,都是 64 位 4 个字节。 -
栈空间段
数据长度不定长,而且占有空间很大的数据类型数据的存储。 - 栈内存是可以直接存取的,而堆内存是不可以直接存取的内存。对于我们的对象来说就是一种大的数据类型而且是占用空间不定长的类型,所以说对象是放在堆里面的,但对象名称是放在栈里面的,这样通过对象名称就可以使用对象了。
int a = 0; //全局初始化区
char *p1; //全局未初始化区
main()
{
int b; //栈
char s[] = "abc"; //栈
char *p2; //栈
char *p3 = "123456"; //123456\0在常量区,p3在栈上。
static int c =0; //全局(静态)初始化区
p1 = (char *)malloc(10); //堆
p2 = (char *)malloc(20); //堆
}
堆和栈的第一个区别就是申请方式不同:栈(英文名称是stack)是系统自动分配空间的,例如我们定义一个 char a;系统会自动在栈上为其开辟空间。而堆(英文名称是heap)则是程序员根据需要自己申请的空间,例如malloc(10);开辟十个字节的空间。
由于栈上的空间是自动分配自动回收的,所以栈上的数据的生存周期只是在函数的运行过程中,运行后就释放掉,不可以再访问。而堆上的数据只要程序员不释放空间,就一直可以访问到,不过缺点是一旦忘记释放会造成内存泄露。
关于堆和栈区别的比喻
使用栈就象我们去饭馆里吃饭,只管点菜(发出申请)、付钱、和吃(使用),吃饱了就走,不必理会切菜、洗菜等准备工作和洗碗、刷锅等扫尾工作,他的好处是快捷,但是自由度小。
使用堆就象是自己动手做喜欢吃的菜肴,比较麻烦,但是比较符合自己的口味,而且自由度大。比喻很形象,说的很通俗易懂,不知道你是否有点收获。