C/C++中指针和引用之相关问题深入研究
本文导语: 一、基本知识指针和引用的声明方式:声明指针: char* pc;声明引用: char c = 'A' char& rc = c; 它们的区别:①从现象上看,指针在运行时可以改变其所指向的值,而引用一旦和某个对象绑定后就不再改变。这句话可以理解为:...
一、基本知识
指针和引用的声明方式:
声明指针: char* pc;
声明引用: char c = 'A'
char& rc = c;
它们的区别:
①从现象上看,指针在运行时可以改变其所指向的值,而引用一旦和某个对象绑定后就不再改变。这句话可以理解为:指针可以被重新赋值以指向另一个不同的对象。但是引用则总是指向在初始化时被指定的对象,以后不能改变,但是指定的对象其内容可以改变。
②从内存分配上看,程序为指针变量分配内存区域,而不为引用分配内存区域,因为引用声明时必须初始化,从而指向一个已经存在的对象。引用不能指向空值。
③从编译上看,程序在编译时分别将指针和引用添加到符号表上,符号表上记录的是变量名及变量所对应地址。指针变量在符号表上对应的地址值为指针变量的地址值,而引用在符号表上对应的地址值为引用对象的地址值。符号表生成后就不会再改,因此指针可以改变指向的对象(指针变量中的值可以改),而引用对象不能改。这是使用指针不安全而使用引用安全的主要原因。从某种意义上来说引用可以被认为是不能改变的指针。
④不存在指向空值的引用这个事实意味着使用引用的代码效率比使用指针的要高。因为在使用引用之前不需要测试它的合法性。相反,指针则应该总是被测试,防止其为空。
⑤理论上,对于指针的级数没有限制,但是引用只能是一级。
如下:
int** p1; // 合法。指向指针的指针
int*& p2; // 合法。指向指针的引用
int&* p3; // 非法。指向引用的指针是非法的
int&& p4; // 非法。指向引用的引用是非法的
注意上述读法是从左到右。
程序1:
#include "stdio.h"
int main(void)
{
// 声明一个char型指针pc,且让它指向空值
char* pc = 0;
char a = 'a';
// 声明一个引用rc,且让它引用变量a
char& rc = a;
printf("%d, %cn", pc, rc);
char *pc2;
// 声明一个指针,但可以不初始化
pc2 = pc;
// char& rc2;
// 上面语句编译时,会产生如下错误:
// error C2530: 'rc2' : references must be initialized
// 即,应用必须初始化
// rc = *pc;
// 上面语句编译不会有问题,但运行时,会报如下错误:
// "0x00401057"指令引用的"0x00000000"内存。该内存不能为"read"
// 说明引用在任何情况下,都不能指向空值
return 0;
}
程序2:
#include
#include
using namespace std;
int main(void)
{
string s1("Hello");
string s2("World");
// printf("%sn", s1); 不能用printf输出s1,而应该用cout
cout