草庐IT

has_public_member_foo

全部标签

c++ - enable_if : minimal example for void member function with no arguments

我试图更好地理解C++11中的std::enable_if并且一直在尝试编写一个最小的示例:一个类A带有成员函数voidfoo()根据类模板中的类型T具有不同的实现。下面的代码给出了期望的结果,但我还没有完全理解它。为什么版本V2有效,但V1无效?为什么需要“冗余”类型U?#include#includetemplateclassA{public:A(Tx):a_(x){}//EnablethisfunctionifT==int/*V1*///template::value,int>::type=0>/*V2*/template::value,int>::type=0>voidfoo(

c++ - 对齐 : warning C4316 in all classes that have aligned members

今天我遇到了很多麻烦,因为我跟踪了一个非常隐蔽的腐败漏洞。我想如果我真的注意警告就不会那么难找到它,但由于找不到有关为什么弹出此特定警告的相关信息,我让它滑动了,这是一个错误。所以这是VisualStudio2013给我的有罪警告:warningC4316:objectallocatedontheheapmaynotbealigned16它是在通过const引用将align(16)临时传递给构造函数时生成的,如以下代码所示:classVector{};__declspec(align(16))classVectorA{};classShape{public:Shape(constVec

C++:可以将 "try { foo(); } catch (...) { throw; }"优化为 "foo();"吗?

在C++中,是如下代码try{foo();}catch(...){throw;}在语义上等同于像这样调用foo吗?foo();如果是这样,我是否可以期望最先进的编译器避免第一个版本到第二个版本(在启用优化的情况下编译时)?换句话说,如果我使用NDEBUG编译这段代码并启用优化try{foo();}catch(...){assert(some_check());throw;}我可以假设这个丑陋的版本永远不会慢吗#ifndefNDEBUGtry{#endiffoo();#ifndefNDEBUG}catch(...){assert(some_check());throw;}#endif

c++ - 如何加快计算最长公共(public)子串的长度?

我有两个非常大的字符串,我想找出它们的LongestCommonSubstring.一种方法是使用后缀树(应该有很好的复杂性,虽然实现起来很复杂),另一种是动态规划方法(都提到了在上面链接的维基百科页面上)。使用动态规划问题在于动态规划方法运行时间巨大(复杂度为O(n*m),其中n和m是两个字符串的长度)。我想知道的(在跳转到实现后缀树之前):如果我只想知道公共(public)子串的长度(而不是公共(public)子串本身),是否可以加快算法速度? 最佳答案 这些将使它运行得更快,尽管它仍然是O(nm)。空间优化(这可能会为您节省一

c++ - const public 成员有什么问题?

我正在阅读一些代码,其中一个类具有私有(private)const数据成员,然后是一大堆提供对这些数据成员的只读访问的公共(public)方法。这有什么意义呢?为什么不直接公开这些私有(private)数据成员呢?它们是常量,因此根据定义访问是只读的,人们可以通过theClass.theMember而不是theClass.getTheMember()访问它们,后者更容易,另外您可以避免首先创建所有这些公共(public)方法。每个成员变量一个,这意味着O(n)效率低下! 最佳答案 除非访问器方法除了提供引用之外实际上还做了一些事情,

c++ - 访问公共(public)继承模板数据成员

这个问题在这里已经有了答案:WhydoIhavetoaccesstemplatebaseclassmembersthroughthethispointer?(3个答案)关闭2年前。我需要澄清为什么我们需要范围解析运算符或this指针来访问从模板基类公开继承的成员的问题。据我了解,这是为了增加清晰度,但是this除了指出它是该类的成员之外,如何进一步增加清晰度。为了让我的问题更清楚,我添加了一些代码。#includeusingnamespacestd;templateclassmypair{public:Ta,b;public:mypair(Tfirst,Tsecond){a=first

c++ - 公共(public)基类的派生类的 TypeID

我正试图在C++中实现某种机制,从而为从公共(public)基类派生的所有类分配一个唯一的“类ID”。例如:classBaseClass{//...public:unsignedintGetID(void);//...};classDerivedClass:publicBaseClass{}DerivedClass类和BaseClass的所有其他子类应该能够返回唯一标识符,而无需向DerivedClass添加任何额外代码……然而,C++使这对我来说相当困难。任何想法将不胜感激。提前致谢!---丹 最佳答案 你应该听听Alf的话:)这

c++ - C1001 : An internal error has occurred in the compiler

这应该是不言自明的。我正在尝试实现分布排序,但MSVC编译器崩溃了。这似乎是用我的SFINAE检测成员函数的特定情况,如果我不将indexert传递给函数,或者替换has_get_index,这似乎不会发生。如果我删除剩余的索引器重载中的任何一个,它也不会发生。如果sortable有一个getIndex()const成员,问题仍然存在。1>test.cpp(34):fatalerrorC1001:Aninternalerrorhasoccurredinthecompiler.1>(compilerfile'msc1.cpp',line1420)1>Toworkaroundthispro

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++ API 设计 : Clearing up public interface

对于我的库,我想公开一个干净的公共(public)API,它不会分散实现细节的注意力。但是,正如您所了解的那样,这些细节甚至会泄露到公共(public)领域:一些类具有有效的公共(public)方法,可供库的其余部分使用,但对API的用户来说不是很有用,因此不要不需要成为其中的一部分。公共(public)代码的简化示例:classCookie;classCookieJar{public:CookiegetCookie();}classCookieMonster{public:voidfeed(CookieJarcookieJar){while(isHungry()){cookieJar