百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

「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.普通成员函数可访问静态成员变量、也可以访问普通成员变量。

理解:静态成员变量只有一份存储空间,普通成员函数可以直接识别,不会混淆。

以上就是类中的静态成员变量以及静态成员函数的理解,原创不易,多多鼓励!!!


关注公号【开发小鸽】,获取开发与深度学习资源,实战项目源码,最新论文下载,大厂面试经验!!!?

相关推荐

使用 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)则是一种广泛应用于视频流媒...

取消回复欢迎 发表评论: