C++_CH15_static在类和结构体中使用
1.1 原理解释
在类或者结构体中使用static关键字,那么之后所有的instance,全部指向的同一块内存空间。在这个时候创建实例就没有意义。比如我创建了两个instance,e1和e2.由于他们指向同一块内存空间,所以修改e2的值也会带动e1的值修改。
1.2代码操作
首先创建一个类或者结构体
#include<iostream>
struct position
{
int x;
int y;
void print()
{
std::cout<<x<<','<<y<<std::endl;
}
};
之后加上static关键字,并创建两个instance
#include<iostream>
struct position
{
static int x,y;
static void print()
{
std::cout<<x<<','<<y<<std::endl;
}
};
int main()
{
position e1;//instance1
e1.x = 9;
e1.y = 10;
position e2;//instance2
e2.x = 20;
e2.y = 30;
e1.print();
e2.print();
std::cin.get();
}
这会报错。因为需要声明x,y两个变量
#include<iostream>
struct position
{
static int x,y;
static void print()
{
std::cout<<x<<','<<y<<std::endl;
}
};
int position::x;
int position::y;
int main()
{
position e1;//instance1
e1.x = 9;
e1.y = 10;
position e2;//instance2
e2.x = 20;
e2.y = 30;
e1.print();
e2.print();
std::cin.get();
}
output:
20,30
20,30
会发现输出的都是e2.这就证明,不论是什么instance,在静态修饰下都没有意义。因此我们可以全这样写:
#include<iostream>
struct position
{
static int x,y;
static void print()
{
std::cout<<x<<','<<y<<std::endl;
}
};
int position::x;
int position::y;
int main()
{
//instance1
position::x = 9;
position::y = 10;
position::print();
//instance2
position::x = 20;
position::y = 30;
position::print();
std::cin.get();
}
output:
9,10
20,30
1.3静态方法不能非静态对象使用
我们保持print的static,删除x,y的static
#include<iostream>
struct position
{
int x,y;
static void print()
{
std::cout<<x<<','<<y<<std::endl;
}
};
int position::x;
int position::y;
int main()
{
position e1;//instance1
e1.x = 9;
e1.y = 10;
position e2;//instance2
e2.x = 20;
e2.y = 30;
e1.print();
e2.print();
std::cin.get();
}
output:
main.cpp: In static member function ‘static void position::print()’:
main.cpp:8:14: error: invalid use of member ‘position::x’ in static member function
8 | std::cout<
这在本质上,是静态方法不知道访问哪个实例。因为他只能访问一块内存,这个静态方法没有类实例,而实际上实例有很多个。如果我们建立一个新的函数,直接把结构体作为参数传入,则不会报错。
#include<iostream>
struct position
{
int x,y;
};
static void print(position e1)
{
std::cout<<e1.x<<','<<e1.y<<std::endl;
}
int main()
{
position e1;//instance1
e1.x = 9;
e1.y = 10;
position e2;
e2.x = 3;
e2.y = 4;
print(e1);
print(e2);
std::cin.get();
}
9,10
3,4