草庐IT

const_cast-ing

全部标签

c++ chrono duration_cast 到毫秒结果以秒为单位

我想要自纪元以来的毫秒数。一个流行的解决方案如下所示(这里提出的这个问题的解决方案之一Gettimesinceepochinmilliseconds,preferablyusingC++11chrono)#include#includeintmain(){automillitime=std::chrono::duration_cast(std::chrono::system_clock::now().time_since_epoch()).count();std::cout通过调用g++来编译它,比如g++-std=c++11main.cpp-otimetest产生输出13726860

c++ - C++ : why does free not accept a const void*, 中的 malloc/free 有更好的方法吗?

这个问题在这里已经有了答案:UnabletofreeconstpointersinC(12个答案)关闭8年前。将C++11代码连接到某些C回调,我必须传递constchar*const*,即字符串数组。这是我的代码的简化版本:intmain(int,char**){constintcnt=10;constchar*const*names=static_cast(malloc(sizeof(char*)*cnt));//...allocatingnames[0],etc.comingsoon...the_c_function(names);free(names);return0;}所以我

c++ - 如果 C++ 类同时包含 const 引用和非 const 引用复制构造函数怎么办?

片段1:#includeusingnamespacestd;classC{public:C(){}C(constC&c){cout输出:调用的const复制构造函数片段2:#includeusingnamespacestd;classC{public:C(){}C(constC&c){cout输出:调用了非常量复制构造函数片段3:#includeusingnamespacestd;classC{public:C(){}C(constC&c){cout输出:错误:复制构造函数必须通过引用传递它的第一个参数我很困惑:对于片段2,为什么此处的非常量复制构造函数有效?为什么调用非const复制

c++ - 奇怪的运算符重载, "operator T& () const noexcept { return *_ptr; }"

我研究了一下,operator函数的格式是(returnvalue)operator[space]op(arguments){implementation}但是,在std::reference_wrapper实现中,有一个运算符重载函数声明为operatorT&()constnoexcept{return*_ptr;。这个运算符和T&operator()constnoexcept{return*_ptr;不同吗?}?.如果两者不同,那么第一个有什么用? 最佳答案 运算符T&()constnoexcept;是一个user-define

c++ - "const char*"类型的值不能用于初始化 "char *"类型的实体

我有这样的代码,但我一直收到此错误:Avalueoftype"constchar*"cannotbeusedtoinitializeanentityoftype"char*"这是怎么回事?我已经阅读了以下主题,但无法看到我的答案的任何结果,因为它们都是从char到char*或char*到char:Valuetypeconstcharcannotbeusedtoinitializeanentityoftypechar*Valueoftypechar*cannotbeusedtoinitializeanentityoftype"char"#include;usingnamespacestd

c++ - 无法在声明时使用初始化列表初始化 const char*/string 数组的 vector

最初我开始尝试在声明时使用初始化列表初始化constchar*[3]的vectorvectorv={{"a","b","c"}};这给出了错误matrixmustbeinitializedwithabrace-enclosedinitializer我觉得可能是constchar*的缘故,虽然看起来很奇怪,改成了字符串vectorv={{"a","b","c"}};但是错误依然存在。我尝试了几种牙套组合都无济于事。是否真的可以在声明时使用初始化列表初始化此结构? 最佳答案 编译失败因为std::vectorrequiresitsTto

已解决java.lang.ClassCastException: class java.lang.Integer cannot be cast to class java.lang.String异常的

已解决java.lang.ClassCastException:classjava.lang.Integercannotbecasttoclassjava.lang.String异常的正确解决方法,亲测有效!!!文章目录报错问题解决思路解决方法交流报错问题java.lang.ClassCastException:classjava.lang.Integercannotbecasttoclassjava.lang.String解决思路java.lang.ClassCastException:classjava.lang.Integercannotbecasttoclassjava.lang.St

c++ - 带有 "const"关键字的 C 类型转换

我通常在C/C++代码中使用C类型转换。我的问题是,在转换类型中添加“const”关键字对结果有什么意义吗?比如我可以想出几个场景:constmy_struct*func1(){my_struct*my_ptr=newmy_struct;//modifymembervariablesreturn(constmy_struct*)my_ptr;//returnmy_instance;}在这个函数中,函数构造了一个结构的新实例,并将其转换为一个常量指针,因此调用者将无法进一步修改其内部状态,除非删除它。“const”转换是必需的、推荐的还是根本不需要的,因为任一return语句都有效。在这

c++ - 使用 const 参数调用 map::find

我有一个对象:mapcollection;我想调用map::find函数,但我的键值为const,如以下代码,无法编译:constA*a=whatever();collection.find(a);以下代码有效并执行与查找操作等效的操作:constA*a=whatever();map::iteratoriter;for(iter=collection.begin();iter!=collection.end();++iter)if(iter->first==a)break;//iternowcontainstheresultormap::end(justlikemap::find)但它

c++ - 被 const 逼入绝境:std::map::find() const 重载

考虑以下片段:#includeclassC{public:C(){}constint&f(constint&x)const{//Error:cannotcastconstint*toint*constreturnmyMap.find(&x)->second;//Withaconst_castworks://returnmyMap.find(const_cast(&x))->second;}std::mapmyMap;};int_tmain(intargc,_TCHAR*argv[]){intx=0;Cc;c.f(x);return0;}f()中的错误是由map的find()的const