C++中的 static
c语言中static的用法,包括全局变量和局部变量用static修饰

c语⾔中static的⽤法,包括全局变量和局部变量⽤static修饰⼀、c程序存储空间布局 C程序⼀直由下列部分组成: 1)正⽂段——CPU执⾏的机器指令部分;⼀个程序只有⼀个副本;只读,防⽌程序由于意外事故⽽修改⾃⾝指令; 2)初始化数据段(数据段)——在程序中所有赋了初值的全局变量,存放在这⾥。
3)⾮初始化数据段(bss段)——在程序中没有初始化的全局变量;内核将此段初始化为0。
4)栈——增长⽅向:⾃顶向下增长;⾃动变量以及每次函数调⽤时所需要保存的信息(返回地址;环境信息)。
5)堆——动态存储分。
是向⾼地址扩展的数据类型,是⾃下向上的扩展⽅式。
⼆、⾯向过程程序设计中的static 1. 全局静态变量 在全局变量之前加上关键字static,全局变量就被定义成为⼀个全局静态变量。
1)内存中的位置:静态存储区(静态存储区在整个程序运⾏期间都存在) 2)初始化:未经初始化的全局静态变量会被程序⾃动初始化为0(⾃动对象的值是任意的,除⾮他被显⽰初始化) 3)作⽤域:全局静态变量在声明他的⽂件之外是不可见的。
准确地讲从定义之处开始到⽂件结尾。
定义全局静态变量的好处: <1>不会被其他⽂件所访问,修改 <2>其他⽂件中可以使⽤相同名字的变量,不会发⽣**。
2. 局部静态变量 在局部变量之前加上关键字static,局部变量就被定义成为⼀个局部静态变量。
1)内存中的位置:静态存储区 2)初始化:未经初始化的全局静态变量会被程序⾃动初始化为0(⾃动对象的值是任意的,除⾮他被显⽰初始化) 3)作⽤域:作⽤域仍为局部作⽤域,当定义它的函数或者语句块结束的时候,作⽤域随之结束。
注:当static⽤来修饰局部变量的时候,它就改变了局部变量的存储位置,从原来的栈中存放改为静态存储区。
但是局部静态变量在离开作⽤域之后,并没有被销毁,⽽是仍然驻留在内存当中,直到程序结束,只不过我们不能再对他进⾏访问。
C中的auto、static、register和extern的区别

} int A=13,B=-8;
也可以在多文件的程序中声明外部变量。
extern还可声明函数,eg:extern int fun(int a, int b);声明的外部函数可供其他文件调用,在C中,定义函数时省略extern,则隐含为外部函数 另附加一个两个关键字const和volitate
1). 并行设备的硬件寄存器(如:状态寄存器)
2). 一个中断服务子程序中会访问到的非自动变量(Non-automatic variables)
3). 多线程应用中被几个任务共享的变量
回答不出这个问题的人是不会被雇佣的。我认为这是区分C程序员和嵌入式系统程序员的最基本的问题。嵌入式系统程序员经常同硬件、中断、RTOS等等打交道,所用这些都要求volatile变量。不懂得volatile内容将会带来灾难。
假设被面试者正确地回答了这是问题(嗯,怀疑这否会是这样),我将稍微深究一下,看一下这家伙是不是直正懂得volatile完全的重要性。
1). 一个参数既可以是const还可以是volatile吗?解释为什么。
2). 一个指针可以是volatile 吗?解释为什么。
3). 下面的函数有什么错误:
}
由于*ptr的值可能被意想不到地该变,因此a和b可能是不同的。结果,这段代码可能返不是你所期望的平方值!正确的代码如下:
long square(volatile int *ptr)
{
int a;
a = *ptr;
return a * a;
}
auto变量:函数中的局部变量,如不专门声明static,一般都是动态地分配存储空间。自动变量:在调用该函数时系统会给他们分配存储空间,一旦函数调用结束这些存储空间就会自动释放。关键字“auto”可以省略,不写则隐含确定为“自动存储类别”,属于动态存储方式。
c语言中static变量详解

