草庐IT

report_result

全部标签

c++ - 除以零预防 : Checking the divisor's expression doesn't result in zero vs. 检查除数不为零?

由于减法中的浮点错误,在以下情况下是否可以被零除?floatx,y,z;...if(y!=1.0)z=x/(y-1.0);换句话说,下面是不是更安全一些?floatdivisor=y-1.0;if(divisor!=0.0)z=x/divisor; 最佳答案 假设IEEE-754float,它们是等价的。FP算法的一个基本定理是,对于有限的x和y,x-y==0当且仅当x==y,假设逐渐下溢。如果次正规结果被刷新为零(而不是逐渐下溢),则只有当结果x-y是正规的时,这个定理才成立。因为1.0的缩放比例很好,所以y-1.0永远不会低于正

c++11 获取第一个(第二个等...)参数的类型,类似于 result_of

假设我有一个模板函数,它接受一个参数,它是一个函数(它可以是一个std::function,或者一个lambda,或者实际的函数指针)。一个说明问题的愚蠢例子:template::type>Bblabla(F&&f){returnf(A())/3;}如果我有A的类型,我可以使用std::result_of::typename引用f的返回类型,但我希望编译器从F的第一个参数推断出类型A。(如果我写templateBblabla(conststd::function&f){returnf(A())/3;}编译器在推导A和B时存在问题(特别是如果它不是std::function而是lambd

c++ - std::match_results::size 返回什么?

我对以下C++11代码有点困惑:#include#include#includeintmain(){std::stringhaystack("abcdefabcghiabc");std::regexneedle("abc");std::smatchmatches;std::regex_search(haystack,matches,needle);std::cout我希望它打印出3但我却得到了1。我错过了什么吗? 最佳答案 你得到1因为regex_search仅返回1个匹配项,size()将返回捕获组的数量+整个匹配值。你的匹配是.

Kotlin:必须初始化变量 'result'

编译器显示错误Kotlin:Variableresultmustbeinitialized.这里是代码。funmain(args:Array){print("Entertwonumbers:")//nextDouble()readsthenextdoublefromthekeyboardvarfirst=readLine()!!.toDouble()varsecond=readLine()!!.toInt()print("Enteranchoice(1-4)):")valoperator=readLine()!!.toInt()varresult:Doublewhen(operator

Kotlin:必须初始化变量 'result'

编译器显示错误Kotlin:Variableresultmustbeinitialized.这里是代码。funmain(args:Array){print("Entertwonumbers:")//nextDouble()readsthenextdoublefromthekeyboardvarfirst=readLine()!!.toDouble()varsecond=readLine()!!.toInt()print("Enteranchoice(1-4)):")valoperator=readLine()!!.toInt()varresult:Doublewhen(operator

c++ - 多重继承 : unexpected result after cast from void * to 2nd base class

我的程序需要使用void*以便在动态调用情况下传输数据或对象,以便它可以引用任意类型的数据,甚至原始类型。但是,我最近发现,在具有多个基类的类的情况下向下转换这些void*的过程失败,甚至在调用这些向下转换的指针上的方法后我的程序崩溃,即使内存地址看起来是正确的。崩溃发生在访问“vtable”期间。所以我创建了一个小测试用例,环境是MacOSX上的gcc4.2:classShape{public:virtualintw()=0;virtualinth()=0;};classSquare:publicShape{public:intl;intw(){returnl;}inth(){ret

c++ - 为什么 std::result_of<int(int)>::type 无效?

我已阅读以下相关问题:std::result_ofsimplefunctiondecltype,result_of,ortypeof?和thepageonstd::result_ofatcppreference.com.所有这些似乎都表明我应该能够使用:std::result_of::typev1=10;但是,当我尝试使用g++4.9.2构建以下程序时#includeintfoo(){return0;}intmain(){std::result_of::typev1=10;//LINEAstd::result_of::typev2=20;//LINEBreturn0;}我收到“LINE

c++ - 基本 Qt 应用程序 : Reports Masive Leaks 上的 Valgrind

所以我想看看当通过Valgrind运行时,从简单的Makefile编译的基本Qt4应用程序会发生什么。什么会导致这些泄漏?我正在删除我这边的任何动态分配的对象。另外,退出程序时,我只单击右上角的关闭(X)。GUI库是否只是“free()”它们malloc()的任何内存?由qmake命令缩减的Makefile是:#######Compiler,toolsandoptionsCXX=g++CXXFLAGS=-pipe-O2-Wall-WLIBS_INCLUDE=${HOME}INCPATH=-I$(LIBS_INCLUDE)/QtSDK/Desktop/Qt/473/gcc/mkspecs

c++ - 使用可变参数模板重载函数模板 : Intel c++ compiler version 18 produces different result from other compilers. intel 错了吗?

考虑以下代码片段:templateclassA,typename...Ts>inta(Aarg){return1;//Overload#1}templateinta(Aarg){return2;//Overload#2}templatestructS{};intmain(){returna(S());}在使用模板类的实例调用函数a时,我希望编译器选择更特殊的函数重载#1。根据compilerexplorer、clang、gcc和17版之前的英特尔实际上会选择重载#1。相反,后来的英特尔编译器版本(18和19)选择重载#2。是代码定义不正确还是最新的英特尔编译器版本有误?

c++ - boost spirit : Lex + Qi error reporting

我正在为使用缩进等的相当复杂的配置文件编写解析器。我决定使用Lex将输入分解为标记,因为它似乎让生活更轻松。问题是我找不到任何将Qi错误报告工具(on_error)与对标记流而不是字符流进行操作的解析器一起使用的示例。要在on_error中使用的错误处理程序需要一些才能准确指示错误在输入流中的位置。所有例子都只是构造std::string从一对迭代器中打印出来。但是如果使用Lex,那么迭代器就是标记序列的迭代器,而不是字符。在我的程序中,这导致挂起std::string在我注意到无效的迭代器类型之前构造函数。据我所知,token可以将一对迭代器保存到输入流中作为它的值。这是默认属性类型