草庐IT

VC_redist.x64

全部标签

c++ - 在 OSX 上从 x86 读取共享内存到 x64,反之亦然

如果我从64位应用程序创建SM并在32位应用程序上打开它,它会失败。//for64bitshared_memory_object(create_only,"test",read_write);//for32bitshared_memory_object(open_only,"test",read_write);64位应用创建的文件路径如下:/private/tmp/boost_interprocess/AD21A54E000000000000000000000000/test32位应用程序搜索的文件在路径中/private/tmp/boost_interprocess/AD21A54E

c++ - Boost 无法打开文件, 'libboost_filesystem-vc100-mt-gd-1_47.lib'

我已经用谷歌搜索了几个小时的错误,但没有得到太多信息。我已将该项目链接到我的VisualStudios(2010年和2012年)项目中,因为这似乎已经解决了与此类似的其他所有人的问题。但是,我仍然无法从boost的网站上获取我的示例代码并继续出现该错误。文件libboost_filesystem-vc100-mt-gd-1_47.lib在我的C:\ProgramFiles(x86)\boost\boost_1_47\lib路径中。这是我正在尝试测试并启动和运行的代码。#include#includeusingnamespaceboost::filesystem;intmain(inta

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

c++ - 如何使 Boost dylibs 在 os x 上通用(i386 和 x86_64)?

我正在尝试将Boost库编译成通用二进制文件(即包含i386和x86_64架构构建的“胖”文件)。破坏互联网和SO我组装了以下说明。下载boost(例如来自http://www.boost.org/users/download/)在下载的文件夹中,输入./bootstrap.sh(或者,在我的例子中./bootstrap.sh--with-libraries=thread,因为我只需要线程库)键入./b2installcxxflags="-archi386-archx86"这些步骤将Boost线程库安装到/usr/local/lib/(它的标准位置)。生成的静态库是一个通用二进制文件。

c++ - __attribute__((destructor)) 在 VC 中等效?

我看过__attribute__((constructor))equivalentinVC?和CRTInitialization,这对特定于gcc的__attribute__((constructor))都有帮助。但是__attribute__((destructor))呢?是否有等效的VC? 最佳答案 如果你正在制作一个动态链接库,你可以制作你的DllMainentrypoint处理这个:BOOLWINAPIDllMain(HINSTANCEhinstDLL,DWORDfdwReason,LPVOIDlpvReserved){if

.NET9 Linux-x64下Console.WriteLine原理

1.前言之前聊过Windows下面Console.WriteLine的运行过程常用Console.WriteLine原理,你知道吗?本篇看下它在Linu-x64下面最新.NET9运行过程2.托管代码.NET里面流读写数据一般都是通过StreamReader和StreamWriter这两个类操作。它们命名空间在:System.IO。托管库:System.Runtime.dll,比如以下简单的操作小例子:using(StreamWriterwriter=File.CreateText("newfile.txt")){awaitwriter.WriteLineAsync("Firstlineofex

c++ - VC++ 2013 : using-declaration + redefinition of member function leads to compile error

我想通过指定策略允许修改我的类的行为。该策略应该用作boost::variant的访问者。有适合大多数情况的默认策略,但用户可能需要添加或替换一些重载。我发现vc++2013没有编译此代码并出现错误C3066:Therearemultiplewaysthatanobjectofthistypeofcanbecalledwiththesearguments。相同的代码在gcc和clang中按预期编译和工作。是vc++2013的错误吗?#includestructDefaultPolicy{voidoperator()(bool){std::coutUPD这个例子适用于vc++2010。看

ARMv8-AArch64 的异常处理模型详解之异常处理概述Handling exceptions

异常处理模型详解之异常处理概述一,异常处理相关概念二,异常处理概述一,异常处理相关概念在介绍异常处理之前,有必要了解一些关于异常处理状态的术语:当处理器响应一个异常时,我们称该异常被获取了(taken)。处理器响应异常之前的状态被称为takenfrom。处理器响应异常之后的状态被称为takento。因此,当处理器识别到异常时,此时处理器处于takenfrom。在异常之后的状态称为takento。当异常处理完成后,处理器需要返回到异常发生前的状态,这个过程称为exceptionreturn。并且在ARM架构中有专门的指令用于异常返回(ERET):处理器在执行异常返回指令之前的状态,称为retur

c++ - ARM NEON aarch64 : How to compare and update neon registers in optimized way?

实际上,我正在尝试找出一种比较从“unsignedshort”数组加载的NEON寄存器值的好方法。由于我正在处理一个大型项目,因此无法解释共享整个代码部分。相反,我将分享一个类似的例子,以便每个人都能理解实际的问题场景。C++实现:unsignedshort*values=newunsignedshort[8];for(inti=0;i255){values[i]=255;}}程序集实现:MOVW3,#255UMOVW2,V4.H[0]CMPW2,#0x00FFCSELW2,W3,W2,GTMOVV4.H[0],W2UMOVW2,V4.H[1]CMPW2,#0x00FFCSELW2,W

c++ - 是否可以使用 Wojciech Mula 算法对 __m256i 进行 popcount 并将结果存储在 8 个 32 位字而不是 4 个 64 位字中?

我最近发现AVX2没有__m256i的popcount,我发现做类似事情的唯一方法是遵循WojciechMula算法:__m256icount(__m256iv){__m256ilookup=_mm256_setr_epi8(0,1,1,2,1,2,2,3,1,2,2,3,2,3,3,4,0,1,1,2,1,2,2,3,1,2,2,3,2,3,3,4);__m256ilow_mask=_mm256_set1_epi8(0x0f);__m256ilo=_mm256_and_si256(v,low_mask);__m256ihi=_mm256_and_si256(_mm256_srli_e