c语⾔中static变量详解Static翻译出来是“静态”“静⽌”的意思,在C语⾔中的意思其实和它的本意差不多,表⽰“静态”或者“全局”的意思,⽤来修饰变量和函数。
经static修饰过后的变量或者函数的作⽤域或者存储域会发⽣变化,⽽由static修饰的变量在初始值⽅⾯也会表现出static关键字的优势。
想知道经static修饰过后的变量或者函数的作⽤域或者存储域发⽣了什么变化吗,发⽣变化的原因是什么吗?请⼤家继续往下看!⼀、c程序的内存分布既然static是⽤来修饰变量和函数的,⽽变量和函数⼜是组成c程序必不可少的,C程序的内存分布图如下。
C程序由下⾯5部分组成: 1)正⽂段——CPU执⾏的机器指令部分;⼀个程序只有⼀个副本;只读,防⽌程序由于意外事故⽽修改⾃⾝指令; 2)初始化数据段(数据段)——在程序中所有赋了初值的全局变量,存放在这⾥。
3)⾮初始化数据段(bss段)——在程序中没有初始化的全局变量;内核将此段初始化为0。
4)栈——增长⽅向:⾃顶向下增长;⾃动变量以及每次函数调⽤时所需要保存的信息(返回地址;环境信息)。
5)堆——动态存储区。
是向⾼地址扩展的数据类型,是⾃下向上的扩展⽅式。
c程序内存分布图上⾯的C程序分布图很明显的告诉我们,变量是存储在栈区或者堆区或者bss段或者data段,变量的存储域为什么会有所不同呢?其实原因很简单,说⽩了就是与他们定义在程序的不同地⽅,有没有static关键字修饰有关啦,定义在不同的地⽅也说明了他们有着不同的作⽤域。
⼆、static修饰的变量1. 全局静态变量 在全局变量之前加上关键字static,全局变量就被定义成为⼀个全局静态变量。
1)内存中的位置:静态存储区(静态存储区在整个程序运⾏期间都存在) 2)初始化:未经初始化的全局静态变量会被程序⾃动初始化为0(⾃动对象的值是任意的,除⾮他被显⽰初始化) 3)作⽤域:全局静态变量在声明他的⽂件之外是不可见的。
c++语言static constexpr const的作用和用法

c++语言static constexpr const的作用和用法在C语言中,static、constexpr和const这三个关键字都具有特殊的含义,它们在编译时期就有特殊的作用。
首先,我们来看一下static关键字。
在C语言中,static关键字具有多种含义,但在这种情况下,我们主要关注其存储分类的意义。
在C语言中,变量可以根据其存储位置分为三种类型:自动存储分类(automatic storage duration)、静态存储分类(static storage duration)和外部存储分类(external storageduration)。
其中,static关键字修饰的变量具有静态存储分类,它们在程序执行期间只分配一次,其值在整个程序执行期间保持不变。
接下来,我们来看一下constexpr关键字。
在C++11及其后续版本中,constexpr是一个关键字,它用于指示一个变量或函数可以在编译时期进行求值。
当constexpr被应用于一个变量或函数时,编译器会尝试在编译时期就计算出结果,而不是等到运行时期。
这对于编译时就能确定结果的情况非常有用,因为它可以大大提高编译的效率。
最后,我们来看一下const关键字。
在C语言中,const关键字用于声明一个变量的只读性。
当一个变量被声明为const时,它的值就不能被改变。
这对于确保程序的稳定性和防止意外的数据更改非常有用。
这三个关键字在C语言中的组合使用可以产生一些有趣的效果。
例如,我们可以使用static const constexpr来创建一个常量。
这样的常量在编译时期就能求值,并且具有静态存储分类,这意味着它们在整个程序执行期间都保持不变。
这样的常量通常用于定义程序的固定值,例如常数和标志。
另外,我们还可以使用constexpr来创建更高效的常量。
例如,如果我们有一个数组的大小是在编译时期就能确定的话,我们就可以使用constexpr来声明这个数组。
c语言static 数组的赋值

