草庐IT

c++ - 模板类构造函数采用模板类的实例

我的情况如下:ClassBar{...}templateclassFoo{public:...Foo(Foobar){...}...}因此类Foo的构造函数之一可以采用由Bar参数化的类Foo的元素。这一切都很好,直到我实例化由Bar参数化的类Foo的某些东西,其中此构造函数被解释为复制构造函数,这不是我想要的。我想知道如何让构造函数在不干扰复制构造函数的情况下采用这样的元素。例如我可以这样做:templateclassFoo{public:...Foo(Foobar,intunused){...}...}而且它工作正常,因为现在构造函数不会与复制构造函数冲突。有没有标准的方法来处理这

c++ - 将基于自定义模板的迭代器类的对象转换为 const_iterator

我正在大学学习OOP类(class)(C++是基础语言)。我的任务是实现自己的链表模板容器类。我几乎完全做到了,但遇到了问题。已知STL提供iterator和const_iterator通过列表进行迭代的类。它们具有几乎相同的实现,主要区别在于iterator的方法返回引用,而const_iterator的方法——常量引用。我关注了https://stackoverflow.com/a/3582733/2108548并创建了单独的模板类ListIterator.然后我用typedef声明类(class)Iterator和ConstIterator类内List.我有这样的东西:templ

【C++】中类的6个默认成员函数 取地址及const成员函数 && 学习运算符重载 && 【实现一个日期类】

文章目录一、【C++】赋值运算符重载1.1运算符重载【引入】1.2运算符重载1.3赋值运算符重载1.4赋值二、日期类的实现2.1判断小于2.2判断等于2.3判断小于等于2.4判断大于2.5判断大于等于2.6判断不等于2.7日期加等天数2.8获取月份天数2.9日期加天数2.9.1日期减等天数2.9.2日期减天数三、前置++&&后置++3.1日期减日期【返回天数】3.2流插入3.3流提取3.4检查输入日期是否合法四、日期类的实现【源码】五、const修饰5.1const成员函数5.2小结一下:5.3默认成员函数【取地址及const取地址操作符重载】一、【C++】赋值运算符重载1.1运算符重载【引入

c++ - 将具有 unique_ptr 的类的构造函数作为成员复制到抽象类

我有一个类(C),它有一个vector的unique_ptr到一个抽象类(A)作为成员(member)。这是因为C必须与A类型的所有类一起工作,即它的子类。问题是我不知道如何为C编写复制构造函数,因为指针指向的对象的类型在编译时是未知的。在我看来这实际上是不可能的。任何人都可以确认这是不可能的吗?你对如何解决这个问题有什么建议吗?有一个没有复制构造函数的类是不是太糟糕了? 最佳答案 你没有说你是否控制抽象类和从它派生的类的代码。如果这样做,那么最简单的方法是在抽象类中提供一个纯虚方法Clone并在派生类中实现它。此方法应处理创建正确

c++ - 了解空继承类的未使用 typedef

我只是想了解我正在阅读的一些教程代码。我正在尝试学习一些Dx11代码,我正在学习的教程中包含设计为事件详细信息的类,以便在事件发生时传递给函数,例如鼠标按钮被按下。有一个空的基类EventArgs定义如下:classEventArgs{public:EventArgs(){};}这是由其他事件类继承的。因此,例如,他们有一个按键事件参数类,如下所示:classKeyEventArgs:publicEventArgs{public:typedefEventArgsbase;KeyEventArgs(/**/){}//Restoftheclass}我理解所有事件都继承一个基础来表示“它们是

具有实矩阵和复矩阵的矩阵类的 C++ 运算符重载

我正在尝试实现一个可以处理实矩阵和复矩阵的矩阵类。当我尝试重载乘法运算符时遇到问题。具体来说,当我尝试将double矩阵乘以复数矩阵时(按此顺序)。结果应该很复杂,但在这种情况下*运算符是双矩阵的成员,我不知道如何返回复数矩阵(我试过使用友元运算符,这似乎也不起作用).这是相关的代码片段:templateMatrixoperator*(constMatrix&b){longi,j,k;Ttemp;Matrixc(mRows,b.Cols());for(i=0;iElement(i,k)*b.Element(k,j);c(i,j)=temp;}returnc;}因此,如果A是实数,并且B

c++ - 使用 GCC 导出 C++ 类的符号

我正在使用dlopen合并动态加载库及其宿主的符号,在宿主中我有一个类:classFoo{public:Foo(){/*...*/}voidbar(){/*...*/}};intmain(){//Foofoo;return0;}我正在使用g++-Wl,--export-dynamic-otesttest.cpp编译它并使用nm-gtest检查符号。我希望符号_ZN3FooC1Ev和_ZN3FooC2Ev存在于可执行文件中,因为动态库需要它们,但除非我通过取消注释上面的行来使用它们,否则它们不会出现.我相信它正在被优化掉,因为GCC认为不需要它。如何强制将Foo的构造函数和方法包含在主机

c++ - 类型组的模板类的成员特化?

我有一个矩阵类,我想针对不同的矩阵类型(int、float、double)以不同的方式将矩阵打印到终端。我想实现这个:如果矩阵类型ifint,使用printf("%d",matrix[i][j])打印矩阵如果矩阵类型iffloat或double,使用printf("%.3f",matrix[i][j])打印矩阵否则,抛出错误以下是我所拥有的相关部分:...templateclassMatrix2D{private:std::vector>matrix;public:...voidprint()const;//printthewholematrix}...templatevoidMatr

c++ - 初始化不可复制和不可移动类的元组

考虑具有唯一自定义构造函数的类A:classA{public:A(float){}private:A()=delete;A(constA&)=delete;A(A&&)=delete;};还有另一个类B,它包含A的一个元组(为简单起见,让它成为唯一的元组成员):classB{public:B():ta(0.0f){}//tainitializationOKprivate:std::tupleta;};现在我们可以声明B的一个对象,它工作正常:Bb;但是如果A的构造函数有多个参数,如何做同样的事情呢?classA{public:A(float,int){}private:A()=dele

c++ - 将任意类的成员函数指针存储为类实例变量

SO上有几个问题解决了将函数指针作为参数/实参传递的问题(here、here、here等)。其实我问了一个relatedquestion另一天。但是,这个问题有点不同。我的问题是我正在编写一个非常灵活的类。我现在拥有的适用于非成员函数。下面贴出来templateclassMyClass{private:typedefdouble(*firstFunctionPtr)(constT&var);typedefbool(*secondFunctionPtr)(constT&var);//FunctionpointersasmembervariablesfirstFunctionPtr_fir