C++技术面_部分零散知识点复习(笔记)

本文介绍了C++中的指针和引用的区别,包括它们的初始化和使用特性。讨论了析构函数的执行时机以及如何防止内存泄漏。同时,对比了new/delete与malloc/free在内存管理上的异同。此外,还强调了静态成员变量在类实例间共享的特性及其应用。
摘要由CSDN通过智能技术生成


前言

笔试 ; 技术面 ; C++ ; 数据结构与算法 ; 操作系统 ; 计算机网络


一、指针、引用的区别

引用和指针并没有本质区别,引用的做了一层封装的指针,引用的底层就是指针

1.指针是本身存储的对象的地址,而引用只是引用对象的别名

2.指针在初始化可为空,指针指向的对象可以改变;
引用不能为空,必须和引用对象绑定,之后不能改变

# include<iosteam>

using namespace std;

int main()
{
	int x = 10;
	int *i = &x;//指针i指向x
	int &j = x; //j引用x
     

	return 0;
}

1.



二、析构函数

1.类的析构函数在什么时候执行

  1. 对象被销毁时
  2. 对象数组被销毁时
  3. 异常抛出时

2.

Class ClsM{
public:
	int*  iv; // 先执行变量的定义
Public:
	ClsM();
    ClsM(int v_i) // 再执行构造函数
    {
    	iv=new int( v_i ); 
    }
};

  1. 假设定义该类对象ClsM m,请你对其成员iv初始化
ClsM m(6); // 传入参数 6,创建一个值为 6 的 int 类型对象,并将其地址赋值给 iv
  1. 当完成A初始化后,请你帮ClsM类补充一个析构函数
    //在析构函数中,需要手动释放成员变量 iv 所指向的动态内存,避免内存泄漏问题。
~ClsM()
{
    delete iv; // 释放内存
}

3.New/delete 与malloc/free 的联系与区别

联系:

  1. 都用于在程序运行期间动态分配和释放内存。
  2. 都返回一个指向动态分配的内存的指针,可以将该指针赋值给指针变量或引用变量
    区别:
  3. new/delete 在内存不足时会抛出异常 std::bad_alloc,而 malloc/free 在内存不足时只能返回 NULL 指针。
  4. new/delete 的使用更为方便,不需要指定所需内存的字节数,而是直接指定所需的对象类型,而 malloc/free 需要手动计算所需的字节数,并需要将指针类型转换为所需的对象类型。

三、成员变量

1.哪一种成员变量可以在同一个类的多个实例之间共享?

  • 静态成员变量。静态成员变量是属于类的,而不是属于类的每个实例。因此,所有该类的实例都可以访问相同的静态成员变量。静态成员变量的内存空间在程序启动时分配,并且在程序结束时释放。使用静态成员变量可以方便地实现数据共享,例如统计某个类的实例数量、保存一些全局信息等。但需要注意的是,静态成员变量的生命周期与程序的生命周期相同,因此需要谨慎使用,以避免不必要的内存开销。

总结

23/05/05 -

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值