草庐IT

ordering_chars

全部标签

c++ - 当我从 char[] 转到 string 时,为什么我的冒号字符消失了?

在我正在处理的旧Windows应用程序中,我需要从环境变量获取路径,然后附加到它以构建文件路径。所以代码看起来像这样:staticstd::stringPathRoot;//Privatevariablestoredinclass'headerfilecharEnvVarValue[1024];if(!GetEnvironmentVariable(L"ENV_ROOT",(LPWSTR)EnvVarValue,1024)){coutENV_ROOT的环境值在Windows系统控制面板中设置为“c:\RootDir”。但是当我运行程序时,我总是以FullFilePath中的字符串结尾,该

c++ - char* 与先前指令中设置的值的比较未优化?

在摆弄一些测试代码时,我在以下代码中观察到:externchar*pc;intmuysimple(){*pc=0;if(*pc!=0){return1111;}return4444;}比较没有被我在godbolt上选择的任何编译器优化掉.如果我将externchar*更改为externint*,比较将被优化掉。为什么gcc和clang都保留对char的比较,即使这段代码中似乎没有任何内容可以合法地更改值以使比较的计算结果为真?语言规范中是否有任何内容禁止通过char*进行写入/读取优化(但允许优化int*!)还是优化器只是对char更加保守?正如评论中已经提到的那样:我不明白--明智的

c++ - 在 C++ 中比较 char

这是我从中获取数据的文本文件10wood8gold7silver5gold9wood1silver1silver9wood3gold5wood7我应该找到具有相同名称的商品并将它们的所有数量相加,所以最终结果应该是wood=19;黄金=21;白银=15。这是我到目前为止所做的#include#includeusingnamespacestd;intmain(){ifstreamread("data.txt");intn;read>>n;charname[10][n];//10symbolsaregivenforitemsnameintamount[n];for(inti=0;i>amo

c++ - 用于取消标志的 std::atomic_bool:std::memory_order_relaxed 是正确的内存顺序吗?

我有一个从套接字读取并生成数据的线程。每次操作后,线程都会检查一个std::atomic_bool标志以确定它是否必须提前退出。为了取消操作,我将取消标志设置为true,然后在工作线程对象上调用join()。线程和取消函数的代码如下所示:std::threadwork_thread;std::atomic_boolcancel_requested{false};voidthread_func(){while(!cancel_requested.load(std::memory_order_relaxed))process_next_element();}voidcancel(){can

c++ - 在没有 USES_CONVERSTION 的情况下从 const char * 转换为 LPTSTR

我正在尝试将constchar*转换为LPTSTR。但我不想使用USES_CONVERSION来执行它。以下是我使用USES_CONVERSION进行转换的代码。有没有办法使用sprintf或tcscpy等进行转换?USES_CONVERSION;jstringJavaStringVal=(somevaluepassedfromotherfunction);constchar*constCharStr=env->GetStringUTFChars(JavaStringVal,0);LPTSTRlpwstrVal=CA2T(constCharStr);//Idonotwanttouset

c++ - 我如何将 uint32_t 转换为 char* 类型

你好,我正在使用带有adafruitshield的ArduinoUNO来显示分数,但用于显示分数的函数只接受char*值,分数本身最多可以占用6位数字(000,000到999,999)。我试过使用sprint()但我没有运气,因为屏幕会像疯了一样闪烁。我认为问题在于chars只包含一定数量的字节,不能容纳32位int,但我认为它们是解决这个问题的方法。绘制文本是盾牌用来在屏幕上绘制内容的函数,输入为char*、颜色代码、大小、x像素、y像素。如果有人可以帮我在这两种类型之间进行转换,请告诉我。如果他们是替代品,也会对我有帮助。我的代码:char*textToWrite;uint32_t

c++ - 将 char* 转换为 uint8_t

我通过CAN协议(protocol)传输消息。为此,CAN报文需要uint8_t类型的数据。所以我需要将我的char*转换为uint8_t。通过我对该站点的研究,我生成了以下代码:char*bufferSlidePressure=ui->canDataModifiableTableWidget->item(6,3)->text().toUtf8().data();//Mychar*/*Conversion*/uint8_tslidePressure[8];sscanf(bufferSlidePressure,"%c",&slidePressure[0]);如您所见,我的char*必须适

带有 char 数组的 C++ 结构以不寻常的方式初始化为零

遇到一段不常见的c++初始化代码,似乎可以很好地处理以下...structsfoobar{charbar[10];charfoo[10];};...sfoobarx{0};这是将这些字符数组初始化为零的可接受方法吗? 最佳答案 这在C++中有效。作为效果sfoobarx{0};会将x.bar和x.foo的所有元素初始化为0.根据aggregateinitialization的规则,嵌套初始化列表的大括号可以省略,thebracesaroundthenestedinitializerlistsmaybeelided(omitted),

c++ - 多线程程序中的 std::atomic<int> memory_order_relaxed VS volatile sig_atomic_t

volatilesig_atomic_t是否提供任何内存顺序保证?例如。如果我只需要加载/存储一个整数,可以使用吗?例如这里:volatilesig_atomic_tx=0;...voidf(){std::threadt([&]{x=1;});while(x!=1){/*waiting...*/}//done!}这是正确的代码吗?在某些情况下它可能不起作用?注意:这是一个过度简化的示例,即我不是在为给定的代码片段寻找更好的解决方案。我只想了解在根据C++标准的多线程程序中,我可以从volatilesig_atomic_t中得到什么样的行为。或者,如果是这种情况,请理解行为未定义的原因。

C++ - 错误 E2285 : Could not find a match for 'tolower(char *)' in function parseInput(fstream &)

给定以下代码:voidparseInput(fstream&inputFile){constintLENGTH=81;charline[LENGTH];while(!inputFile.fail()){inputFile.getline(line,LENGTH);line=tolower(line);cout编译时出现这个错误:ErrorE2285:Couldnotfindamatchfor'tolower(char*)'infunctionparseInput(fstream&)我知道它返回一个int,而不是int[],这是否意味着我不应该使用getline而应该将输入字符转换为字符