
1 直接调用classB的静态函数
2 通过classB的实例调用非静态函数(例如一个全局classB实例)
互相调用的话,好像必须用指针。
// classah
class classB;
class classA
{
classB cb;//好像必须用指针
};
// classbh
class classA;
class classB
{
classA ca;//好像必须用指针
}
函数调用的时候直接调用就写,你这写的是函数原型了:
class A
{
public:
int B();
private:
int C();
}
int A::B()
{
C();//直接调用C函数即可
}
int A::C()
{
}
当个可以了!不过要说对应的函数和公共变量声明到头文件里,前面加前缀external!在对应的C文件定义函数和变量,如果想调用的话!只需要用include包含一下头文件,就可以在不同文件相互调用函数了!
首先来看一个函数间的调用
类方法:
执行结果:
metaclass能有什么用处,先来个感性的认识:
11 在wiki上面,metaclass是这样定义的:In object-oriented programming,
a metaclass is a class whose instances are classes
Just as an ordinary class defines the behavior of certain objects,
a metaclass defines the behavior of certain classes and their instances
也就是说metaclass的实例化结果是类,而class实例化的结果是instance。我是这么理解的:
metaclass是类似创建类的模板,所有的类都是通过他来create的(调用 new ),这使得你可以自由的控制
创建类的那个过程,实现你所需要的功能。
当然你也可以用函数的方式(下文会讲)
41 用类的形式
411 类继承于type, 例如: class Meta(type):pass
412 将需要使用metaclass来构建class的类的 metaclass 属性(不需要显示声明,直接有的了)赋值为Meta(继承于type的类)
42 用函数的形式
421 构建一个函数,例如叫metaclass_new, 需要3个参数:name, bases, attrs,
name: 类的名字
bases: 基类,通常是tuple类型
attrs: dict类型,就是类的属性或者函数
422 将需要使用metaclass来构建class的类的 metaclass 属性(不需要显示声明,直接有的了)赋值为函数metaclas_new
51 basic
metaclass的原理其实是这样的:当定义好类之后,创建类的时候其实是调用了type的 new 方法为这个类分配内存空间,创建
好了之后再调用type的 init 方法初始化(做一些赋值等)。所以metaclass的所有magic其实就在于这个 new 方法里面了。
说说这个方法: new (cls, name, bases, attrs)
cls: 将要创建的类,类似与self,但是self指向的是instance,而这里cls指向的是class
name: 类的名字,也就是我们通常用类名 name 获取的。
bases: 基类
attrs: 属性的dict。dict的内容可以是变量(类属性),也可以是函数(类方法)。
所以在创建类的过程,我们可以在这个函数里面修改name,bases,attrs的值来自由的达到我们的功能。这里常用的配合方法是
getattr和setattr(just an advice)
下面实现python中在一个类中调用另一个类的函数方法
或者下面来一个号理解的例子
执行结果:
先来介绍内部类与外部类是什么?
看源码解析:
内部类调用外部类的类属性和类方法
参考文献1
参考文献2
参考文献3
在2cpp写
extern int a;
(在全局范围写就可以了)
之后就可以用a的值了。
如果类型不是int,请自行修改。
对于问题补充:
增加一个与a同类型的全局变量,把a赋值给它,然后用上述方法。
或者增加一个a的指针类型的全局变量,把a的地址赋值给它,然后用上述方法。
function
a{}这是一个类而不是函数,function
a(){};这才是一个函数,b也同样,如果调用b,就直接b();就会运行函数b,如果b是参数,b()这是传的b运行后返回的值,b是传的b这个函数
创建类只是建立一个模板,内部代码块的书写没有顺序要求;编译时编译器会把它们弄成一个标准化结构的东西。如果考虑你纠结的问题,那绝大多数类的写法都过不了编译,因为习惯上在类名后的public:后就写构造函数了,而常常这构造函数就要 *** 作类中的private数据成员,而这private数据成员偏偏习惯上又是放在类的最后才声明的。这完全是个人理解,没有权威性,只供参考……
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)