博客
关于我
C++指针
阅读量:270 次
发布时间:2019-03-01

本文共 736 字,大约阅读时间需要 2 分钟。

指针与引用的基础知识

在编程领域,指针和引用常常被混淆,但它们在内存管理和变量访问中扮演着不同的角色。以下是关于指针的详细解释。

1. 指针与引用不同

指针本身就是一个对象,它可以通过操作符*访问指向的目标对象。然而,引用不是一个对象,因为它不具备实际的内存地址。因此,引用无法直接作为指针使用。

2. 引用的特殊性

由于引用不具备实际地址,它不能像指针那样直接指向内存中的数据。这意味着即使你定义了一个引用,它也不会自动获取对应对象的内存地址。

3. 指针的内存管理

指针需要谨慎使用,因为编译器不会自动处理指针相关的内存问题。未经初始化的指针或错误访问的指针可能导致程序运行错误。

4. 指针的类型匹配

指针类型必须与它所指向的对象类型一致。例如,不能将一个用于整数的指针用于字符串操作。

5. 编译器的责任

编译器不会检查指针操作是否安全。无效指针可能导致不可预知的后果,包括程序崩溃或数据丢失。

6. 空指针的定义

空指针(null pointer)表示指针不指向任何有效对象。请注意区分空指针和无类型的指针(void*),后者可以存储任何对象的内存地址。

7. 指针的初始化

在C++中,你可以使用多种方式初始化指针:

  • int *p1 = nullptr;(C++11及以上版本)
  • int *p2 = 0;
  • int *p3 = NULL;(需要包含<cstdlib>

8. 赋值规则

将整数直接赋值给指针是错误的操作,即使数值为0也不例外。正确的做法是使用nullptr来表示空指针。

9. void指针的作用

void*指针可以用来存储任意类型的内存地址,使其具有高度的灵活性。

通过以上知识,你可以更好地理解指针的行为和潜在风险,从而避免在编程中出现问题。

转载地址:http://vuix.baihongyu.com/

你可能感兴趣的文章
oracle中sql查询上月、本月、上周、本周、昨天、今天的数据!
查看>>
oracle中sql的case语句运用--根据不同条件去排序!
查看>>
Oracle中Transate函数的使用
查看>>
oracle中关于日期问题的汇总!
查看>>
Oracle中常用的语句
查看>>
Oracle中序列的操作以及使用前对序列的初始化
查看>>
oracle中新建用户和赋予权限
查看>>
Oracle中的NVL,NVL2,NULLIF以及COALESCE函数使用
查看>>
Oracle中的rownum 和rowid的用法和区别
查看>>
oracle中的大小写、字符、dual、数字、处理、日期、函数、显/隐式、时间、条件表达式case、decode、to_date、to_char、sysdate
查看>>
oracle中表和视图的区别,oracle中常用表和视图
查看>>
oracle之表空间(tablespace)、方案(schema)、段(segment)、区(extent)、块(block)
查看>>
Oracle从11g导出后导入10g
查看>>
oracle从备份归档日志的方法集中回收
查看>>
oracle优化器analyzed,Oracle 学习之 性能优化(十三) 索引
查看>>
Oracle修改字段类型
查看>>
Oracle修改表或者字段的注释
查看>>
oracle典型安装失败,安装oracle 10失败
查看>>
Oracle内存结构详解(四)--Oracle SGA其他组成部分
查看>>
Oracle函数与存储过程和程序包
查看>>