P10 C++类和结构体的区别

2023-11-25 15:30
文章标签 c++ 区别 结构 p10

本文主要是介绍P10 C++类和结构体的区别,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

 01 前言

02 struct 与 class格式上的区别

03 struct 与 class 使用上的区别

04 常用的代码风格


 01 前言

今天这期我们主要解决一个问题,就是 C++ 中的类和结构体有什么区别。

本期我们有两个术语,结构体 struct,它是 structure 的缩写,以及类 class。它们的用法看起来有点相似,很多人都会困惑他们之间的区别。你是应该使用 struct,还是应该使用一个 class,本期内容我们将搞清楚这些。

02 struct 与 class格式上的区别

看下图代码,一个类的成员默认为私有的(private)。这意味着如果我要做这样的事情,如果不加 public 的话,这里会得到一个错误。

编译器告诉我们 Player 类中的 platerX是不可访问的,因为它被标记为私有的(private)。如果我们想执行这段代码,我们必须在开始的位置必须写上 public。

#include <iostream>class Player
{
public:int playerX, playerY;
};int main()
{Player player;player.playerX = 10;return 0;
}

这就是区别的本质所在,默认情况下类是私有的,如果你不指定修改任何可见性,那默认值就是私有的私有的(private)。而在结构体中默认值却是公有的 (public) ,技术上讲这是类与结构的唯一区别。

如果把 class 改成 struct ,你可以试着运行上面的代码,一切就都好了

 如果我真的想让某些东西是私有的,在他们之前加上private这个关键字就可以了。

#include <iostream>struct Player
{int playerX, playerY;
};int main()
{Player player;player.playerX = 10;return 0;
}

这个就是两者的区别。非常简单,这就是他们的全部。

03 struct 与 class 使用上的区别

虽然从技术上讲他们可能没有太大区别,然而实际使用情况会有一些不同。

struct 结构体在 C++ 中继续存在的唯一原因,是因为它希望与 C 保持向后兼容性,因为C代码没有类,但是有结构体,如果我们去掉这个结构体关键字,就会失去兼容性,那样的话 C 的编译器就不知道什么是 struct。

当然它也可以很容易地解决这个问题,只需要用 #define 来查找,我们可以写一些类似于 #define 的东西来实现。

#include <iostream>
#define struct classstruct Player
{
public:int playerX, playerY;
};int main()
{Player player;player.playerX = 10;return 0;
}

这样能得到 C 与 C++ 的某种兼容性,在理想情况下,这样应该能将代码中的 struct 替换成 class,也就只能是这样了,在实际情况中不会有更多的区别了。

所以语义上的不同以及人们如何看待它,或多或少取决于用法,如果没有区别,那什么时候使用 struct 或者 class,如果我想要所有的成员都是公共的而不想写 public 这个字,那我应该使用结构体吗?真的就是些这么微不足道的区别吗?的确如此,它真的就是那么微不足道。

正因为如此,人们都有自己对于 struct 以及 class 的理解和定义。这并没有什么正确或错误的答案,这个取决于你的编程风格。

04 常用的代码风格

从根本上说这个类,不管是用 class 还是 struct,都是代表这两个整形数的一种结构。这个就是它的核心。他不应该像之前的 Player 类一样的,包含大量功能,——这个 Player 类可能有一个 3D 模型,它可能会为这个 3D 模型处理渲染代码,它可能处理比如 Player 如何在地图上移动并接收键盘输入,所有这些,可能有很多功能。

如果我只是想用结构体表示一些数据,我将使用一个结构体,

#include <iostream>struct Player
{int playerX, playerY;
};int main()
{Player player;player.playerX = 10;return 0;
}

如果我想要一个大量功能的整个类,比如一个游戏世界或者一个 Player,或者其他可能也有需要继承的东西,所有这些系统,我将使用一个类。这也是我个人区分这两种类型的方法。

#include <iostream>class Player_Class 
{
private:int playerX, playerY;
public:void setPlayerX(int x) { playerX = x; }void setPlayerY(int y) { playerY = y; }
};int main()
{Player_Class player_class;player_class.setPlayerX(20);return 0;
}

