读完ruby hacking guide第6章,彻底总结下:
1.在Ruby中,类也是一个对象,因此有实例变量。类的实例变量、类变量、常量都是存储在RClass struct的iv_tbl中,
struct RClass {
struct RBasic basic;
struct st_table *iv_tbl;
struct st_table *m_tbl;
VALUE super;
};
iv_tbl的类型是st_table,我在 这里用java实现了一下。
2.用户自定义类的对象(ruby层次声明的类的对象)的实例变量存储在RObject struct的iv_tbl中,
struct RObject {
struct RBasic basic;
struct st_table *iv_tbl;
};
调用方法,本质上是一个查表操作。buildin的几个类,比如String、Array、Hash等(在c层次上实现的类),它们的结构并没有 iv_table,这是从节省内存空间的角度考虑,它们的实例变量存储在一张全局的st_table中。这张表比较特别,其中的每一个对应的值又是一个 st_table,也就是一个“二元结构”,第一层结构是类名与实例变量表的映射,第二层才是实例变量名与实际值的映射。
3.全局变量存储在一张全局的st_table中,这个表的键就是变量名ID,由于全局变量允许通过alias来设置别名,因此这张全局表中真正存储的是下面这个struct
334 struct global_entry {
335 struct global_variable *var;
336 ID id;
337 };
324 struct global_variable {
325 int counter; /* 引用计数 */
326 void *data; /* 变量值 */
327 VALUE (*getter)(); /* 取值函数 */
328 void (*setter)(); /* 设置函数 */
329 void (*marker)(); /* 标记函数 */
330 int block_trace;
331 struct trace_var *trace;
332 };
(variable.c)
当不同变量名(通过别名声明)指向的是同一个全局变量,其实它们指向的是同一个struct global_variable。
1.在Ruby中,类也是一个对象,因此有实例变量。类的实例变量、类变量、常量都是存储在RClass struct的iv_tbl中,
struct RClass {
struct RBasic basic;
struct st_table *iv_tbl;
struct st_table *m_tbl;
VALUE super;
};
iv_tbl的类型是st_table,我在 这里用java实现了一下。
2.用户自定义类的对象(ruby层次声明的类的对象)的实例变量存储在RObject struct的iv_tbl中,
struct RObject {
struct RBasic basic;
struct st_table *iv_tbl;
};
调用方法,本质上是一个查表操作。buildin的几个类,比如String、Array、Hash等(在c层次上实现的类),它们的结构并没有 iv_table,这是从节省内存空间的角度考虑,它们的实例变量存储在一张全局的st_table中。这张表比较特别,其中的每一个对应的值又是一个 st_table,也就是一个“二元结构”,第一层结构是类名与实例变量表的映射,第二层才是实例变量名与实际值的映射。
3.全局变量存储在一张全局的st_table中,这个表的键就是变量名ID,由于全局变量允许通过alias来设置别名,因此这张全局表中真正存储的是下面这个struct
334 struct global_entry {
335 struct global_variable *var;
336 ID id;
337 };
324 struct global_variable {
325 int counter; /* 引用计数 */
326 void *data; /* 变量值 */
327 VALUE (*getter)(); /* 取值函数 */
328 void (*setter)(); /* 设置函数 */
329 void (*marker)(); /* 标记函数 */
330 int block_trace;
331 struct trace_var *trace;
332 };
(variable.c)
当不同变量名(通过别名声明)指向的是同一个全局变量,其实它们指向的是同一个struct global_variable。