类成员的访问控制
课外 → 好的编程习惯:定义与实现分开写,提升代码可读性。
如下代码,Student这个类的所有成员我们都可以调用,但是我们不想让被人调用Print1这个方法该怎么?
struct Student {
int age;
int sex;
void Print1() {
printf("Func Print1");
}
void Print() {
printf("Func Print");
}
};
这里我们可以使用关键词:private、public来控制我们想被人访问的和不想被人访问的成员:
struct Student {
private:
void Print1() {
printf("Func Print1");
}
public:
int age;
int sex;
void Print() {
printf("Func Print");
}
};
当我们调用Print1的时候就会发现无法编译:
private(私有)、public(公有)的使用总结:
- 对外提供的函数或者变量,定义成public,不能随意改动
- 可能会改动的函数或者变量,定义成private,使用时编译器会检测
- 只有当前结构体内部函数才可以访问private的成员
- private、public可以修饰函数或者变量
那么问题来了,private修饰的函数或者变量真的不能访问吗?并不是,只是我们没有办法通过正常的方式去使用,但是我们可以使用指针的方式去调用:
那就说明private修饰的成员与普通成员没有区别,只有编译器会检测。
自己vs2022测试下:
代码如下:
#include <stdio.h>
class Person {
private:
int age;
int sex;
public:
Person(int a, int b) {
age = a;
sex = b;
}
};
void main() {
Person tom(100, 1);
int* p = (int*)&tom;
printf("%d %d\n", p[0], p[1]);
return;
}
在我的vs2022里,运行下看看tom这个局部变量存放的地址:
是从ebp-c开始的,不是ebp-4,也不是ebp-8!
从这节课开始我们不再使用struct作为类的创建,而是直接使用class关键词,其使用没有什么区别,唯一的区别在于成员默认访问属性不一样,在struct中所有成员默认的属性是public,而在class中则相反:
除此之外还有一个就是在继承时的区别,我们可以将一个正常的struct继承修改成class:
class A {
public:
int x;
int y;
};
class B:A {
public:
int v;
int n;
};
当我们创建对象调用的时候却无法编译:
这是因为在继承的时候默认将继承过来的A的所有成员设置为private,也就是如下代码:
class A {
public:
int x;
int y;
};
class B:private A {
public:
int v;
int n;
};
而我们想要外部可以调用可以将private修改成public。
最后一个问题:私有成员是否会被继承?
class A {
private:
int x;
public:
int y;
};
class B:public A {
public:
int v;
int n;
};
以上代码B继承了A,这里A前面的public代表着,按照A的成员定义的属性继承过来,公有就是公有,私有就是私有。
而在这里我们想要确认B有没有继承A的私有成员,有2个方法:
1.查看数据宽度,显示为16
2.指针方式调用,可以成功调用获取到值
所以我们得出最终结论:父类的私有成员是可以被继承的,但是也不能直接访问。(当然,使用前面指针的方式是可以访问的)
标签:Print1,逆向,访问控制,成员,private,class,int,C++,public From: https://blog.51cto.com/u_11908275/6941579