草庐IT

unsigned-char

全部标签

c++ - 隐式转换将符号 'int"更改为 'unsigned int"

我正在使用clang++编译程序,我需要在clang++中正确编译它。我在其他编译器上没有错误。代码中的错误行是memset(grid_,0,sizeof(int)*x_quadrants*y_quadrants);整个函数是这样的:Ocean::Ocean(intnum_boats,intx_quadrants,inty_quadrants){grid_=newint[x_quadrants*y_quadrants];memset(grid_,0,sizeof(int)*x_quadrants*y_quadrants);x_quadrants_=x_quadrants;y_quadr

c++ - 为什么这个编译器错误? - 没有匹配函数调用 'std::basic_ofstream<char>::open(std::string&)'

这适用于VisualStudio,并且适用于一台计算机上的GCC4.9.2。但在不同的计算机上,我认为它是相同的GCC4.9.2编译器,但它给了我这个错误。我错过了什么吗?怎么回事?#include#include#includeusingnamespacestd;intmain(){stringfilename;filename="teststring";ofstreamfout;fout.open(filename);fout.||===Build:Debuginfileiotest(compiler:TDM32GNUGCCCompiler4.9.2dw2)===|F:\Users

c++ - std::string 与静态常量的 char 数组

我想在我的cpp文件中的多个位置使用字符串常量。我应该使用std::string还是char[]?staticconststd::stringkConstantString="ConstantStringValue";staticconstcharkConstantString[]="ConstantStringValue";有人告诉我更喜欢后者,因为它“避免了静态分配”。char数组不是也必须静态分配吗? 最佳答案 是的,是的,它也必须静态分配。总是使用std::string除非你的探查器告诉你它值得惹恼像constchar[]这

c++ - 如何通过 unsigned long 将 std::shared_ptr 传递给回调?

我有一个旧的C风格库,它使用带有unsignedlong作为用户参数的回调,我想将我的shared_ptr传递给回调,以便增加引用计数。voidcallback(unsignedlongarg){std::shared_ptrptr=???arg???}voidstarter_function(){std::shared_ptrptr=std::make_shared();unsignedlongarg=???ptr???//passtolibrarysoitmaybeusedbycallback}目前我在shared_ptr上使用get(),然后使用C风格的强制转换,但这会在star

c++ - 对于具有 char[] 的结构,浅拷贝是否足够?

我有一个包含字符数组的结构,没有任何其他成员函数。我正在这些结构的两个实例之间进行赋值操作。如果我没记错的话,它正在做浅拷贝。在这种情况下浅拷贝安全吗?我已经在C++中尝试过它并且它有效,但我只想确认这种行为是否安全。 最佳答案 如果通过“浅拷贝”,你的意思是在分配一个包含数组的struct之后,该数组将指向原始struct的数据,然后:它不能。数组的每个元素都必须复制到新的struct中。如果你的结构有指针,“浅拷贝”就会出现。否则,您不能进行浅拷贝。当您将包含数组的struct分配给某个值时,它不能进行浅拷贝,因为这意味着分配给

c++ - 测试 char* 字符串是否包含多字节字符

我从TCP服务器接收到一个字节流缓冲区,其中可能包含形成unicode字符的多字节字符。我想知道是否总有一种方法可以检查BOM以检测这些字符,否则您想怎么做? 最佳答案 如果你知道数据是UTF-8,那么你只需要检查高位:0xxxxxxx=单字节ASCII字符1xxxxxxx=多字节字符的一部分或者,如果您需要区分前导/尾部字节:10xxxxxx=多字节字符的第二个、第三个或第四个字节110xxxxx=2字节字符的第一个字节1110xxxx=3字节字符的第一个字节11110xxx=4字节字符的第一个字节

c++ - 如何从 unsigned long 转换为 void*?

我正在尝试在具有给定文件描述符的文件的某个偏移处pwrite一些数据。我的数据存储在两个vector中。一个包含unsignedlong和其他char。我想构建一个void*指向代表我的unsignedlong和char的位序列,并将它传递给pwrite以及累积大小。但是如何将unsignedlong转换为void*?(我想我可以找出字符)。这是我正在尝试做的事情:voidwriteBlock(intfd,intblockSize,unsignedlongoffset){void*buf=malloc(blockSize);//hereIshouldbetryingtobuildbuf

c++ - std::string 真的包装了一个 C char 数组吗?

我一直认为std::string是作为C字符数组字符串的STL包装器实现的。但是仔细观察这个设计,我注意到它没有给出任何暗示或迹象表明它是一个包裹起来的C弦。据我所知,std::string可以在内部做任何事情!当然有c_str()方法,我认为它返回了内部字符数组,但我怎么知道该方法是否没有创建一个新cchar数组从它存储在里面的任何数据并返回它?说真的,std::string是如何实现的?它(看起来)只是Cchar数组的包装器,还是其他东西?还是两者的混合?或者甚至可以有条件地成为两者? 最佳答案 ForallIknowanstd

c++ - 将 -1 分配给 unsigned int 以获得最大值是否安全?

如果我需要获取最大值,将-1分配给无符号整数或其他无符号C++数据类型是否安全?是否存在无法提供无符号数据类型可包含的最高值的情况? 最佳答案 为了安全起见,请使用std::numeric_limits::max().将-1转换为unsigned可以在主流平台上运行,但标准AFAIR不能保证。UPD:我会纠正自己。(unsigned)-1在C中必须是UINT_MAX,参见答案here 关于c++-将-1分配给unsignedint以获得最大值是否安全?,我们在StackOverflow上

C++ char 单引号与双引号和内存内部工作原理

我想知道程序在运行时在内存方面做了什么,因为它遇到以下情况:charchr='a';charchrS[]="a";cout这会产生以下内容:Address:a�c�3�Address:0x7fff33936280为什么获取不到“chr”的内存地址? 最佳答案 因为&chr产生char*(此处隐式添加const)和cout假定它是一个字符串,因此以null结尾,但事实并非如此。然而,&chrS产生char(*)[],它不会衰减到constchar*因此将通过operator输出重载,打印地址。如果您想要constchar*的这种行为您