草庐IT

shared_int

全部标签

c++ - 没有上下文类型信息的重载函数 |无法根据转换为类型 'swap' 解析重载函数 'int'

我正在尝试编写自己的冒泡排序算法作为练习。我不明白这两个错误消息。谁能指出我的代码的问题?//Bubblesortalgorithm#include#includeusingnamespacestd;voidbubbleSort(intarray[],intarraySize);//bubbleSortprototypeintmain(void){constintarraySize=10;intarray[arraySize]={2,3,6,5,7,8,9,3,7,4};coutarray[i+1]){swap=array[i+1];array[i+1]=array[i];array[

c++ - 将 time_t 转换为 int

我想将给定时间转换为epoch(time_t),反之亦然。谁能告诉我这是什么例程或算法?谢谢更新epoch_strt.tm_sec=0;epoch_strt.tm_min=0;epoch_strt.tm_hour=0;epoch_strt.tm_mday=1;epoch_strt.tm_mon=1;epoch_strt.tm_year=70;epoch_strt.tm_isdst=-1;doublensecs=difftime(curtime,basetime);//currenttimefromsystem,Iconverrtingittostructtm但出于某种原因,这总是返回3

c++ - if((int val = getvalue()) == x) 表格是否应该工作

此表单无法使用我的VS2008编译器进行编译。应该可以吗?#includeusingnamespacestd;intgetvalue(){return3;}intmain(intargc,char*argv[]){if((intval=getvalue())==3)cout这个表格确实有效。...intval;if((val=getvalue())==3)...为什么不起作用? 最佳答案 这是不合法的,因为你不能将语句用作表达式。因此,不是在if中声明变量是非法的,而是比较。就像:(intx=3)==3;是非法的,而intx=3;x

c++ - const boost::shared_ptr<T>& 作为函数参数的目的?

我正在使用某个大型且维护良好的开源C++库,并遇到了一个具有以下形式的构造函数的类定义classSomeClass{SomeClass(constboost::shared_ptr&);}我的问题是:传递constboost::shared_ptr有什么意义?引用?传递boost::shared_ptr是否真的存在不可忽略的开销?按值(value)计算,或者传递boost::shared_ptr是否存在其他危险?按我不知道的值(value)? 最佳答案 按值传递将复制它,这会导致引用计数增加,并在所有线程之间同步。绝对不可忽略。

C++ stringstream >> int 返回零

我正在编写一个函数来返回数字的反转,即将int(1234)转换为int(4321)。这是我目前拥有的:#include#include#include#includeusingnamespacestd;intreverse(intnum){stringstreamss(stringstream::in|stringstream::out);stringinitial;intreversed;//readthenumberintoastringstreamss>reversed;returnreversed;}intmain(intargc,constchar*argv[]){intte

c++ - 当基类和派生类都继承自 boost::enable_shared_from_this 时出现错误的弱指针

我有一个派生自boost::enable_shared_from_this的基类,然后是另一个派生自基类和boost::enable_shared_from_this的类:#include#includeusingnamespaceboost;classA:publicenable_shared_from_this{};classB:publicA,publicenable_shared_from_this{public:usingenable_shared_from_this::shared_from_this;};intmain(){shared_ptrb=shared_ptr(n

c++ - Qt raw 与 std::shared_ptr

我注意到当在QT中用shared_ptr替换原始指针时,我的代码不再起作用。例如,如果不是QTreeWidgetItem*vItem(newQTreeWidgetItem(ItemTitle));我用std::shared_ptrvItem(newQTreeWidgetItem(ItemTitle));然后,要么程序崩溃,要么什么都没做(即使我使用.get()函数来获取来self代码后面共享的原始指针)。有谁知道可能是什么原因? 最佳答案 对Qt模型项使用共享指针会导致所有权冲突:QTreeWidget获取您传递给它的任何QTree

c++ - 使用 strdup() 后将 char* 转换为 int

为什么在使用strdup(value)(int)value后返回与之前不同的输出?如何获得相同的输出?我的简短示例出错了,请使用长示例:这里是完整的测试代码:#include#includeintmain(){//TheFirstPartchar*c="ARD-642564";char*ca="ARD-642564";std::cout>x;} 最佳答案 因为在您的情况下数组衰减为指针,所以您正在打印一个指针(即,在非奇异计算机上,一个内存地址)。不能保证指针适合int。在代码的第一部分,c和ca不必相等。您的编译器执行某种内存优化

c++ - C++11 是否强制要求 vector<int> 将 resize() 中的元素归零?

这个问题在这里已经有了答案:std::vector,defaultconstruction,C++11andbreakingchanges(2个答案)关闭9年前。这个问题是关于new[]int和new[]int()在语义和性能上的差异,以及在向allocator_traits::construct添加ctor参数的完美转发时可能无意中创建的从第一个到第二个措辞的变化().这个问题不涉及一个非常明显的问题,即默认ctor运行在由vector的resize()构造的所有新元素上。对我来说,在调整大小时清除内置类型vector的元素似乎是一种浪费。但是VS2012的实现使得resize(n)

c++ - 为什么 C++ 不将 INT_MIN 定义为 (1<<31)

我理解C++将INT_MIN定义为(-2147483647-1)的原因,但他们为什么不直接使用1 最佳答案 Thatpreventtheoverflowandalsoeasytounderstand如果通过左移一个正数试图得到一个负数,它如何防止溢出?;)请记住,有符号整数溢出是未定义行为。根据C++11标准的第5.8/2段:ThevalueofE1isE1left-shiftedE2bitpositions;vacatedbitsarezero-filled.[...]Otherwise,ifE1hasasignedtypeand