草庐IT

my_numeric_cast

全部标签

C++ NetBeans : How to link my . o 文件到我的项目?

我买了一个类。我有header(.h)和目标文件(.o)。如何在我的NetBeansIDE中链接.o文件?谢谢! 最佳答案 您需要将您的.o文件添加为外部库。我能够使用以下步骤完成此操作:转到项目属性在Build->Linker选项下,将库添加到Libraries部分点击“添加库文件”导航到您的.o文件并选择绝对路径选项重建希望这对你也有用。 关于C++NetBeans:Howtolinkmy.o文件到我的项目?,我们在StackOverflow上找到一个类似的问题:

c++ - boost::lexical_cast 和非内置类型的字符串化

我有一个(也许)关于复合类型的boost::lexical_cast的简单问题(在我的例子中是std::vector。我的第一个模板化字符串化函数版本如下templatestd::stringstringiy(constT&t){std::ostringstreamo;o下面是一个工作示例:vectorx(10,-3;cout>(x)输出“-3-3-3-3-3-3-3-3”~但出于性能原因,我想利用boost::lexical_cast现在我更改了函数实现:templatestd::stringstringiy(constT&t){returnboost::lexical_cast(t

从基础到派生的 shared_ptr 的 C++ dynamic_ptr_cast 失败

这是我本周遇到的一个益智游戏。部分原因是我在编写了一段时间的Java代码后刚刚回到C++编码。给定以下代码:classBase{};classA:Base{public:virtualvoidrun(){coutptrToA=shared_ptr(newC());cout(ptrToA)run();assert(dynamic_pointer_cast(ptrToA));cout为什么会产生如下输出?PointertoA:0x1f29c010DynamicCastAptrtoC:0Running...ThisisC.tester-cpp:tester.cpp:89:intmain(in

c++ - OpenMP 和 C++ 并行 for 循环 : why does my code slow down when using OpenMP?

我有一个关于使用OpenMP(与C++)的简单问题,我希望有人能帮助我。我在下面提供了一个小示例来说明我的问题。#include#include#include#includeusingnamespacestd;intmain(){srand(time(NULL));//Seedrandomnumbergeneratorvectorv;//Createvectortoholdrandomnumbersininterval[0,9]vectord(10,0);//Vectortoholdcountsofeachintegerinitializedto0for(inti=0;i::iter

c++ - const_cast 类构造函数中的 const 成员

当我希望类的成员变量在类的生命周期内保持不变,但在构造函数期间需要可变时,我有时会使用const_cast。示例:structqqq{constvectormy_foo;qqq(vector*other){vector&mutable_foo=const_cast&>(my_foo)other->swap(mutable_foo);}};我曾假设在构造函数中执行此操作基本上没问题,因为此时没有其他人依赖它,因此它不会与优化等产生不良交互。但是最近有人告诉我这是“未定义的行为”,并且在任何情况下在构造const对象之后对其进行变异基本上都是非法的。有人能解释一下吗?这是不好的/未定义的行

python:`del my_list` vs` del [my_list]

我在Python中创建了一个列表>>>my_list=[1,2,3,4]现在,如果我想删除列表,我想使用del操作员喜欢>>>delmy_list这可以正常工作,并且可能是使用它的一般方法。但是在某个地方,我偶然发现了不寻常的语法>>>del[my_list]这也是同样的事情!现在,我有点困惑DEL的实际运作方式。我可以理解以前的语法del作为内置的陈述,但第二个语法看起来像是我的索引。看答案del服用目标列表名字,请参阅参考文档:del_stmt::="del"target_list就像是作业和for循环,目标列表包括使用[...]和(...)列表和元组语法:del(foo,bar)del[

c++ - -Werror=old-style-cast 的意义?

我正在使用将一些整数转换为float以进行除法的代码。size_ta;uint8_tb,c;a=(float)b/(float)c;我在编译时启用了警告标志,我得到了一个用于“旧类型转换”的警告标志。有没有更好或更合适的方式来转换这些东西?如果是,怎么办? 最佳答案 旧式转换是“C风格”转换。-Werror=old-style-cast将C风格转换的使用变成错误。你应该使用C++casts.在这里你可以使用一个static_cast:size_ta;uint8_tb,c;a=static_cast(b)/static_cast(c)

c++ - static_casting a constexpr void* 的结果是常量表达式吗?

clang正在拒绝gcc允许的这段代码:intmain(){staticconstexprconstvoid*vp=nullptr;staticconstexprconstchar*cp=static_cast(vp);}具有以下内容:error:constexprvariable'cp'mustbeinitializedbyaconstantexpressionstaticconstexprconstchar*cp=static_cast(vp);阅读完N3797中的最终list后5.9/2我没有看到任何禁止在常量表达式中使用static_cast的内容。我是在看错地方还是误读了什么

c++ - 显式构造函数和 static_cast

structFoo{explicitFoo(inta):m(a){}intpadd1,m,padd2;};voidBar(Foo){}intmain(){Bar(11);//OK,giveserrorautox=static_cast(37);x.m;}static_cast构造Foo对象是否可以,即使它的构造函数被标记为explicit?它适用于MSVC2013和GCChttp://ideone.com/dMS5kB 最佳答案 是的,static_cast将使用explicit构造函数。5.2.9Staticcast[expr.s

c++ - static_cast 与直接调用转换运算符?

考虑下面的类,作为一个简单的例子:#include#includeusingnamespacestd;classpoint{public:int_x{0};int_y{0};point(){}point(intx,inty):_x{x},_y{y}{}operatorstring()const{return'['+to_string(_x)+','+to_string(_y)+']';}friendostream&operator(p);//Option1os应该直接调用转换运算符,还是只调用static_cast并让它完成工作?这两行几乎会做完全相同的事情(即调用转换运算符),据我所