草庐IT

c++ - 从 ‘const char*’ 到 ‘char’ 的无效转换

我正在尝试使用以下代码行将字符串中的某个字符替换为空格:str[i]="";如何在没有问题标题错误的情况下实现这一点? 最佳答案 使用单引号str[i]='';在C++中,标记""是一个字符串文字,表示两个字符的数组:字符集中的空格值(例如,ascii中的值32)和零.另一方面,标记''表示具有空格值(通常为32)的单个字符。请注意,在C语言中,标记''表示具有空格值的整数。(在C中,sizeof''==sizeof(int),而在C++中,sizeof''==sizeof(char)==1。)

c++ - std::string 或 std::vector<char> 保存原始数据

我希望这个问题适用于stackoverflow...将原始数据字节(8位)存储在std::string中有什么区别?而不是将它们存储在std::vector中.我正在从文件中读取二进制数据并将这些原始字节存储在std::string中.这很好用,这样做没有问题。我的程序按预期工作。但是,其他程序员更喜欢std::vector方法并建议我停止使用std::string因为它对原始字节不安全。所以我想知道为什么使用std::string可能不安全保存原始数据字节?我知道std::string最常用于存储ASCII文本,但是一个字节就是一个字节,所以我不明白std::vector的偏好.感谢

c++ - 如何将 float 转换为长度为 4 的字节数组(char* 数组)?

如何将float转换为长度为4的字节数组(char*数组)?我需要通过网络发送一些数据、tcp,并且需要将float作为字节数组发送。(我知道两位小数的精度,所以目前我在客户端乘以100,在服务器端除以100-基本上转换为整数,然后使用&0xff 最佳答案 将任何类型作为字节序列读取非常简单:floatf=0.5f;unsignedcharconst*p=reinterpret_cast(&f);for(std::size_ti=0;i!=sizeof(float);++i){std::printf("Thebyte#%zuis0x

c++ - 如何将 ASCII char 转换为其 ASCII int 值?

我想将一个字符转换成它的ASCII整数值。我可以用所有可能的值填充一个数组并与之比较,但我觉得这不对。我想要类似的东西charmychar="k"publicintASCItranslate(charc)returncASCItranslate(k)//>>Shouldreturn107asthatistheASCIIvalueof'k'.重点是atoi()在这里不起作用,因为它仅用于可读数字。它不会处理空格(ASCII32)。 最佳答案 只需这样做:int(k)这里只是将char直接转换为int,不需要函数调用。

c++ - 不允许从 'const char *' 到 'void *' 的 static_cast

在C++中,我试图打印C字符串的地址,但我的转换似乎存在一些问题。我从一本书中复制了代码,但它无法在我的Mac上编译。constchar*constword="hello";cout(word) 最佳答案 你正试图抛弃“常量”:word指向常量数据,但static_cast的结果不是指向常量数据的指针。static_cast不会让你那样做的。你应该使用static_cast相反。 关于c++-不允许从'constchar*'到'void*'的static_cast,我们在StackOve

c++ - 从 char* 缓冲区读取 int32_t 的惯用 cpp14 方法是什么?

给定一个包含int(小端)的字符缓冲区c。如何读作int32_t?我写了这段代码,但感觉不符合cpp的习惯。int32_tv;char*p=(char*)&v;for(inti=0;i 最佳答案 将binary数据从char*缓冲区复制到任何其他数据类型的唯一可移植方法是使用memcpy(或等效字节-copyingmerhodsuchasstd::copy或你自己的模仿这种行为的方法)。memcpy(&my_number,my_buffer,sizeof(my_number));当然,缓冲区应该包含给定数据类型的正确位。如果它源于在

c++ - 从 ‘void*’ 到 ‘unsigned char*’ 的无效转换

我有以下代码;void*buffer=operatornew(100);unsignedchar*etherhead=buffer;我在尝试编译时收到该行的以下错误;error:invalidconversionfrom‘void*’to‘unsignedchar*’为什么我会收到这个错误,我认为void是“无类型”的,所以它可以指向任何东西,或者任何东西都可以指向它? 最佳答案 您需要进行转换,因为如果不先进行转换,您无法将void*转换为任何内容。你需要做的unsignedchar*etherhead=(unsignedchar

c++ - 将 QByteArray 转换为 std::vector<unsigned char>

我尝试转换QByteArray至std::vector使用此代码:unsignedchar*buffer=(unsignedchar*)byteArrayBuffer.constData();std::vector::size_typesize=strlen((constchar*)buffer);std::vectorbufferToCompress(buffer,buffer+size);但是,假设byteArrayBuffer是QByteArray充满了数据,我认为它在线上效果不佳unsignedchar*buffer=(unsignedchar*)byteArrayBuffer

c++ - 无法修改 char* - 内存访问冲突

为什么说“内存访问冲突”?char*str="HelloGuys";intlen=strlen(str);for(inti=0;i 最佳答案 字符串文字存储在内存的只读部分。任何修改字符串文字内容的尝试都会调用未定义行为(大多数实现中的段错误)。而是使用字符数组charstr[]="HelloGuys"; 关于c++-无法修改char*-内存访问冲突,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/q

c++ - 如果图像文件的内容在 char 数组中,如何使用 cv::imdecode?

我在缓冲区jpegBuffer中有一个jpeg图像。我试图将它传递给cv::imdecode函数:MatmatrixJprg=imdecode(Mat(jpegBuffer),1);我收到这个错误:/home/richard/Desktop/richard/client/src/main.cc:108:error:nomatchingfunctionforcallto‘cv::Mat::Mat(char*&)’这是我填充jpegBuffer的方式:FILE*pFile;longlSize;char*jpegBuffer;pFile=fopen("img.jpg","rb");if(pF