草庐IT

char_set

全部标签

c++ - 强制在堆栈中而不是全局分配 char[] (string)

我试图强制编译器在堆栈中分配内联字符串:此代码分配.rdata部分中的字符串:foo("test");当这段代码在栈中分配字符串时:charszt1[]="test1";foo(szt1);这正是我想要强制执行的。如何强制编译始终在堆栈中分配数组?我正在使用gcc。谢谢 最佳答案 没有好的方法可以做到这一点,而且可能没有太多好的理由需要这种行为。如果您不希望该字符串存在于数据段中,最接近的做法是分配一个char的自动数组并将字符分配给它,一次一个。charhello[6]={};hello[0]='h';hello[1]='e';h

c++ - 为什么使用reinterpret_cast 将char* 转换为结构似乎可以正常工作?

人们说相信reinterpret_cast将原始数据(如char*)转换为结构是不好的。例如,对于结构structA{unsignedinta;unsignedintb;unsignedcharc;unsignedintd;};sizeof(A)=16和__alignof(A)=4,完全符合预期。假设我这样做:char*data=newchar[sizeof(A)+1];A*ptr=reinterpret_cast(data+1);//+1istoensureitdoesn'tpointsto4-bytealigneddata然后复制一些数据到ptr:memcpy_s(sh,sizeo

Redis 数据类型及其常用命令一(string、list、set、zset、hash)

1、简介    Redis的常用数据类型有十种,分别为:string、list、set、zset、hash、geo、hyperloglog、bitmap、bitfield、stream。熟练使用各种数据类型,能够快速结合场景进行使用。注:我们所说的数据类型是指value的数据类型,key都是字符串。所有类型的命令查看:help@数据类型;例如help@string2、Redis的key常用命令#1、查看当前库所有keykeys*#2、判断某个key是否存在existskey#3、查看key的类型是什么typekey#4、删除指定的key,会发生阻塞delkey#5、非阻塞删除,仅仅将key从k

c++ - 为什么 static const char * template struct 成员没有初始化

我有一些C++11模板代码,我正在尝试移植到VisualC++Compiler2015。原始代码工作得很好,但是我需要重写它以解决constexpr的问题。Theoriginalcode(simplifiedexample)#includestructString{staticconstexprconstchar*value{"STRING"};};templateclassDerived{public:staticconstexprconstchar*value{Base::value};};templatestructFoo{staticconstexprconstchar*val

c++ - boost::lexical_cast<signed char> 无法处理负数?

这个简短的C++程序的行为方式让我感到困惑:#include#include#include#includeintmain(void){signedcharc=-2;assert(c==-2);c=boost::lexical_cast(std::string("-2"));std::cout使用g++5.2.1和boost-1.58.0,我得到:terminatecalledafterthrowinganinstanceof'boost::exception_detail::clone_impl>'what():badlexicalcast:sourcetypevaluecouldn

c++ - 遍历 unordered_set 的效率如何?

遍历unordered_set是否需要查看哈希表的每个桶?如果是这样,那不是很低效吗?如果我想频繁迭代一个集合但仍然需要在O(1)时间内删除,unordered_set仍然是最好的数据结构吗? 最佳答案 碰巧,std::unordered:set的常见实现将所有元素链接在一起,就像std::forward_list所做的那样,因此遍历容器基本上是等价的遍历列表(详情here)。在任何情况下,如有疑问,请分析您的程序并查看结果是否满足您的需求。 关于c++-遍历unordered_set的

python - 如何将 char 指针从 python 传递给 C++ API?

我正在尝试从我的python代码中调用以下C++方法:TESS_APITessResultRenderer*TESS_CALLTessTextRendererCreate(constchar*outputbase){returnnewTessTextRenderer(outputbase);}我对如何将指针传递给方法有困难:遵循正确的方法吗?textRenderer=self.tesseract.TessTextRendererCreate(ctypes.c_char)或者我应该这样做:outputbase=ctypes.c_char*512textRenderer=self.tess

c++ - cout 是否保证有 ctype<char> 刻面?

给定:autofoo="ABCDEFGHIJKLMNOPQRSTUVWXYZ"s我可以通过以下方式将所有字符转换为小写:use_facet>(cout.getloc()).tolower(data(foo),next(data(foo),foo.size()));LiveExample但这取决于cout.getloc()包含ctypefacet.假设我使用的是未修改的cout我可以假设cout.getloc()将包含facetctype还是我需要在使用前确认这一点:has_facet>(cout.getloc()) 最佳答案 来自c

c++ - 指向 char 数组的整数指针

我正在开发一个应用程序(visualstudio上的C++语言),其中所有字符串都使用整数指针引用。例如,我正在使用的类有一个指向数据的整数指针和一个大小变量。{....unsignedshortint*pData;intiLen}我想知道使用int指针代替char指针有什么优势吗?经过深思熟虑,我怀疑原因可能是为了避免在没有空终止的情况下使用char指针可能发生的应用程序崩溃。但我不是100%确定。在调试过程中,我们如何检查指针的内容,其中内容是字符数组或字符串(在VisualStudio上)。调试时查看内容只能看到地址。因此,我在调试时遇到了困难。使用printf可以显示内容,但我

c++ - C++ 标准是否为 unordered_set 定义了桶的结构?

当计算出unordered_set中某个元素的哈希值时,它会与其他不同但哈希值相同的元素一起放入“桶”中。我的经验是,这样一个桶中的元素是存储在一个单向链表中的。这意味着,在哈希函数不佳的存储桶内搜索时,它会变得非常慢。单向链表是标准的要求还是只是一种可能的实现方式?可以用set作为桶来实现unordered_set吗? 最佳答案 标准规定了要求和保证,但没有明确强制底层数据结构和算法。N4140§23.2.5[unord.req]/1Unorderedassociativecontainersprovideanabilityfor