草庐IT

static-mt

全部标签

c++ - 使用无法安装的类的有效 STATIC 成员函数

我有以下代码:在gcc-3.4、gcc-4.3、intel编译器下编译没有问题,在MSVC9下编译失败。MSVC告诉“使用未定义类型c_traits,同时编译类模板成员函数voidfoo::go(void)与C=short。编译器试图安装未使用类的未使用成员函数,因为根本没有使用这个类。我可以通过专门化整个类foo而不是专门化来解决这个问题它的成员函数。但重点是,由于不同的原因,对整个类(class)进行特化对我来说有点问题。大问题:什么是正确的?我的代码是否错误,gcc和intel编译器只是忽略了这个问题,因为它们没有完全安装foo,或者代码正确,这是MSVC9(VC2008)的错误

c++ - G++ 4.6 -std=gnu++0x : Static Local Variable Constructor Call Timing and Thread Safety

voida(){...}voidb(){...}structX{X(){b();}};voidf(){a();staticXx;...}假设在进入main之后,f被多个线程(可能竞争)多次调用。(当然,唯一对a和b的调用是上面看到的那些)以上代码在-std=gnu++0x模式下用gccg++4.6编译时:Q1。是否保证至少调用一次a()并在调用b()之前返回?也就是说,在第一次调用f()时,x的构造函数是否会同时调用一个自动持续时间局部变量(非静态)(而不是在全局静态初始化时间)?Q2。是否保证b()只会被调用一次?即使两个线程第一次同时在不同的核上执行f?如果是,GCC生成的代码通过

【C++】详解用标准库的std::mt19937生成随机数

2023年8月16日,周三晚上写了1个半小时目录概述英文文档什么是mt19937什么是状态大小头文件std::mt19937的常用成员函数1.构造函数:2.种子操作函数:3.随机数生成函数:4.辅助函数:生成种子值方法1:使用std::random_device方法2:使用时间戳举例说明概述英文文档std::mersenne_twister_engine-cppreference.comhttps://cplusplus.com/reference/random/mt19937/什么是mt19937std::mt19937是C++标准库中的一个伪随机数生成器类,它实现了梅森旋转算法(Merse

c++ - 关于多线程环境下static const变量的使用

我正在尝试了解潜在的场景以及它是否可能成为问题。所以我有一个当前线程安全的静态函数。函数是这样的:staticthread_safe_func(){...process}现在在此函数中,我添加以下内容:staticthread_safe_func(){staticconstClass::NonThreadSafeClassName()*array[16]={Class::NonThreadSafeClassName(),Class::NonThreadSafeClassName(),Class::NonThreadSafeClassName(),Class::NonThreadSafe

c++ - 错误 : invalid use of member in static member function

我有两个类,这是其中一个的标题:#ifndefWRAPPER_HPP#defineWRAPPER_HPP#includeusingnamespacestd;classWrapper{private://SDL_Surface*screen;public:staticSDL_Surface*screen;staticvoidset_screen(SDL_Surface*_screen);staticvoidset_pixel(intx,inty,Uint8color);staticvoidclear_screen(intr,intg,intb);staticSDL_Surface*loa

c++ - 如果函数被称为 constexpr,则有条件地 static_assert

我知道有人提议使用constexpr()运算符,但这还没有在gcc/clang中实现。我也知道有一个使用机器代码编辑等技巧的实现:http://saadahmad.ca/detecting-evaluation-context-inside-constexpr-functions/我想知道是否有一个有点受限的解决方案:structF{constexprF(intv){ifconstexpr(constexpr()){static_assert(v>0);}else{assert(v>0);}}};//...constexprFf{0};//shouldtriggeracompile-t

c++ - 在 VS2008 和 GCC 中编译 static const int = X 的最佳代码

我在编写需要在VisualStudio2008和GCC4.6中编译(并且还需要编译回GCC3.4)的C++代码时遇到了一个问题:staticconstint类成员。Otherquestionshavecoveredstaticconstint类成员所需的规则。特别是,标准和GCC要求变量在一个且仅一个目标文件中有定义。但是,VisualStudio在编译包含.cpp文件中的定义的代码(在Debug模式下)时会产生LNK2005错误。我试图在其中做出决定的一些方法是:使用.cpp文件中的值而不是header对其进行初始化。使用预处理器删除MSVC的定义。将其替换为枚举。用宏替换它。最后两

c++ - 铿锵错误 : ambiguous conversion for static_cast

我有以下代码:typedefintAliasB;typedefunsignedshortAliasA;classAlias{public:explicitAlias(intsomeInt){}};//(*)!!belowbreakstheconversionpathviaAliasA!!//typedefAliasAliasA;classC{public:C(){}};classB{public:B(){}B(constAliasB&value){}operatorAliasB()const{return-1000;}Ccombine(constB&someB){returnC();}

c++ - C++ 对 static const 整数类型应用了哪些特殊规则?

我的印象是C++将相同的特殊规则应用于staticconst整型regardless是否声明于命名空间范围或在类/结构/union内声明。现在我在想我被不合规的编译器教坏了。staticconstintA=1;structs{staticconstintA=1;};除了范围上的明显差异,A和s::A有何不同?...它们的用法何时会被替换为字面值?...我什么时候可以拿到它的地址?...什么时候需要单独定义它们?我对C++03特别感兴趣。 最佳答案 static关键字在类作用域中的含义不同并在命名空间范围内。事实上,它在命名空间范围内

C++ map<char, static method pointer>?

这个问题在这里已经有了答案:Howtocreateclassobjectsdynamically?(3个答案)关闭7年前。我已经编写了一个非常基本的表达式解析器,我希望它是可扩展的,以便它可以解析用户定义的表达式类型。例如,如果在解析时遇到字符,我想创建一个用于解析以此字符开头的表达式的类的实例。我有两个问题:如何将字符关联到静态方法指针?我想使用一个静态方法来返回类的一个新实例,因为我无法获得指向类构造函数的指针。以下语法可能是错误的,但这就是想法:typedefstaticIValue*(*returnPtrIValue)();map...假设我有A类,B类扩展了A类,我可以初始化