C++编译器对属性和方法的处理机制
2017-05-19 08:44
169 查看
C++中的class从面向对象理论出发,将变量(属性)和函数(方法)集中定义在一起,用于描写叙述现实世界中的类。
从计算机的角度。程序依旧由数据段和代码段构成。
C++编译器怎样完毕面向对象理论到计算机程序的转化?
换句话:C++编译器是怎样管理类、对象、类和对象之间的关系
详细的说:详细对象调用类中的方法。那,c++编译器是怎样区分,是哪个详细的类,调用这种方法?
demo
通过上面的demo。我们能够的得出:
1)C++类对象中的成员变量和成员函数是分开存储的
成员变量:
普通成员变量:存储于对象中,与struct变量有同样的内存布局和字节对齐方式
静态成员变量:存储于全局数据区中
成员函数:存储于代码段中。
问题出来了:非常多对象共用一块代码?代码是怎样区分详细对象的?
换句话说:int getK() const { return k; },代码是怎样区分,详细obj1、obj2、obj3对象的k值?
看下图
对于普通成员函数。C++编译器做了一层封装。比方Test类的构造函数。当中尽管仅仅写了一个參数i,但实际上就像右面结构体的初始化函数那样,类的构造函数隐藏定义了一个this指针。
而静态成员函数,不须要this指针,由于是共用的。对于类仅仅须要标注作用域就能够了。
所以运行Test a(10); 就相当于 Test a; Test_initialize(%a, 10);其它的类似对照就懂了。
总结:
1、C++类对象中的成员变量和成员函数是分开存储的。
C语言中的内存四区模型仍然有效!
2、C++中类的普通成员函数都隐式包括一个指向当前对象的this指针。
3、静态成员函数、成员变量属于类
静态成员函数与普通成员函数的差别
静态成员函数不包括指向详细对象的指针
普通成员函数包括一个指向详细对象的指针
从计算机的角度。程序依旧由数据段和代码段构成。
C++编译器怎样完毕面向对象理论到计算机程序的转化?
换句话:C++编译器是怎样管理类、对象、类和对象之间的关系
详细的说:详细对象调用类中的方法。那,c++编译器是怎样区分,是哪个详细的类,调用这种方法?
demo
#include <iostream> using namespace std; class C1 { public: int i; //4 int j; //4 int k; //4 protected: private: }; // 大小应该是12 class C2 { public: int i; //4 int j; //4 int k; //4 static int m; //4 public: int getK() const { return k; } //4 void setK(int val) { k = val; } //4 protected: private: }; //大小可能是12,可能是16。可能是24 struct S1 { int i; int j; int k; }; // 大小是12 struct S2 { int i; int j; int k; static int m; }; // 大小可能是12,可能是16 int main() { printf("c1:%d \n", sizeof(C1)); // 结果是12 printf("c2:%d \n", sizeof(C2)); // 结果是12 printf("s1:%d \n", sizeof(S1)); // 结果是12 printf("s2:%d \n", sizeof(S2)); // 结果是12 }
通过上面的demo。我们能够的得出:
1)C++类对象中的成员变量和成员函数是分开存储的
成员变量:
普通成员变量:存储于对象中,与struct变量有同样的内存布局和字节对齐方式
静态成员变量:存储于全局数据区中
成员函数:存储于代码段中。
问题出来了:非常多对象共用一块代码?代码是怎样区分详细对象的?
换句话说:int getK() const { return k; },代码是怎样区分,详细obj1、obj2、obj3对象的k值?
看下图
对于普通成员函数。C++编译器做了一层封装。比方Test类的构造函数。当中尽管仅仅写了一个參数i,但实际上就像右面结构体的初始化函数那样,类的构造函数隐藏定义了一个this指针。
而静态成员函数,不须要this指针,由于是共用的。对于类仅仅须要标注作用域就能够了。
所以运行Test a(10); 就相当于 Test a; Test_initialize(%a, 10);其它的类似对照就懂了。
总结:
1、C++类对象中的成员变量和成员函数是分开存储的。
C语言中的内存四区模型仍然有效!
2、C++中类的普通成员函数都隐式包括一个指向当前对象的this指针。
3、静态成员函数、成员变量属于类
静态成员函数与普通成员函数的差别
静态成员函数不包括指向详细对象的指针
普通成员函数包括一个指向详细对象的指针
相关文章推荐
- C++编译器对属性和方法的处理机制
- C++编译器对属性和方法的处理机制
- C++编译器对属性和方法的处理机制
- C++编译器对属性和方法的处理机制
- C++复习要点总结之六——编译器对属性和方法的处理机制
- 项目中出现无法识别的属性“decompressionEnabled”处理方法
- C#处理AMF消息机制的方法
- 关于IE7打开任何网页弹出[未处理的异常('对象不支持此属性或方法')发生在iexplorer.exe]错误调试框的解决办法
- Android开发(12)--多线程处理机制之Handler的使用方法
- 利用java的反射机制调用类的私有方法及私有属性
- JNI学习笔记:(1)开篇(2)本地代码访问Java代码 (3)本地方法取得Java属性/调用java方法 (4)本地代码创建Java对象(包括javaString) (5) 本地方法处理java数组
- .net控件开发系列 事件处理机制 三个接口两个方法
- 对启用了ReadOnly属性的WebEdit控件无法使用Set方法赋值的处理办法
- Java的动态性支持学习二 - 反射机制 属性、方法、对象的操作
- Java的动态性支持学习三 - 反射机制 取消属性、方法、构造器的访问限制
- (转载)iOS属性和方法扩展之扩展机制category与associative
- 处理XML文档的DOM元素属性和方法
- linux 并发机制的处理方法
- IIS模式切换和IIS属性中没有asp.net选项的处理方法
- JSONObject.fromObject方法出现处理日期属性异常