C++ 解引用与函数基础:内存地址、调用方法及声明

简介: C++ 中的解引用允许通过指针访问变量值。使用 `*` 运算符可解引用指针并修改原始变量。注意确保指针有效且不为空,以防止程序崩溃。函数是封装代码的单元,用于执行特定任务。理解函数的声明、定义、参数和返回值是关键。函数重载允许同一名称但不同参数列表的函数存在。关注公众号 `Let us Coding` 获取更多内容。

C++ 解引用

获取内存地址和值

在上一页的示例中,我们使用了指针变量来获取变量的内存地址(与引用运算符 & 一起使用)。但是,你也可以使用指针来获取变量的值,这可以通过使用 * 运算符(解引用运算符)来实现:

string food = "Pizza"; // 变量声明
string* ptr = &food; // 指针声明

// 引用:使用指针输出 food 的内存地址(0x6dfed4)
cout << ptr << "\n";

// 解引用:使用指针输出 food 的值(Pizza)
cout << *ptr << "\n";

需要注意的是,符号 * 在这里可能会让人感到困惑,因为它在我们的代码中有两种不同的作用:

  • 在声明中使用时(string* ptr),它创建一个指针变量。
  • 在非声明中使用时,它作为解引用运算符。

修改指针值

你可以改变指针的值。但要注意,这也会改变原始变量的值:

string food = "Pizza";
string* ptr = &food;

// 输出 food 的值(Pizza)
cout << food << "\n";

// 输出 food 的内存地址(0x6dfed4)
cout << &food << "\n";

// 访问 food 的内存地址并输出其值(Pizza)
cout << *ptr << "\n";

// 改变指针的值
*ptr = "Hamburger";

// 输出指针的新值(Hamburger)
cout << *ptr << "\n";

// 输出 food 变量的新值(Hamburger)
cout << food << "\n";

解引用指针的注意事项

  • 解引用指针时,要确保指针指向有效的内存地址,否则会导致程序崩溃。
  • 不要解引用空指针,这会导致程序崩溃。
  • 修改指针的值可能会导致意外的结果,应谨慎操作。

总结

解引用是 C++ 中一个重要的概念,它允许你获取指针指向的变量的值或内存地址。在使用解引用运算符时,要遵循一些注意事项,以避免程序崩溃或意外结果。

C++ 函数

函数概述

函数是一组用于执行特定任务的封装代码块。它们可以提高代码的可重用性、可读性和可维护性。

创建函数

在 C++ 中,创建函数需要遵循以下语法:

returnType functionName(parameterList) {
  // 函数体
}

其中:

  • returnType:函数的返回值类型,可以是 void(无返回值)或其他数据类型。
  • functionName:函数名称,由字母、数字和下划线组成,但不能以数字开头。
  • parameterList:函数参数列表,参数之间用逗号分隔,每个参数由数据类型和参数名组成。
  • 函数体:函数要执行的代码,由花括号括起来。

例如,以下代码创建了一个名为 printMessage 的函数,该函数接收一个字符串参数并将其打印到控制台:

void printMessage(string message) {
  cout << message << endl;
}

函数调用

要调用函数,只需在代码中写下函数名及其参数值,例如:

printMessage("Hello, world!");

函数参数

函数参数可以是输入参数、输出参数或输入输出参数。

  • 输入参数:函数从调用者接收数据。
  • 输出参数:函数将数据返回给调用者。
  • 输入输出参数:函数既可以接收数据又可以返回数据。

在 C++ 中,函数参数默认是输入参数。要声明输出参数或输入输出参数,需要使用引用或指针。

函数返回值

函数可以返回一个值给调用者。返回值类型写在函数声明的括号前面,例如:

int square(int number) {
  return number * number;
}

该函数接收一个整数参数 number,并返回其平方值。要调用该函数并获取返回值,可以使用以下代码:

int result = square(5);
cout << result << endl; // 输出 25

函数声明和定义

函数声明告诉编译器函数的名称、返回值类型和参数列表,而函数定义提供了函数要执行的代码。

函数声明通常放在程序的开头,而函数定义放在后面。例如:

// 函数声明
void printMessage(string message);
int square(int number);

// ...

// 函数定义
void printMessage(string message) {
  cout << message << endl;
}

int square(int number) {
  return number * number;
}

函数重载

函数重载是指允许使用相同名称但不同参数列表的多个函数。例如:

void printMessage(string message) {
  cout << message << endl;
}

void printMessage(int number) {
  cout << number << endl;
}

在调用这些函数时,需要根据实际参数类型选择正确的函数。

函数的作用域

函数的作用域是指函数内的变量和函数名在程序中可见的范围。函数内的变量和函数名只在该函数内可见,在其他函数中不可见。

总结

函数是 C++ 中重要的编程概念,它们可以提高代码的可重用性、可读性和可维护性。通过理解函数的声明、定义、调用和参数传递等概念,您可以编写更简洁、更有效的 C++ 程序。

最后

