「C++学习笔记(十)」理解类中的静态成员变量与静态成员函数
yuyutoo 2025-01-05 00:09 1 浏览 0 评论
一. 类的静态成员
大家应该都知道静态变量,就是在变量前面加上static,类的静态成员也是同样的道理,在类的成员函数与成员变量前面加上static声明为类的静态成员。和静态变量的原理一样,不管这个类创建了多少个对象,静态成员只有一个拷贝,这个拷贝是被所有这个类的对象共享的。
二. 类的静态成员变量
(一)定义
类的静态变量即是在类中,用关键字static声明成员变量。无论建立了多少个对象,都只有一个静态变量的拷贝。静态成员变量,不属于某一个类对象,而只是属于这个类,对于所有类对象时共享的。
(二)重点记忆
1. 类的静态变量的分配空间
类的静态变量,在编译阶段就已经分配了空间,即还没有创建类对象时,就已经分配空间。 理解:同static变量一样,类的静态变量也是在编译阶段就分配好了空间。
2. 在为类对象分配空间中不包括静态成员所占空间。
理解:因为静态变量并不属于某个类对象,它是共享的,因此独立的类对象分配空间是不包括静态成员的空间的。
3. 类的静态变量可以通过类对象来访问,也可以通过类名直接访问。
理解:
(1)通过类对象访问是正常访问。
如下面代码所示:(我直接写类和调用了)
#include<iostream>
using namespace std;
class Person{
public:
Person(){};
static int a;
}
int Person::a = 0;
int main()
{
Person p1;
p1.a = 100;
Person p2;
p2.a = 200;
cout << "a1 = " << p1.a<<endl;
cout <<"a2 = " << p2.a << endl;
}
输出结果是什么呢? 当然是: a1 = 200; a2 = 200; 因为 a 是类的静态变量,是共享的,所以更改的都是同一个值。
(2)通过类名直接访问
如何通过类名直接访问呢?可以用下面代码所示调用:
Person::a;
因为static变量并不属于任何一个类对象,但是它属于这个类,因此可以直接用类名调用。
4. 静态成员变量必须在类中声明,在类外定义。
静态变量在类中声明static,为什么在类外定义呢?类中能否定义?答案是不行的。来看看代码。
#include<iostream>
using namespace std;
class Person{
public:
Person(int pa)
{
a = pa;
};
static int a;
}
int main()
{
cout <<Person::a << endl; //错误,无法访问到a
}
代码中,我们用 Person::a 的方式直接访问类的静态变量,是不会调用构造函数的,因此类中的 a 是没有定义的。所以最好是在类外定义类的静态变量。
三. 类的静态成员函数
(一). 定义
在类定义中,用static声明的成员函数为静态成员函数。使用方式与静态成员变量一样,都是通过类对象访问和类名直接访问。
(二)意义
类的静态成员函数的意义在于管理静态成员变量,完成对静态成员变量的封装。
(三). 重点记忆
1. 静态成员函数只能访问静态成员变量,不能访问普通成员变量。
理解:static成员函数是是共享的,存储在一块空间中,而普通的成员变量是属于每个类对象的,每个类对象存储在独立的空间中,若在静态成员函数中直接访问普通成员变量,那么它将无法区分普通的成员变量属于哪个类对象。
2.普通成员函数可访问静态成员变量、也可以访问普通成员变量。
理解:静态成员变量只有一份存储空间,普通成员函数可以直接识别,不会混淆。
以上就是类中的静态成员变量以及静态成员函数的理解,原创不易,多多鼓励!!!
关注公号【开发小鸽】,获取开发与深度学习资源,实战项目源码,最新论文下载,大厂面试经验!!!?
- 上一篇:CPU眼里的:变量
- 下一篇:C语言的随机数函数和静态变量
相关推荐
- 使用 Node.js、Canvas 和 FFmpeg 实时生成并推送视频流
-
1、背景和需求在许多实时视频应用场景中,我们需要动态生成实时视频流并将其推送到RTMP服务器。例如,我们可能需要生成一个实时显示当前时间的视频流,或者在游戏直播时显示实时弹幕等。本文将介绍如何使...
- 熊孩子高空泼墨,全楼都遭殃!父母的反应让全网点赞
-
自家熊孩子从楼上泼墨邻居晾的衣服、楼的外墙…无一幸免!事发后孩子父母的反应让全网点赞!5月21日,江苏宿迁。网友“宇兄宇弟”发了几条短视频,只见视频中阳台上晾晒的衣服全都被泼上了墨汁,楼下地上和楼外墙...
- 动态爬虫(ajax)-爬取bilibili热门视频信息
-
前言使用python爬虫爬取bilibli每日热门视频的数据使用的第三方软件包括requests、my_fake_useragent...
- 轻视频课程:AngularJS开发框架实用编程入门之一
-
这个基础课程将介绍知名的Google前端开发框架AngularJS的基础使用,包括:基本概述,数据绑定,指令,表达式,控制器,过滤器等基础内容课程内容:AngularJS核心功能数据绑定:自动同步视图...
- html5的video标签实现对m3u8格式视频(HLS)的支持 亲测可用
-
在切图网一个项目切图中遇到的,网页中嵌入视频理所当然用html5自带的video标签即可实现,也有比较主流的插件videojs,但是这个比较特别播放的视频是m3u8格式的(这种好像imacsaf...
- html5的video标签实现m3u8格式的支持,基于hls.min.js
-
切图网站的踩坑笔记,vue开发项目中通过api接口获取到了m3u8格式的音频,但是有的浏览器默认不支持,所以需要借助辅助手段来实现,下面介绍详细方法。什么是m3u8?m3u8是m3u的一种,是utf-...
- 基于 vue.js+xgplayer 开源音视频播放器组件
-
今天继续给小伙伴们分享一个西瓜视频播放器Vue组件XGPlayer-Vue。xgplayer-vue西瓜视频播放器xgplayer的vue.js版本组件。安装...
- 盘点戏精萌娃的搞笑日常,好看吗?
-
孩子们搞笑的日常。盘点戏精萌娃的搞笑日常。好看吗?你这不是难为我吗?这咋难为你了,你别怪我说话直,那你也别怪我下手重。我这一身傲骨还能不怕你威胁吗?就让你看这衣服好不好看,怎么这么费劲?衣服。...
- WEB页面页面播放实时视频流
-
业务述求需要在WEB端实时查看现场的视频监控(公司选型的是大华摄像机)1技术方案选型1.ffmpeg通过rtsp协议拉取视频流2.使用vlcmediaplayer组件拉取视频流,在...
- 科研笔记神器:??一边视频,一边笔记,轻松搞定B站视频学习
-
上一期,笔者介绍了一款笔记神器——Obsidian,它可以用于思维导图和知识管理。...
- 在网页上显示监控视频
-
最近需要在web项目中显示监控视频,采用了webrtc+webrtc-streamer+coturn的方案实现,能够在公网上做很低的延时,对于实时监控视频有很好的效果,是目前来讲比较好的一个选择方案...
- Node.js服务端使用ffmpeg压缩视频处理技巧
-
在Node.js中,我们可以使用fluent-ffmpeg进行视频的合并、拼接、修改、转码、压缩等操作。网上的资料有很多,但是大部分是英文的,对于普通开发者来说,要轻松地了解使用方法还是很有难度的。...
- 杜淳晒女儿跑步萌态,1岁小蛋饺步伐超稳,全身肉嘟嘟可爱爆棚
-
4月27日下午,杜淳在个人社交平台分享了一段女儿小蛋饺跑步的萌态,老父亲还感慨写道:“奔跑吧,我的小蛋饺,跑着跑着就长大了,我的小公主”。杜淳自从升级奶爸后,这“女儿奴”属性真是愈发明显了,每一次晒与...
- 8款测试HLS m3u8视频流的免费在线播放器
-
翻译:Alex技术审校:纪永康本文来自OTTVerse,作者为KrishnaRaoVijayanagar。...
- HLS视频拉流播放
-
1、安装HlsVue.js是一个适用于构建用户界面的渐进型框架,它的流行程度已经在现代Web应用开发领域中得到了广泛的认可。而HLS(HTTPLiveStreaming)则是一种广泛应用于视频流媒...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- mybatis plus (70)
- scheduledtask (71)
- css滚动条 (60)
- java学生成绩管理系统 (59)
- 结构体数组 (69)
- databasemetadata (64)
- javastatic (68)
- jsp实用教程 (53)
- fontawesome (57)
- widget开发 (57)
- vb net教程 (62)
- hibernate 教程 (63)
- case语句 (57)
- svn连接 (74)
- directoryindex (69)
- session timeout (58)
- textbox换行 (67)
- extension_dir (64)
- linearlayout (58)
- vba高级教程 (75)
- iframe用法 (58)
- sqlparameter (59)
- trim函数 (59)
- flex布局 (63)
- contextloaderlistener (56)