草庐IT

MY_CLASS

全部标签

c++ - 嵌套类声明 : template vs non-template outer class

我有一个C++模板类,里面有一个嵌套类,比如:templateclassOuter_t{public:classInner;Inneri;};templateclassOuter_t::Inner{public:floatx;};intmain(){Outer_to_t;//3oranyarbitraryinto_t.i.x=1.0;return0;}编译没有任何问题。然而,一旦我声明了一个类似的非模板类,就像这样:classOuter_1{public:classInner;Inneri;};classOuter_1::Inner{public:floatx;};intmain(){

c++ - Gtest : Expected Class-Name Before '{'

我正在尝试将Gtest下的测试用例转换为使用测试夹具,以便在添加更多测试时可以使用通用设置。但是,这会导致错误:test_integrate.cc:4:47:error:expectedclass-namebefore'{'tokenclassIntegratorTest:public::testing::test{这种失败是我无法理解的,因为根据我的经验,它通常是由循环导入引起的,并且导入与工作代码相比没有变化。完整代码如下:#include"gtest/gtest.h"#include"utils/integrate.hpp"classIntegratorTest:public::

c++ - 为什么一个 const Class& 可以被初始化为自身?

今天我遇到了一个非常愚蠢但难以检测的错误。相关代码如下:classVector;classPointIterator{constVector&x;constVector&yv;PointIterator(constVector&xv,constVector&yvo):x(xv),yv(yv){;};//^^hereiswrong};为什么这样的代码是合法的C++?在任何情况下都可以使用yv变量吗?我知道关于intx=x+1;的类似问题,(请参阅thisquestion)但后者未正确初始化,您仍然可以使用x变量,而在上面的代码中,我认为您不能使用yv。奖励点:是否有任何编译选项可以让我检

c++ - C++ 中的 class a() 和 class a = class() 有什么区别?

来自Java和C#世界,一直喜欢用someclassa=someclass();代替someclassa();在C++中初始化一个类变量。但是,我的编译器有时会提示ErrorC2280:Attemptingtoreferenceadeletedfunction它们之间有什么区别吗?哪个更好? 最佳答案 Isthereanydifferencebetweenthem?一个大的:someclassa();isdeclaringafunction!someclassa=someclass();,在C++17'scopyellision之前

c++ - "How to impress interviewers with my coding? What practices can I adopt in the code I' 已经为给面试官留下深刻印象的问题而写了吗?

假设有一个整数vector。现在我们想要合并,我们选择2个相邻元素v[I]和v[I+1](对于每个有效的I)并执行v[I]=v[I+1]+v[I]。并删除v[I+1]。继续这样做,直到vector中只剩下一个元素。(注意I=0&I=v.size()-1也被认为是相邻的)。所以我们需要尝试所有这些可能的组合(即我们首先采用哪一对并合并问题,如果需要进一步说明,请在评论中告诉我)每次我们合并时,我们都会做成本+=v[I]+v[I+1]。目标是最小化成本。举个例子说vector是123。合并[123]->[3,3]&cost=3->[6]&cost=9另一种方式[123]->[1,5]&co

c++ - 一个类(class)的规模是多少?

这个问题在这里已经有了答案:关闭12年前。PossibleDuplicate:EmptyclassinC++classClass1{charc;};classClass2{};Class1和Class2的大小是多少?在VC6中,我同时获得了1.有人可以解释一下吗?

c++ - 在 C : Will alignment break my neck? 中伪造继承

我有一个C结构,用于各种C和C++代码(通过extern"C")。#ifdef__cplusplusextern"C"{#endiftypedefstructAA;structA{/*somemembers*/};#ifdef__cplusplus}#endif分配、初始化和释放是由我控制的独立成员函数完成的,但我不控制对成员的访问,因为它们可以在任何地方访问。问题是,我无法更改整个系统中大量使用的header中struct的定义,但我仍然想扩展类型并添加一些成员。由于这必须编译为C++和C,我不能简单地创建派生类型structB:publicA。所以我的想法是将这种类型添加到cpp文

c++ - 在 C++ 中重新定义模板 <class T>

我已经搜索并搜索了我的问题的解决方案,但似乎找不到。我正在使用Code::Blocks,但出现了模板类的重定义错误。这是我的“vectorAux.h”文件:#ifndefvectoraux_h#definevectoraux_h#include#include#includetemplatevoidremoveDup(std::vector&v);templateunsignedseqVectSearch(conststd::vector&v,unsignedfirst,unsignedlast,constT&target);templatevoidwriteVector(consts

c++ - SFINAE 专业类(class)

我想编写一个模板类,它使用SFINAE检查特征。正如我在那篇文章中读到的那样,类不能被“重载”:templateoverloadingandSFINAEworkingonlywithfunctionsbutnotclasses我写了下面的代码:classAA{public:usingTRAIT=int;};classBB{public:usingTRAIT=float;};templateclassX;templateclassX::value,int>::type>{public:X(){std::coutclassX::value,unsignedint>::type>{publi

c# - 父类(super class)构造函数中的虚拟化

我认为根据OOP的设计,虚拟化在父类(superclass)构造函数中不起作用。例如,考虑以下C#代码。usingSystem;namespaceProblem{publicclassBaseClass{publicBaseClass(){Console.WriteLine("Hello,World!");this.PrintRandom();}publicvirtualvoidPrintRandom(){Console.WriteLine("0");}}publicclassDescendent:BaseClass{privateRandomrandomValue;publicDes