为了方便其他设备和平台的小伙伴观看往期文章:

微信公众号搜索:Let us Coding,关注后即可获取最新文章推送

看完如果觉得有帮助,欢迎点赞、收藏、关注

相关文章
|
4月前
|
弹性计算 定位技术 数据中心
阿里云服务器配置选择方法:付费类型、地域及CPU内存配置全解析
阿里云服务器怎么选?2025最新指南:就近选择地域,降低延迟;长期使用选包年包月,短期灵活选按量付费;企业选2核4G5M仅199元/年,个人选2核2G3M低至99元/年,高性价比爆款推荐,轻松上云。
384 11
|
7月前
|
安全 C语言 C++
比较C++的内存分配与管理方式new/delete与C语言中的malloc/realloc/calloc/free。
在实用性方面,C++的内存管理方式提供了面向对象的特性,它是处理构造和析构、需要类型安全和异常处理的首选方案。而C语言的内存管理函数适用于简单的内存分配,例如分配原始内存块或复杂性较低的数据结构,没有构造和析构的要求。当从C迁移到C++,或在C++中使用C代码时,了解两种内存管理方式的差异非常重要。
251 26
|
8月前
|
C语言 C++
c与c++的内存管理
再比如还有这样的分组: 这种分组是最正确的给出内存四个分区名字:栈区、堆区、全局区(俗话也叫静态变量区)、代码区(也叫代码段)(代码段又分很多种,比如常量区)当然也会看到别的定义如:两者都正确,记那个都选,我选择的是第一个。再比如还有这样的分组: 这种分组是最正确的答案分别是 C C C A A A A A D A B。
157 1
|
8月前
|
存储 Windows
内存卡坏了还能修吗?4种常见修复方法
内存卡出现“无法保存”或“存储异常”等问题时,不一定是硬件损坏,可能是系统错误或文件系统异常导致。本文介绍几种亲测有效的修复方法:1) 更换读卡设备排除接触问题;2) 格式化修复文件系统(需先备份数据);3) 使用DiskGenius检测坏道;4) 借助厂商工具深度修复。同时提供日常保养建议,如避免高温环境、养成数据备份习惯,延长内存卡使用寿命。通过这些方法,多数问题可轻松解决,无需更换硬件。
|
8月前
|
人工智能 机器人 编译器
c++模板初阶----函数模板与类模板
class 类模板名private://类内成员声明class Apublic:A(T val):a(val){}private:T a;return 0;运行结果:注意:类模板中的成员函数若是放在类外定义时,需要加模板参数列表。return 0;
219 0
|
11月前
|
存储 Linux C语言
C++/C的内存管理
本文主要讲解C++/C中的程序区域划分与内存管理方式。首先介绍程序区域,包括栈(存储局部变量等,向下增长)、堆(动态内存分配,向上分配)、数据段(存储静态和全局变量)及代码段(存放可执行代码)。接着探讨C++内存管理,new/delete操作符相比C语言的malloc/free更强大,支持对象构造与析构。还深入解析了new/delete的实现原理、定位new表达式以及二者与malloc/free的区别。最后附上一句鸡汤激励大家行动缓解焦虑。
|
11月前
|
安全 C++
【c++】继承(继承的定义格式、赋值兼容转换、多继承、派生类默认成员函数规则、继承与友元、继承与静态成员)
本文深入探讨了C++中的继承机制,作为面向对象编程(OOP)的核心特性之一。继承通过允许派生类扩展基类的属性和方法,极大促进了代码复用,增强了代码的可维护性和可扩展性。文章详细介绍了继承的基本概念、定义格式、继承方式(public、protected、private)、赋值兼容转换、作用域问题、默认成员函数规则、继承与友元、静态成员、多继承及菱形继承问题,并对比了继承与组合的优缺点。最后总结指出,虽然继承提高了代码灵活性和复用率,但也带来了耦合度高的问题,建议在“has-a”和“is-a”关系同时存在时优先使用组合。
647 6
|
7月前
|
存储
阿里云轻量应用服务器收费标准价格表:200Mbps带宽、CPU内存及存储配置详解
阿里云香港轻量应用服务器,200Mbps带宽,免备案,支持多IP及国际线路,月租25元起,年付享8.5折优惠,适用于网站、应用等多种场景。
2371 0
|
7月前
|
存储 缓存 NoSQL
内存管理基础:数据结构的存储方式
数据结构在内存中的存储方式主要包括连续存储、链式存储、索引存储和散列存储。连续存储如数组,数据元素按顺序连续存放,访问速度快但扩展性差;链式存储如链表,通过指针连接分散的节点,便于插入删除但访问效率低;索引存储通过索引表提高查找效率,常用于数据库系统;散列存储如哈希表,通过哈希函数实现快速存取,但需处理冲突。不同场景下应根据访问模式、数据规模和操作频率选择合适的存储结构,甚至结合多种方式以达到最优性能。掌握这些存储机制是构建高效程序和理解高级数据结构的基础。
783 1