草庐IT

int_void

全部标签

c++ - `int` 假定在 OpenCV 中始终为 32 位?

似乎在OpenCV中,int数据类型总是假定为32位。这反射(reflect)在文档中(例如,intheintroduction),也反射(reflect)在源代码中(例如,在modules/core/include/opencv2/core/cvdef.h的注释中,以及它将uint定义为32位无符号整数,但没有定义相应的有符号类型这一事实。在int不是32位的系统上,这如何不破坏OpenCV?毕竟,标准只保证int是16位。我希望OpenCV为其使用的所有大小定义数据类型(就像它为int64所做的那样),或者使用uint_8和friend。 最佳答案

c++ - C : x86 Intel Intrinsics usage of _mm_log2_ps() -> error: incompatible type 'int' ?

我正在尝试将log2应用于__m128变量。像这样:#includeintmain(void){__m128two_v={2.0,2.0,2.0,2.0};__m128log2_v=_mm_log2_ps(two_v);//log_2:=log(2)return0;}尝试编译会返回此错误:error:initializing'__m128'withanexpressionofincompatibletype'int'__m128log2_v=_mm_log2_ps(two_v);//log_2:=log(2)^~~~~~~~~~~~~~~~~~~我该如何解决?

c++ - 将 int 数组转换为可变参数模板

假设我有一个像intarr[N]这样的整数数组然后说arr[i]来自一个很小的域(例如1-10)。假设我还有一个具有通用接口(interface)(抽象类)的可变参数模板类templateclassFooImpl:publicFoo{}问题是我如何实现一个功能:Foo*getFoo(intarr[N]);或者更好:Foo*getFoo(int*pint,intsize);这将返回FooImpl模板参数对应我的数组?例如arr={4,2,6,1}我会得到FooImpl 最佳答案 我找到了问题的答案。诀窍在于使用结构可变参数模板而不是我

c++ - 在宏中包装模板函数调用,或避免特化 void 返回

我有以下功能,允许我包装OpenGL命令并在出现问题时记录:templatestructChecker{staticResrun(conststd::string&function_name,Func&&func,Args&&...args){Resresult=func(std::forward(args)...);check_and_log_error(function_name);returnresult;}};templatestructChecker{staticvoidrun(conststd::string&function_name,Func&&func,Args&&.

Java中是否有一种干净的方式将int数组的一部分作为字符串输出?

给定一系列int和索引k。任务是输出左移k的数组。例如...a=[1,2,3,4,5],k=4Output:51234在JavaScript中,代码是:varresult=a.slice(d).join('')+''+a.slice(0,d).join('')我真的很努力地在Java找到一个简洁的同等用品。看答案正如您所说,您只需要输出,这将起作用:int[]a=newint[]{1,2,3,4,5};intk=4;for(inti=0;i

c++ - Opencv,对 `cv::imread(??cv::String const&???, int)' 的 undefined reference

这个问题在这里已经有了答案:error:undefinedreferenceto`cv::imread(std::stringconst&,int)'(4个答案)Whatisanundefinedreference/unresolvedexternalsymbolerrorandhowdoIfixit?(38个答案)关闭5年前。我在QT+Opencv中有一个项目,代码可以正常工作,但我必须格式化窗口,现在我试图再次导入该项目,但出现了这个错误。对`cv::imread(cv::Stringconst&,int)'的undefinedreference在这一行中:mat=cv::imre

C++。为什么 std::cout << char + int 打印 int 值?

比方说,我们有:charx='a';inty=1;所以,如果你运行:std::cout它打印98而不是'b'。正如我从here看到的那样只有int参数实现。从现在开始我有两个问题:char+int操作后返回什么类型?为什么没有char参数实现,而是std::cout仍然按预期工作并打印char值? 最佳答案 感谢Fefux,BoPersson和MattiVirkkunen答案是:来自CPPReference:Implicitconversions:arithmeticoperatorsdonotaccepttypessmallert

c++ - 在编译时解析 (u)int_fastX_t

C++标准typedef的实现将(u)int_fastX类型定义为其内置类型之一。这需要研究哪种类型最快,但不可能对每种情况都有一种最快的类型。在编译时解析此类类型以通过为实际使用选择最佳类型来解决这种情况是否会提高性能?编译器会分析_fast变量的使用,然后选择最佳类型。发挥作用的因素可能是对齐方式和变量使用的操作类型。这将有效地使这些类型成为一种语言特性。当编译器突然决定为这样的变量选择另一个宽度时,这可能会引入错误。但是在这种用例中不应该使用_fast类型,无论如何,行为取决于宽度。标准允许这样的编译时解析吗?如果是,为什么到今天还没有实现?如果不是,为什么不在标准中?

c# - 将包含 int 和 int[] 的结构从 C# 编码到 C++

我有一个带有非托管代码的C++DLL和一个C#UI。有一个从C++DLL导入的函数,它以我编写的结构作为参数。将我编写的结构(MyImage)从C#编码到C++后,我可以访问其中的int[]数组的内容,但内容不同。我不知道我在这里遗漏了什么,因为我花了很多时间并尝试了一些技巧来解决这个问题(显然还不够)。C#中的MyImage结构:[StructLayout(LayoutKind.Sequential)]structMyImage{publicintwidth;publicintheight;publicint[]bits;//theserepresentcolorsofimage-4

c++ - size_t 和 __w64、time_t 和 __int64 是如何工作的?

我不是C或C++的老手。我不知道time_t是如何定义和设计的。几个帖子,例如:Whatisultimatelyatime_ttypedefto?Whatissize_tinC?Differencebetweensize_tandstd::size_t但是这些帖子只说明什么是time_t或size_t。它没有明确说明time_t或size_t是如何以及在何处定义和声明的。我正在使用WIN8VS2012ExpressC++。我搜索了库,发现size_t是在crtdefs.h中定义的,而不是cstddef。为什么需要size_t、time_t这样的类型?我们可以让sizeof只返回unsi