博客
关于我
C++ 基础【05】
阅读量:268 次
发布时间:2019-03-01

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

内存管理

内存是计算机系统中最重要的资源之一,而在C++程序中,内存管理尤为关键。程序运行时,内存被分为几个区,主要有栈区和堆区。

栈区(Stack)主要用于存储局部变量和函数调用的上下文信息。这些变量在函数执行时会被自动分配到栈区,执行完成后会被释放。例如,以下函数中的变量都会存放在栈区:

int a = 999;  // 栈区中的局部变量int* p = &a;  // p是指向栈区内存的指针

堆区(Heap)则用于动态内存分配,开发者可以通过newdelete操作符来管理。new操作符分配内存到堆区,而delete操作符释放该内存。例如:

int* p = new int(666);  // 内存分配到堆区

需要注意的是,堆区内存如果没有用delete释放,会导致内存泄漏,影响程序性能。

引用

引用(Reference)是C++中的一个强大工具,允许程序在不移动数据的情况下操作数据。引用本质上是指针常量,提供了与常量一样的访问特性,但比常量更灵活。

引用主要用于以下场景:

引用传递

引用允许函数传递较大的数据时避免移动数据。例如:

void fun01(int& a, int& b) {    int temp = a;    a = b;    b = temp;}

引用作为返回值

引用也可以作为函数返回值,允许函数返回非常量的数据。例如:

int& fun02() {    int a = 0;    return a;}

静态引用

静态引用(static reference)允许引用操作在函数退出后仍然保留内存。例如:

int& fun03() {    static int a = 666;    return a;}

需要注意的是,静态引用会导致内存一直保留,直到程序退出。

函数

函数是编程的基本单元,用于将任务分解为独立的逻辑模块。C++支持函数的默认参数和函数重载,使得代码更加灵活。

默认参数

默认参数允许函数在缺少必要参数时自动使用默认值。例如:

void fun01(int a, int b = 20, int c = 30) {    cout << a + b + c << endl;}

默认参数必须在右边的参数中使用。

函数重载

函数重载允许在同一个作用域中定义多个名称相同但参数不同的函数。例如:

void fun02() {    cout << "调用了这个重载的函数" << endl;}int fun02(int a, int b, int c) {    cout << a + b + c << endl;}

总结

内存管理、引用传递以及函数的定义与实现是C++开发中核心技能。通过合理使用内存和引用,可以提高程序的性能和可维护性。函数的默认参数和重载则为代码提供了更大的灵活性。

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

你可能感兴趣的文章
Palo Alto Networks Expedition 远程命令执行漏洞(CVE-2024-9463)
查看>>
Palo Alto Networks PAN-OS身份认证绕过导致RCE漏洞复现(CVE-2024-0012)
查看>>
Panalog 日志审计系统 libres_syn_delete.php 前台RCE漏洞复现
查看>>
Springboot中@SuppressWarnings注解详细解析
查看>>
Panalog 日志审计系统 sprog_deletevent.php SQL 注入漏洞复现
查看>>
Panalog 日志审计系统 sprog_upstatus.php SQL 注入漏洞复现(XVE-2024-5232)
查看>>
Panalog 日志审计系统 前台RCE漏洞复现
查看>>
PANDA VALUE_COUNTS包含GROUP BY之前的所有值
查看>>
pandas - 如何将所有列从对象转换为浮点类型
查看>>
Pandas - 按列分组并将数据转换为 numpy 数组
查看>>
Pandas - 有条件的删除重复项
查看>>
pandas -按连续日期时间段分组
查看>>
pandas -更改重新采样的时间序列的开始和结束日期
查看>>
SpringBoot+Vue+Redis前后端分离家具商城平台系统(源码+论文初稿直接运行《精品毕设》)15主要设计:用户登录、注册、商城分类、商品浏览、查看、购物车、订单、支付、以及后台的管理
查看>>
pandas :to_excel() float_format
查看>>
pandas :加入有条件的数据框
查看>>
pandas :将多列汇总为一列,没有最后一列
查看>>
pandas :将时间戳转换为 datetime.date
查看>>
pandas :将行取消堆叠到新列中
查看>>
pandas :设置编号.最大行数
查看>>