再说一次,你可以在任何可以使用类的地方使用结构体,它们将以相同的方式工作。如果在C++中我更喜欢用类,因为C++的代码风格更适合面向对象,在写代码分析代码更清晰明了

这篇关于P10 C++类和结构体的区别的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/424052

相关文章

C++右移运算符的一个小坑及解决

《C++右移运算符的一个小坑及解决》文章指出右移运算符处理负数时左侧补1导致死循环,与除法行为不同,强调需注意补码机制以正确统计二进制1的个数... 目录我遇到了这么一个www.chinasem.cn函数由此可以看到也很好理解总结我遇到了这么一个函数template<typename T>unsigned

Vue和React受控组件的区别小结

《Vue和React受控组件的区别小结》本文主要介绍了Vue和React受控组件的区别小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录背景React 的实现vue3 的实现写法一:直接修改事件参数写法二:通过ref引用 DOMVu

C++统计函数执行时间的最佳实践

《C++统计函数执行时间的最佳实践》在软件开发过程中,性能分析是优化程序的重要环节,了解函数的执行时间分布对于识别性能瓶颈至关重要,本文将分享一个C++函数执行时间统计工具,希望对大家有所帮助... 目录前言工具特性核心设计1. 数据结构设计2. 单例模式管理器3. RAII自动计时使用方法基本用法高级用法

Vite 打包目录结构自定义配置小结

《Vite打包目录结构自定义配置小结》在Vite工程开发中,默认打包后的dist目录资源常集中在asset目录下,不利于资源管理,本文基于Rollup配置原理,本文就来介绍一下通过Vite配置自定义... 目录一、实现原理二、具体配置步骤1. 基础配置文件2. 配置说明(1)js 资源分离(2)非 JS 资

深入解析C++ 中std::map内存管理

《深入解析C++中std::map内存管理》文章详解C++std::map内存管理,指出clear()仅删除元素可能不释放底层内存,建议用swap()与空map交换以彻底释放,针对指针类型需手动de... 目录1️、基本清空std::map2️、使用 swap 彻底释放内存3️、map 中存储指针类型的对象

Go之errors.New和fmt.Errorf 的区别小结

《Go之errors.New和fmt.Errorf的区别小结》本文主要介绍了Go之errors.New和fmt.Errorf的区别,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考... 目录error的基本用法1. 获取错误信息2. 在条件判断中使用基本区别1.函数签名2.使用场景详细对

Redis中哨兵机制和集群的区别及说明

《Redis中哨兵机制和集群的区别及说明》Redis哨兵通过主从复制实现高可用,适用于中小规模数据;集群采用分布式分片,支持动态扩展,适合大规模数据,哨兵管理简单但扩展性弱,集群性能更强但架构复杂,根... 目录一、架构设计与节点角色1. 哨兵机制(Sentinel)2. 集群(Cluster)二、数据分片

C++ STL-string类底层实现过程

《C++STL-string类底层实现过程》本文实现了一个简易的string类,涵盖动态数组存储、深拷贝机制、迭代器支持、容量调整、字符串修改、运算符重载等功能,模拟标准string核心特性,重点强... 目录实现框架一、默认成员函数1.默认构造函数2.构造函数3.拷贝构造函数(重点)4.赋值运算符重载函数

C++ vector越界问题的完整解决方案

《C++vector越界问题的完整解决方案》在C++开发中,std::vector作为最常用的动态数组容器,其便捷性与性能优势使其成为处理可变长度数据的首选,然而,数组越界访问始终是威胁程序稳定性的... 目录引言一、vector越界的底层原理与危害1.1 越界访问的本质原因1.2 越界访问的实际危害二、基

Java集合中的链表与结构详解

《Java集合中的链表与结构详解》链表是一种物理存储结构上非连续的存储结构,数据元素的逻辑顺序的通过链表中的引用链接次序实现,文章对比ArrayList与LinkedList的结构差异,详细讲解了链表... 目录一、链表概念与结构二、当向单链表的实现2.1 准备工作2.2 初始化链表2.3 打印数据、链表长