分析静态存储区、堆、栈:
静态存储区:编译时由编译器分配,由系统释放,其存放在的是全局变量、static变量和常量。
栈:有编译器自动释放,存放在主调函数中被调函数的下一句代码、函数参数、局部变量,容量有限,较小。
对:由程序员自己分配释放,若不手动释放程序结束才释放。若对分配空间不用时不释放而一味分配,则可能造成内存泄露,其容量取决于虚拟内存,较大。
区别:1)栈是由高地址向低地址扩展,堆是由低地址向高地址扩展;2)栈是连续空间,堆是不连续空间;3)申请空间时,栈的分配更快,堆则要变量找空闲存储地址链表,修改链表,在进行分配,而栈则是只要空间够用就可分配,不够报栈溢出。4)静态存储区生命期最长,栈的生命期最短,到函数调用结束,堆生命期取决于程序员释放时间。
指针与引用区别:
相同点:都是地址的概念;指针指向一块内存,它的内容是所指内存的地址;引用是某块内存的别名
区别:1)指针是一个实体,而引用仅是个别名;
2)引用使用时无需解引用(*),指针需要解引用;
3)引用只能在定义时被初始化一次,之后不可变;指针可以改变
4)引用没有const,指针有const
5)引用不能为空,指针可以为空
6)“sizeof 引用”得到的是所指向变量(对象)的大小,而“sizeof 指针”得到的是指针本身(所指向的变量或对象地址)的大小
7)指针和引用的自增(++)运算意义不一样
8)从内存分配上看:程序为指针变量分配内存区域,而引用不需要分配内存区域。