C语言中的static关键字和数组是编程中常用的概念,而将它们结合起来进行赋值操作更是程序员经常会遇到的需求。
本文将从静态数组的定义和使用、静态关键字的作用、以及静态数组的赋值方式等方面进行分析和总结,希望能够为读者提供一些有益的知识。
一、静态数组的定义和使用静态数组是C语言中的一种数据类型,它是由相同类型的元素组成的集合。
静态数组在定义时需要指定数组的大小,例如:```cint arr[5];```上述代码定义了一个包含5个整型元素的静态数组。
静态数组的大小在定义时就已经确定,不能够在程序运行过程中进行动态调整。
静态数组的元素通过索引来进行访问,索引从0开始,例如:```cint value = arr[2];```上述代码就是访问arr数组中第3个元素的值,并将其赋给value变量。
二、静态关键字的作用在C语言中,static关键字有两个不同的作用,一个是用于修饰变量,另一个是用于修饰函数。
在这里我们主要讨论static修饰静态数组时的作用。
当static修饰一个全局数组时,它表示该数组在整个程序运行过程中只有一份内存空间,即使在不同的文件中引用该数组,也都指向同一块内存空间。
这意味着该数组的值在多处都是共享的,这在一些特定的场景下可能会带来一些问题。
而static修饰一个局部数组时,则表示该数组在程序执行时只会初始化一次,即使函数多次被调用,该数组的值也会保持不变。
三、静态数组的赋值方式在C语言中,静态数组的赋值有多种方式,下面将分别介绍这些方式及其使用场景。
1. 手动逐个赋值手动逐个赋值是最基本的数组赋值方式,即通过循环遍历数组,并逐个赋值。
例如:```cint arr[5];for (int i = 0; i < 5; i++) {arr[i] = i;}```这种方式的优点是灵活,适用于任何数组元素需要单独计算的场景。
但缺点是效率较低,尤其是对于较大的数组来说,循环遍历的开销较大。
static在c++语言中的用法

