模板编程可以节省时间和避免代码重复,但是有时候使用模板却有可能导致代码膨胀,也就是当完成编译后,目标代码可能会很大,即使我们自己敲打出的代码看起来非常的间接。所以在使用模板编程的时候应该小心,如何避免重复将会还能重要。
如下代码,便是矩阵,同时求矩阵的逆,
现在如下的使用方式:
上述的sm1和sm2将会被编译器认为是两个不同的类,因此,将会调用两个不同的函数invet,然而,事实上两个invert函数只有5和10两个参数不同,其他部分完全相同,因此这也就导致了代码膨胀的问题。
为了解决上述的代码膨胀的问题,我们很容易想到将上述的invert函数抽离,然后传入一个参数表示矩阵的大小,只要在invert函数中能够访问矩阵的相应的参数即可。所以我们设计一个模板基类,然后让所有的派生类都能共享一份相同的基类的代码,这样我们便可以减小目标文件的大小。
代码如下:
this->模板化基类的成员函数将会被派生类遮掩,因此需要用this-> 显示指明该基类中有相应的成员函数。
对于,相同数据类型的矩阵而言,上述模板基类将会被实现为相同的一份代码,因为这基类的模板参数是相同的,所有对于相同参数的矩阵,其调用的基类函数invert(n),将会是同样的一份基类模板代码,从而减小了目标代码的长度。
对于数据等访问,基类访问数据的方式比较简单,只要基类维护一个指向举证数据的指针即可,不管数据存放于基类对象中还是数据存放于堆上。
数据存放于基类对象之中:
数据存放于堆上:
以下补充: