草庐IT

scala-compiler

全部标签

c++ - 与 friend 一起上课而不是前向声明,: which compiler is correct

这个问题在这里已经有了答案:Friendmethod"notdeclaredinthisscope"inC++(1个回答)Error:'FriendMemberFunctionName'wasnotdeclaredinthisscope(3个答案)关闭3年前。我有这个简单的C++程序:#includestructobj{friendintf(int);voidm(intx){std::cout如果我使用GNUC++编译器g++进行编译,我会得到错误prog.cpp:7:55:error:'f'wasnotdeclaredinthisscope但是,如果我使用cl(和/W4)编译它,它会

c++ - Scala等与C/C++/Fortran的性能比较?

我想知道是否有任何可靠的“现代”多线程专用语言之间的性能比较,例如scala和“经典”“低级”语言,如C、C++、Fortran,使用并行库,如MPI、Posix甚至Open-MP。欢迎任何链接和建议。 最佳答案 假设Java以及Scala可以调用外部库,并且假设那些高度特化的外部库将完成大部分工作,那么只要使用相同的库,性能是相同的。除此之外,任何此类比较本质上都是没有意义的。Scala代码在具有运行时优化的虚拟机上运行。这种优化可以插入长时间运行的程序比使用其他语言编译的程序具有更高的性能——或者不是。这取决于用每种语言编写的具

c++ - SFINAE : Detecting if a function is called by a compile time known value

我喜欢在我的一个ctors以编译时已知值被调用时做一些检查。有办法检测吗?所以当有人调用它时:Aa(10);因为10是编译时已知常量,所以我喜欢调用一个特殊的构造函数,如下所示:template>A(intValue){}知道如何解决这个问题吗?谢谢! 最佳答案 积分常量可以解决您的问题:structA{template*=nullptr>A(std::integral_constant){}};然后,你可以像这样使用它:Aa{std:integral_constant{}};为了便于使用,您还可以使用类似于boost::hana的

c++ - C1001 : An internal error has occurred in the compiler

这应该是不言自明的。我正在尝试实现分布排序,但MSVC编译器崩溃了。这似乎是用我的SFINAE检测成员函数的特定情况,如果我不将indexert传递给函数,或者替换has_get_index,这似乎不会发生。如果我删除剩余的索引器重载中的任何一个,它也不会发生。如果sortable有一个getIndex()const成员,问题仍然存在。1>test.cpp(34):fatalerrorC1001:Aninternalerrorhasoccurredinthecompiler.1>(compilerfile'msc1.cpp',line1420)1>Toworkaroundthispro

Scala游戏框架JSON转换

我有两个案例类A和B。我需要有条件地创建JSON对象json.tojson(如果(cond)aelseb)if(cond)json.tojson(a)其他JSON.TOJSON(B)语句1不编译,但语句2确实如此。背后的原因是什么?看答案签名toJson(...)是:toJson[T](o:T)(implicittjs:Writes[T]):JsValue这意味着必须有一个隐式Writes在参数类型的范围T.现在,表达if(cond)AelseB是个常见的超级类型相应的值A和B的类型。对于不明确从同一基类继承的类型,公共超级类型将是Scala的Any。没有隐性Writes为了Any(因为任何东

公共Scala构造函数在Java中不公开

问题很简单。当我直接在构造函数中声明scala字段时,这样:classVector2D(valx:Float,valy:Float){}田野x和y在爪哇不公开。例如:publicclassJavaMain{publicstaticvoidmain(String[]args){Vector2Dvec=newVector2D(1,2);System.out.println(vec.x);//Won'tcompile.}}但是,在Scala中,这将汇编:objectScalaMain{defmain(args:Array[String])={varvec=newVector2D(1,2);print

c++ - CMake + 库达 : compile cpp files in Cuda-mode (--x=cu)

假设我有一个文件,我们称它为foo.cpp,我的目标是在cuda模式下用nvcc编译这个文件。在命令行中,这可以通过调用轻松完成:nvcc--x=cufoo.cpp我正在苦苦挣扎的是让CMake做同样的事情。事实证明,CMake命令cuda_add_executable(foofoo.cpp)将过滤*.cpp文件并使用c++编译器(而不是nvcc)。请注意,将所有文件重命名为*.cu不是一种选择,因为代码库还必须支持非cuda构建。 最佳答案 在FindCUDAsourcecode我找到了一个选项来为特定的非.cu文件激活CUDA编

c++ - VC++ 使用 fp :fast causes wrong (not just inaccurate) results - is this a compiler bug?

我已经安装了最新的VS2017更新(15.4.4),但在编译我们的项目时,单元测试开始失败。在使用优化(/O2)和浮点快速模型(/fp:fast)时,问题似乎发生在某些情况下。以前的编译器(VS2017update15.2)没有出现这个问题。这是一个示例程序:#includeconstfloatFACTOR=0.01745329251994329576923690768489f;unsignedlonglonghoursToMicrosecs(inthours){returnhours*3600*1000000LL;}floatdegToRad(floatdeg){returndeg*

c++ - 将指针转换为模板参数 : Comeau & MSVC compile, GCC 失败

考虑以下代码:templateclassbase{};intmain(){basetest;return0;}Comeau和MSVC都可以毫无问题地编译它(除了Comeau警告未使用的变量),而GCC在basetest;上失败行,说明Infunction`intmain()':acaststoatypeotherthananintegralorenumerationtypecannotappearinaconstant-expressiontemplateargument1isinvalid它到底在提示什么?谁是对的——这段代码应该编译吗?值得注意的是,我的GCC版本非常旧(3.4.2

c++ - Opencv 错误 : no GPU support (library is compiled without CUDA support)

我正在尝试使用CUDA在GPU上使用opencv处理一些图像处理任务。我正在使用ubuntu。我毫无问题地设置了我的两个产品Opencv和Cuda,我确信这一点。但是,当我尝试在eclipse中运行sampleCOde时,出现错误:OpenCV错误:在mallocPitch中没有GPU支持(库在没有CUDA支持的情况下编译),文件/home/muad/Source/OpenCV-2.4.2/modules/core/src/gpumat.cpp,第749行我重做了我的opencv,但我还是明白了。 最佳答案 如文档中所述,您必须使用