草庐IT

char16-t

全部标签

c++ - 在 C++11 标准中哪里说 char* p = "abc";是病态的?

在C++11标准中哪里说char*p="abc";格式错误? 最佳答案 这在C++03中仍然有效(尽管已弃用),但在C++11中情况发生了变化。C++11标准的附件C提到(参见C1.1):Change:StringliteralsmadeconstThetypeofastringliteralischangedfrom“arrayofchar”to“arrayofconstchar.”Thetypeofachar16_tstringliteralischangedfrom“arrayofsome-integer-type”to“ar

c++ - 如何从 vector<char> 复制一个整数

我现在正在处理wav文件,我正在尝试解析它们。我暂时不想使用图书馆。我用fstream打开wav文件并将所有数据读取到vector。现在我想解析wav文件头。例如,我想获取第4到第8个字节之间的文件大小。我想将其分配给一个整数。我会用memcpy轻松完成此操作。但是因为它是C++,所以我不想使用memcpy。我最终得到的解决方案:std::vector::iteratorvectorIte=soundFileDataVec.begin();vawParams.totalfilesize=0;//SinceitislittleendianIusedreverse_copystd::rev

c++ - 使用基于范围的 For 循环和 Char 指针字符串

这个问题在这里已经有了答案:Rangebasedforloopsonnullterminatedstrings(3个答案)关闭9年前。我是C++11的新手,坦率地说,我已经一年多没用过C++,所以一开始我有点生疏。我正在根据旧的大学教科书做一些练习,在尝试迭代char指针字符串时遇到了问题(例如:char*c="astring";)。我在谷歌上找不到任何有用的东西。我已经习惯了Java,其中foreach循环可以遍历任何集合。我知道指针是如何工作的,但是我从C++休假让我对实际使用它们的语法一无所知。谁能告诉我为什么以下代码(特别是convert()函数)会导致编译错误,其中“开始”和

c++ - 将 16 位立体声转换为 16 位单声道

我正在尝试将16位立体声从WAVE文件转换为16位单声道,但我遇到了一些困难。我尝试将8位立体声转换为单声道,效果很好。这是一段代码:if(bitsPerSample==8){dataSize/=2;openALFormat=AL_FORMAT_MONO8;for(SizeTypei=0;i((static_cast(pData[i*2])+static_cast(pData[i*2+1]))/2);}但是,现在我正尝试对16位音频做几乎相同的事情,但我就是无法让它工作。我只能听到某种奇怪的声音。我尝试将“monoSample”设置为“left”(Uint16monoSample=le

c++ - 如何将 unsigned char 数组转换为 unsigned long long?

假设我有8个unsignedchar,我想将其转换为unsignedlonglong。例如,如果所有char都等于0xFF,则unsignedlonglong将等于0xFFFFFFFFFFFFFFFF。使用C或C++最有效的方法是什么? 最佳答案 例如:unsignedcharbuffer[8]={0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF};unsignedlonglongtarget;memcpy(&target,buffer,sizeoftarget);请注意,如果buffer的所有元素并非

c++ - 奇怪的错误 char 的加密 (ascii)

这是一个简单的代码,但我无法理解一个奇怪的事件。代码:voidCrittografia::CifraTesto(chartext[]){inti;for(i=0;i'z'){text[i]=text[i]-26;}}}函数接收此处输入的字符串:Itworks.在这种情况下,它使用key5。“y”在“d”中正确更改。但在这种情况下:Doesn'twork.键值为7时,它会更改'Ç'中的'y'而不是正确的'f',因此显然不会执行该行:“text[i]=text[i]-26;” 最佳答案 text[i]=text[i]+key;当key为

c++ - __declspec(align(16)) 不将指针对齐到 16 个字节

所以我正在尝试使用SSE函数__mm_load_128,我是SSE的新手,如果我在某处犯了一些愚蠢的错误,请原谅我。这是代码voidone(__m128i*arr,char*temp){//SSEneeds16bytealignment._declspec(align(16))__m128i*tmp=(__m128i*)temp;if(((uintptr_t)tmp&15)==0)printf("Alignedpointer");elseprintf("%d",((uintptr_t)tmp&15));//Thisprintsas12arr[0]=_mm_load_si128(tmp)

c++ - 防止不同数据类型的重复代码 (uint16_t/uint32_t)

我正在寻找使用函数的可能性,我将指针传递给uint16_t或uint32_t值。目前我使用的是两个重载函数std::vectorcalcMap(uint16_t*map)std::vectorcalcMap(uint32_t*map)由于它们返回浮点值,因此对于16位和32位值的计算是相同的。唯一的区别是通过指向的数组所需的数据类型。我不想两次拥有函数的全部内容,是否有可能使其与类型无关? 最佳答案 主要是为了完整性:以防您不想公开函数的实现,并且出于任何原因不想转发到私有(private)模板。有一个经常被忽视的显式模板实例化声明

c++ - 为什么在将 short[] 转换为 char* 时数组会反转?

对于下面的代码:shortshortArray[]={('B'输出是:ABCDEFG有人可以向我解释一下这是如何工作的吗? 最佳答案 表达式('B'结果类型为int,将等于'B'*256+'A'.当转换为short时(假设short表示为两个8位字节)此值由字节对AB表示,其中A是最低有效字节。在小端机器上,最低有效字节最先出现在内存中(即'A'在最左边,下一个字节是'B')。在大端机器上,'B'将在最左边。您描述的输出表明您的主机架构是小端架构。英特尔处理器都是小端。从历史上看,包括Motorola68000系列处理器、Power

c++ - 二进制表达式 ('const char*' 和 'const char *' 的无效操作数)

这个问题在这里已经有了答案:Can'taddstringsinC++(7个答案)关闭4年前。我想用简单的语言知道这个错误的原因。#include#includeintmain(){std::stringexclam="!";std::stringmessage="Hello"+",world"+exclam;std::couttest.cpp:55:35:error:invalidoperandstobinaryexpression('constchar*'and'constchar*')std::stringmessage="Hello"+",world"+exclam;