static在c++语言中的用法static是C++中的一个关键字,用于定义静态变量和静态函数。
静态变量和普通变量的区别在于,静态变量存储在数据区,生命周期与整个程序运行时间相同,在程序运行时只会被初始化一次。
而普通变量在程序运行时会被重复初始化和销毁,生命周期与函数调用时间相同。
1. 静态变量静态变量可以声明在函数体内和类内部。
当静态变量声明在函数体内时,该变量只在此函数中可见,即使此函数被多次调用,静态变量只会被初始化一次。
当静态变量声明在类内部时,它属于整个类,不需要通过对象来访问,可以直接通过类名+范围解析符(::)来访问。
如:静态变量在类内部的声明可以用于实现单例模式。
如下代码实现了只能创建一个MyClass对象的单例模式:2. 静态函数静态函数的另一个用途是实现工厂模式。
当我们需要创建一些对象并且它们的类型在编译时不能确定时,可以使用工厂模式来创建这些对象。
静态函数可以作为工厂函数,用于创建对象的实例。
如下代码:3. 静态成员变量和静态函数的限制1. 静态成员变量需要在类外部进行初始化。
即使不进行初始化,编译器也会为它自动赋值为0。
2. 静态成员变量的访问权限可以是public、protected或private。
3. 静态成员变量可以在类声明中提供初值,如`static int myStaticVar = 0;`。
4. 静态函数不能声明为const,因为const只能用于成员函数,而静态函数没有对象,无法成为成员函数。
5. 静态函数可以被继承,但不能被override(覆盖),因为静态函数与类名绑定在一起,无法被子类的同名函数所覆盖。
但是,如果子类中声明一个与父类中静态函数同名的静态函数,它并不会覆盖父类中的静态函数,而是在子类中新增一个同名函数。
6. 静态函数不能访问非静态的成员函数和变量。
如果需要访问非静态成员,必须通过对象来调用成员函数。
但是,由于静态函数没有对象,无法调用非静态成员函数。
C语言关键字:auto、static、register、const
C语言关键字:auto、static、register、constC语言关键字:auto、static、register、const程序是由一个一个的语句组成的,下面店铺就为大家总结一下C 语言关键字:auto、static、register、const、volatile 、extern ,希望对您有所帮助!auto这个这个关键字用于声明变量的生存期为自动,即将不在任何类、结构、枚举、联合和函数中定义的变量视为全局变量,而在函数中定义的变量视为局部变量。
这个关键字不怎么多写,因为所有的变量默认就是auto的。
register这个关键字命令编译器尽可能的将变量存在CPU内部寄存器中而不是通过内存寻址访问以提高效率。
static常见的两种用途:1>统计函数被调用的次数;2>减少局部数组建立和赋值的开销.变量的建立和赋值是需要一定的处理器开销的,特别是数组等含有较多元素的存储类型。
在一些含有较多的变量并且被经常调用的函数中,可以将一些数组声明为static 类型,以减少建立或者初始化这些变量的开销.详细说明:1>、变量会被放在程序的全局存储区中,这样可以在下一次调用的时候还可以保持原来的赋值。
这一点是它与堆栈变量和堆变量的区别。
2>、变量用static告知编译器,自己仅仅在变量的作用范围内可见。
这一点是它与全局变量的区别。
3>当static用来修饰全局变量时,它就改变了全局变量的作用域,使其不能被别的程序extern,限制在了当前文件里,但是没有改变其存放位置,还是在全局静态储存区。
使用注意:1>若全局变量仅在单个C文件中访问,则可以将这个变量修改为静态全局变量,以降低模块间的耦合度;2>若全局变量仅由单个函数访问,则可以将这个变量改为该函数的静态局部变量,以降低模块间的耦合度;3>设计和使用访问动态全局变量、静态全局变量、静态局部变量的函数时,需要考虑重入问题(只要输入数据相同就应产生相同的输出)。
C语言中static的作用及C语言中使用静态函数有何好处
C语⾔中static的作⽤及C语⾔中使⽤静态函数有何好处转⾃:在C语⾔中,static的作⽤有三条:⼀是隐藏功能,⼆是保持持久性功能,三是默认初始化为0。
在C语⾔中,static的字⾯意思很容易把我们导⼊歧途,其实它的作⽤有三条,分别是:⼀是隐藏功能,对于static修饰的函数和全局变量⽽⾔⼆是保持持久性功能,对于static修饰的局部变量⽽⾔。
三是因为存放在静态区,全局和局部的static修饰的变量,都默认初始化为0下⾯我逐⼀给⼤家介绍:(1)先来介绍它的第⼀条也是最重要的⼀条:隐藏。
当我们同时编译多个⽂件时,所有未加static前缀的全局变量和函数都具有全局可见性。
为理解这句话,我举例来说明。
我们要同时编译两个源⽂件,⼀个是a.c,另⼀个是main.c。
下⾯是a.c的内容1 2 3 4 5char a = 'A'; // global variable void msg(){printf("Hello\n");}下⾯是main.c的内容1 2 3 4 5 6 7int main(void){extern char a; // extern variable must be declared before use printf("%c ", a);(void)msg();return0;}程序的运⾏结果是:A Hello你可能会问:为什么在a.c中定义的全局变量a和函数msg能在main.c中使⽤?前⾯说过,所有未加static前缀的全局变量和函数都具有全局可见性,其它的源⽂件也能访问。
此例中,a是全局变量,msg是函数,并且都没有加static前缀,因此对于另外的源⽂件main.c是可见的。
如果加了static,就会对其它源⽂件隐藏。
例如在a和msg的定义前加上static,main.c就看不到它们了。
利⽤这⼀特性可以在不同的⽂件中定义同名函数和同名变量,⽽不必担⼼命名冲突。
C语言中static的作用
在C语言中,static的字面意思很容易把我们导入歧途,其实它的作用有三条。
(1)第一个作用:隐藏。
当我们同时编译多个文件时,所有未加static前缀的全局变量和函数都具有全局可见性。
为理解这句话,我举例来说明。
我们要同时编译两个源文件,一个是a.c,另一个是main.c。
下面是 a.c的内容#include<cstdio>增加这条语句char a = ‘A‘; // global variable void msg() { printf("Hello\n"); } 你可能会问:为什么在a.c中定义的全局变量a和函数msg能在main.c中使用?前面说过,所有未加static前缀的全局变量和函数都具有全局可见性,其它的源文件也能访问。
此例中,a是全局变量,msg是函数,并且都没有加static前缀,因此对于另外的源文件main.c是可见的。
如果加了static,就会对其它源文件隐藏。
例如在a和msg的定义前加上static,main.c就看不到它们了。
利用这一特性可以在不同的文件中定义同名函数和同名变量,而不必担心命名冲突。
Static可以用作函数和变量的前缀,对于函数来讲,static的作用仅限于隐藏,而对于变量,static还有下面两个作用。
(2)static的第二个作用是保持变量内容的持久。
存储在静态数据区的变量会在程序刚开始运行时就完成初始化,也是唯一的一次初始化。
共有两种变量存储在静态存储区:全局变量和static变量,只不过和全局变量比起来,static可以控制变量的可见范围,说到底static 还是用来隐藏的。
(3)static的第三个作用是默认初始化为0。
其实全局变量也具备这一属性,因为全局变量也存储在静态数据区。
在静态数据区,内存中所有的字节默认值都是0x00,某些时候这一特点可以减少程序员的工作量。
最后对static的三条作用做一句话总结。
首先static的最主要功能是隐藏,其次因为static变量存放在静态存储区,所以它具备持久性和默认值0。
c语言中static的定义
c语言中static的定义
static是一种在C语言中使用的关键字,用于声明静态变量或函数。
它的作用是限制变量或函数的作用域,使其只能在声明它们的文件中可见,无法被其他文件访问。
静态变量是一种只在声明它的函数或文件中可见的变量。
与普通变量不同,静态变量在程序执行期间只会被初始化一次,并且在函数调用结束后也不会被销毁,而是保留其值供下一次调用使用。
这使得静态变量在函数调用之间保持了状态,可以用于在多次函数调用中共享数据。
静态函数是一种只在声明它的文件中可见的函数。
与普通函数不同,静态函数无法被其他文件调用,只能在本文件中使用。
这种限制可以有效地隐藏实现细节,提高代码的安全性和可维护性。
使用static关键字可以有效地控制变量和函数的作用域,避免命名冲突和意外访问。
静态变量的持久性和静态函数的封装性使得它们在模块化编程中发挥重要作用。
在C语言中,static的使用场景非常广泛。
例如,在多个文件中定义同名的全局变量时,可以使用static关键字限制其作用域,避免冲突。
另外,在编写库文件时,可以使用static关键字将一些内部函数和变量隐藏起来,只暴露必要的接口,提高代码的安全性和可维护性。
总结一下,static是C语言中的一个关键字,用于声明静态变量和静态函数,限制其作用域,使其只能在本文件中可见。
它具有保持变量状态和隐藏实现细节的功能,对于模块化编程和库文件的编写非常有用。
通过合理使用static关键字,可以提高代码的可读性、安全性和可维护性。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
C++的static关键字作者:韩耀旭C++的static有两种用法:面向过程程序设计中的static和面向对象程序设计中的static。
前者应用于普通变量和函数,不涉及类;后者主要说明static在类中的作用。
一、面向过程设计中的static1、静态全局变量在全局变量前,加上关键字static,该变量就被定义成为一个静态全局变量。
我们先举一个静态全局变量的例子,如下://Example 1#include <iostream.h>void fn();static int n; //定义静态全局变量void main(){n=20;cout<<n<<endl;fn();}void fn(){n++;cout<<n<<endl;}静态全局变量有以下特点:∙该变量在全局数据区分配内存;∙未经初始化的静态全局变量会被程序自动初始化为0(自动变量的值是随机的,除非它被显式初始化);∙静态全局变量在声明它的整个文件都是可见的,而在文件之外是不可见的;静态变量都在全局数据区分配内存,包括后面将要提到的静态局部变量。
对于一个完整的程序,在内存中的分布情况如下图:new产生的动态数据存放在堆区,函数内部的自动变量存放在栈区。
自动变量一般会随着函数的退出而释放空间,静态数据(即使是函数内部的静态局部变量)也存放在全局数据区。
全局数据区的数据并不会因为函数的退出而释放空间。
细心的读者可能会发现,Example 1中的代码中将static int n; //定义静态全局变量改为int n; //定义全局变量程序照样正常运行。
的确,定义全局变量就可以实现变量在文件中的共享,但定义静态全局变量还有以下好处:∙静态全局变量不能被其它文件所用;∙其它文件中可以定义相同名字的变量,不会发生冲突;您可以将上述示例代码改为如下://Example 2//File1#include <iostream.h>void fn();static int n; //定义静态全局变量void main(){n=20;cout<<n<<endl;fn();}//File2#include <iostream.h>extern int n;void fn(){n++;cout<<n<<endl;}编译并运行Example 2,您就会发现上述代码可以分别通过编译,但运行时出现错误。
试着将static int n; //定义静态全局变量改为int n; //定义全局变量再次编译运行程序,细心体会全局变量和静态全局变量的区别。
2、静态局部变量在局部变量前,加上关键字static,该变量就被定义成为一个静态局部变量。
我们先举一个静态局部变量的例子,如下://Example 3#include <iostream.h>void fn();void main(){fn();fn();fn();}void fn(){static n=10;cout<<n<<endl;n++;}通常,在函数体内定义了一个变量,每当程序运行到该语句时都会给该局部变量分配栈内存。
但随着程序退出函数体,系统就会收回栈内存,局部变量也相应失效。
但有时候我们需要在两次调用之间对变量的值进行保存。
通常的想法是定义一个全局变量来实现。
但这样一来,变量已经不再属于函数本身了,不再仅受函数的控制,给程序的维护带来不便。
静态局部变量正好可以解决这个问题。
静态局部变量保存在全局数据区,而不是保存在栈中,每次的值保持到下一次调用,直到下次赋新值。
静态局部变量有以下特点:∙该变量在全局数据区分配内存;∙静态局部变量在程序执行到该对象的声明处时被首次初始化,即以后的函数调用不再进行初始化;∙静态局部变量一般在声明处初始化,如果没有显式初始化,会被程序自动初始化为0;∙它始终驻留在全局数据区,直到程序运行结束。
但其作用域为局部作用域,当定义它的函数或语句块结束时,其作用域随之结束;3、静态函数在函数的返回类型前加上static关键字,函数即被定义为静态函数。
静态函数与普通函数不同,它只能在声明它的文件当中可见,不能被其它文件使用。
静态函数的例子://Example 4#include <iostream.h>static void fn();//声明静态函数void main(){fn();}void fn()//定义静态函数{int n=10;cout<<n<<endl;}定义静态函数的好处:∙静态函数不能被其它文件所用;∙其它文件中可以定义相同名字的函数,不会发生冲突;二、面向对象的static关键字(类中的static关键字)1、静态数据成员在类内数据成员的声明前加上关键字static,该数据成员就是类内的静态数据成员。
先举一个静态数据成员的例子。
//Example 5#include <iostream.h>class Myclass{public:Myclass(int a,int b,int c);void GetSum();private:int a,b,c;static int Sum;//声明静态数据成员};int Myclass::Sum=0;//定义并初始化静态数据成员Myclass::Myclass(int a,int b,int c){this->a=a;this->b=b;this->c=c;Sum+=a+b+c;}void Myclass::GetSum(){cout<<"Sum="<<Sum<<endl;}void main(){Myclass M(1,2,3);M.GetSum();Myclass N(4,5,6);N.GetSum();M.GetSum();}可以看出,静态数据成员有以下特点:∙对于非静态数据成员,每个类对象都有自己的拷贝。
而静态数据成员被当作是类的成员。
无论这个类的对象被定义了多少个,静态数据成员在程序中也只有一份拷贝,由该类型的所有对象共享访问。
也就是说,静态数据成员是该类的所有对象所共有的。
对该类的多个对象来说,静态数据成员只分配一次内存,供所有对象共用。
所以,静态数据成员的值对每个对象都是一样的,它的值可以更新;∙静态数据成员存储在全局数据区。
静态数据成员定义时要分配空间,所以不能在类声明中定义。
在Example 5中,语句int Myclass::Sum=0;是定义静态数据成员;∙静态数据成员和普通数据成员一样遵从public,protected,private访问规则;∙因为静态数据成员在全局数据区分配内存,属于本类的所有对象共享,所以,它不属于特定的类对象,在没有产生类对象时其作用域就可见,即在没有产生类的实例时,我们就可以操作它;∙静态数据成员初始化与一般数据成员初始化不同。
静态数据成员初始化的格式为:<数据类型><类名>::<静态数据成员名>=<值>∙类的静态数据成员有两种访问形式:<类对象名>.<静态数据成员名>或<类类型名>::<静态数据成员名>如果静态数据成员的访问权限允许的话(即public的成员),可在程序中,按上述格式来引用静态数据成员;∙静态数据成员主要用在各个对象都有相同的某项属性的时候。
比如对于一个存款类,每个实例的利息都是相同的。
所以,应该把利息设为存款类的静态数据成员。
这有两个好处,第一,不管定义多少个存款类对象,利息数据成员都共享分配在全局数据区的内存,所以节省存储空间。
第二,一旦利息需要改变时,只要改变一次,则所有存款类对象的利息全改变过来了;∙同全局变量相比,使用静态数据成员有两个优势:1.静态数据成员没有进入程序的全局名字空间,因此不存在与程序中其它全局名字冲突的可能性;2.可以实现信息隐藏。
静态数据成员可以是private成员,而全局变量不能;2、静态成员函数与静态数据成员一样,我们也可以创建一个静态成员函数,它为类的全部服务而不是为某一个类的具体对象服务。
静态成员函数与静态数据成员一样,都是类的内部实现,属于类定义的一部分。
普通的成员函数一般都隐含了一个this指针,this指针指向类的对象本身,因为普通成员函数总是具体的属于某个类的具体对象的。
通常情况下,this是缺省的。
如函数fn()实际上是this->fn()。
但是与普通函数相比,静态成员函数由于不是与任何的对象相联系,因此它不具有this指针。
从这个意义上讲,它无法访问属于类对象的非静态数据成员,也无法访问非静态成员函数,它只能调用其余的静态成员函数。
下面举个静态成员函数的例子。
//Example 6#include <iostream.h>class Myclass{public:Myclass(int a,int b,int c);static void GetSum();/声明静态成员函数private:int a,b,c;static int Sum;//声明静态数据成员};int Myclass::Sum=0;//定义并初始化静态数据成员Myclass::Myclass(int a,int b,int c){this->a=a;this->b=b;this->c=c;Sum+=a+b+c; //非静态成员函数可以访问静态数据成员}void Myclass::GetSum() //静态成员函数的实现{// cout<<a<<endl; //错误代码,a是非静态数据成员cout<<"Sum="<<Sum<<endl;}void main(){Myclass M(1,2,3);M.GetSum();MyclassN.GetSum();Myclass::GetSum();}关于静态成员函数,可以总结为以下几点:∙出现在类体外的函数定义不能指定关键字static;∙静态成员之间可以相互访问,包括静态成员函数访问静态数据成员和访问静态成员函数;∙非静态成员函数可以任意地访问静态成员函数和静态数据成员;∙静态成员函数不能访问非静态成员函数和非静态数据成员;∙由于没有this指针的额外开销,因此静态成员函数与类的全局函数相比速度上会有少许的增长;∙调用静态成员函数,可以用成员访问操作符(.)和(->)为一个类的对象或指向类对象的指针调用静态成员函数,也可以直接使用如下格式:<类名>::<静态成员函数名>(<参数表>)调用类的静态成员函数。