草庐IT

atomic_int

全部标签

c++重载具有不同参数的3个函数(int,* int,& int)

所以我有这个作业要做“使用函数重载定义3个具有相同名称但具有不同prams类型(int、int*、int&)的函数,它们将返回值的平方根。”好吧,我做到了,但我不知道它给了我这个错误:“对重载函数的模糊调用”。我尝试修复它但没有成功......这是我的代码,它非常简单:#define_CRT_SECURE_NO_WARNINGS#include#includeusingnamespacestd;doublerad(int);doublerad(int*);doublerad(int&);intmain(){inta,*pt=&a;cin>>a;cout 最佳

力扣报错runtime error: load of null pointer of type ‘int‘解决思路

记录本算法小白刷力扣的这道题遇到的报错349.两个数组的交集https://leetcode.cn/problems/intersection-of-two-arrays/出现报错的代码 /***Note:Thereturnedarraymustbemalloced,assumecallercallsfree().*/int*intersection(int*nums1,intnums1Size,int*nums2,intnums2Size,int*returnSize){inthash[1000]={0};intresult[1000];//交集是去重的,最多只有1000个数for(inti

c++ - 将 long int 转换为 const time_t

我有变量tmit:longtmit;。我在这段代码中出错:printf("Time:%s",ctime(&tmit));错误说:无法将参数“1”的“longint*”转换为“consttime_t*{akaconstlonglongint*}”到“char*ctime(consttime_t*)”我的问题是,如果我想查看日期,如何在不丢失任何有关时间的信息的情况下将long转换为time_t或如何更改此代码。我正在研究这个answer,但我得到了错误。 最佳答案 一般情况下,您不能这样做,因为std::time_t之间不需要有任何合

从 const int* 到 int* 的 C++ 转换处理意外结果

这个问题在这里已经有了答案:whichpropertyofaconstantmakesitnotchangable?(3个答案)关闭6年前。在c++中,我们知道我们不能将constint*转换成int*。但是我有一个代码片段,我可以在其中将constint*转换为int*。我是C++的初学者,我用谷歌搜索了这个,但我只是得到提到constint*can'tbeconvertedintoint*toavoidconstviolation的链接。我无法弄清楚为什么它编译没有错误#includeusingnamespacestd;intmain(void){constinta1=40;con

c++ - 为什么编译器不断警告我从 `int` 缩小到 `uint8`?

我检查了一遍又一遍,我确定我没有将uint8转换为int隐含在我的代码中,既不向前也不向后。//main.cpp#includeusingstd::cout,std::endl;usinguint8=unsignedchar;structVector{uint8x,y,z;Vectoroperator+(constVector&v)const{returnVector{this->x+v.x,this->y+v.y,this->z+v.z};};voidoperator+=(constVector&);voidoperator-(constVector&)const;Vectorope

c++ - 将 BYTE 数组转换为 unsigned long long int

我正在尝试将BYTE数组转换为等效的unsignedlonglongint值,但我的编码没有按预期工作。请帮助修复它或建议替代方法。额外信息:这4个字节组合成一个十六进制数,输出一个等效的十进制数。假设一个给定的byteArray={0x00,0xa8,0x4f,0x00},十六进制数是00a84f00,它等效的十进制数是11030272。#include#includetypedefunsignedcharBYTE;intmain(intargc,char*argv[]){BYTEbyteArray[4]={0x00,0x08,0x00,0x00};std::stringstr(re

c++ - std::atomic 如何保证原子性

如果我有密码a=a+1,现在我明白执行此操作需要多个CPU级别的操作,但是如何定义a作为std::atomic使这些多个事务成为原子?它是否改变了CPU指令的执行方式。我假设它必须以某种方式将指令数减少到1,这样任何上下文切换都不会导致不可靠的结果,但它是如何做到的呢?如果编译器总是可以创建这样的代码,为什么不总是这样做呢? 最佳答案 如果有原子指令可以发出(对于已知可能的原子操作),则发出这条原子指令,否则会带锁机制。有一个函数(C++17)可以告诉您原子类型是否始终是无锁的:is_always_lock_free.请注意,如果此

c++ - 如果 `atomic<T>` 是无锁的并且大小与 `T` 相同,内存布局是否相同?

Thisquestionhere表示std::atomic通常应该与T具有相同的大小,而对于x86、x64和ARM上的gcc、clang和msvc,情况确实如此。在std::atomic的实现中对于某些类型总是无锁T,它的内存布局是否保证与T的内存布局相同??std::atomic是否有任何额外的特殊要求?,比如对齐? 最佳答案 在查看[atomics.types.generic]时,您链接的答案部分引用了该答案,关于对齐的唯一评论是您之前看到的注释:Note:Therepresentationofanatomicspecializ

c++ - c++中int的ostringstream问题

我希望下面的代码输出hello5。相反,它只输出hello。尝试将int输出到ostringstream似乎是个问题。当我将相同的内容直接输出到cout时,我收到了预期的输入。在SnowLeopard上使用XCode3.2。谢谢!#include#include#includeusingnamespacestd;intmain(){intmyint=5;stringmystr="hello";stringfinalstr;ostringstreamoss;oss编辑:请参阅我在下面发布的答案。这似乎是由SnowLeopard上的XCode3.2中的事件配置“调试”中的问题造成的

c++ - 缺少关于 "int main(int argc, char* argv[])"的知识

我是一名物理学家,通常我只想完成计算,这就是我真正需要的。不过我一直在用intmain(intargc,char*argv[])非常令人高兴的是二进制文件在我没想到的级别上变得灵活,即初始化变量~$./program.exeabc(a,bandcarenumbersinthiscase,notlettersok?)所以问题是*如何在不使用文件的情况下以这种方式(或其他方式)“解析”或“传输”事物?*示例:假设“a.exe”给出了一组“X-Y”点(就像在电子表格上一样),我要将其插入“b.exe”。或者说我使用bash/awk脚本来格式化“a.exe”的输出格式,以便在gnuplot上绘