草庐IT

int_void

全部标签

c++ - 如何强制 pow(float, int) 返回 float

重载函数floatpow(floatbase,intiexp)在C++11中被移除,现在pow返回一个double。在我的程序中,我正在计算很多这些(单精度),我对最有效的方法很感兴趣。是否有一些具有上述签名的特殊函数(在标准库或任何其他函数中)?如果不是,在任何其他操作(这将转换所有其他内容)之前将pow的结果显式转换为float是否更好(就单精度性能而言)转换成double)或者将iexp转换成float并使用重载函数floatpow(floatbase,floatexp)?编辑:为什么我需要float而不使用double?主要原因是RAM——我需要数十或数百GB,因此这种减少是巨

c++ - 最令人烦恼的解析阻止了类内初始化 std::vector<int>

这个问题在这里已经有了答案:Whycan'tmemberinitializersuseparentheses?(2个答案)关闭4个月前。C++11允许类内初始化:structFoo{std::vectorv{3};//vectorof3emptystrings};如果我们想在类中初始化一个intsvector,我们会得到其他东西:structFoo{std::vectorv{3};//vectorofoneelementwithvalue3};这个问题好像是语言的限制,asdiscussedinpreviousquestions.但是,如果这不是类内初始化,我们将能够使用圆括号而不是大

c++ - 为什么我应该更喜欢类中的 static constexpr int 而不是类级整数常量的枚举?

C++17更新:staticconstexpr变量是隐式内联,因此不需要外部定义。原始问题:假设我有一个常量列表,例如structCls{staticconstexprintN=32;staticconstexprintM=64;};这当然建议我为这些添加定义以避免可能发生的ODR使用问题,因此我需要:constexprintCls::N;constexprintCls::M;为什么应该我更喜欢这个structCls{enum:int{N=32,M=64};};这让我免于ODR使用的麻烦,因为N和M更真实地只是常量,而不是对象本身(如果这是标题,那就更重要了-only)并且更短。我可以

c++ - 将 void (*p)(SomeType*) 转换为 void (*p)(void*) 是否安全

假设我有如下函数:voidfun(void*p){SomeType*p=reinterpret_cast(p);...}API需要签名。我只是想知道我能不能把它写成。voidfun(SomeType*p){...}并将其转换为void(*)(void*)。 最佳答案 虽然您可以将函数指针转换为其他函数指针并返回,但通过与其签名不匹配的指针调用函数是未定义的行为。您不能只是转换它并传递给API。在C和C++03中,您必须创建一个与签名匹配并执行转换的命名包装函数。在C++11及更高版本中,您可以只使用无捕获的lambda(正确转换):

c++ - 调用 placement new 时,将指针强制转换为 "void*"有什么影响吗?

我正在审查自定义容器的代码,它的某些部分创建了如下元素:::new((void*)&buffer[index])CStoredType(other);有些人是这样的:::new(&buffer[index])CStoredType(other);所以两者都使用placementnew来调用复制构造函数来通过复制其他元素来创建元素,但在一种情况下,指向新元素存储的指针按原样传递,而在另一种情况下,它被转换为void*。转换为void*有什么影响吗? 最佳答案 是的,您可以为非空指针重载operatornew。强制转换确保采用void指

c++ - 为什么 std::tuple<int> 不能简单复制?

内置thisonlinecompiler,以下代码:#include#include#includeintmain(){std::cout>::value>::value>::value>::value输出:0000我在VisualStudio2015中得到了相同的结果。为什么会这样?POD类型的std::tuple,更不用说简单的std::pair,是否有正当理由不能被简单复制?我假设它们的实现提供了一些自定义赋值运算符,但它们与编译器生成的默认版本有何不同? 最佳答案 就琐碎的可复制性而言,对失败的原因是标准不要求复制/移动赋值

c++ - 解析一个 int(x) 参数

这是一个带有一个int参数的简单函数:voidf(intx){}f(42);这是另一个带有一个int参数的函数:voidg(int(x)){}g(42);现在让我们将x定义为一个类型:typedefintx;voidh(int(x)){}h(42);//warning:passingargument1of‘h’makespointerfromintegerwithoutacast(这是我用gcc4.8.2观察到的行为)解析器作者如何处理这种情况?似乎经典管道Lexer->Parser->SemanticChecker->...在这里不起作用。 最佳答案

c++ - 编译器错误 C4430 : missing type specifier - int assumed

这个问题在这里已经有了答案:Resolvebuilderrorsduetocirculardependencyamongstclasses(12个答案)关闭8年前。我有这个错误:“错误C4430:缺少类型说明符-假定为int。注意:C++不支持default-int”使用此代码示例://A.h#include"B.h"classA{B*b;..};//B.h#include"A.h"classB{A*a;//errorerrorC4430:missingtypespecifier-intassumed.};

C++ - const 成员/返回 const int& 与 return int

那些C++行是什么意思?是否有其他方式来编写它们?constint&a()const;intgetA()const;谢谢。 最佳答案 这两个是promise不更改对象本身的类中成员函数的两个可能签名。在第一种情况下,它将返回一个对整数(可能是成员属性)的常量引用,引用是const意味着调用者将无法使用它来更改内部属性。第二种情况它按值返回一个整数。在语义上略有不同,但大多数情况下它们并不重要,将它们视为两个获取值的函数。对于它会有所作为的情况,请参见:classtest{public:test():m_value(){std::co

c++ - 输入: int fd = open ("file");?时fd代表什么

我正在研究C++中的I/O操作,我有一个问题。打开如下文件时:#includeintmain(){unsignedcharbuffer[16];intfd=open(argv[1],O_RDONLY);read(fd,buffer,sizeof(buffer));return0;}变量fd在将文件传递给open方法时如何将文件表示为整数?它是否代表当前文件夹中的文件?如果我打印“fd”变量,它会打印3。这是什么意思?附言。我知道还有其他几种处理文件的方法,例如stdio.h、fstream等,但这超出了本问题的范围。Ds. 最佳答案