草庐IT

data_thread

全部标签

C++/Windows : HeapAlloc() for contention-free per-thread heaps

我有一个使用boost::thread的多线程应用程序。出于性能原因,我希望每个线程都有一个独立的堆。我可以使用HeapCreate()创建一个堆,但不清楚如何将其连接到CRT库,以便new和malloc在创建的堆上分配内存。如何做到这一点? 最佳答案 Howcanthisbedone?如果不完全替换整个内存分配器就无法完成。例如可伸缩内存管理器Hoard正是这样做的。但是替换内存分配器并不适合胆小的人。如果您想通过HeapCreate使用每线程堆,并且合理包含您的分配/释放代码,那么您可以简单地调用HeapAlloc和HeapFr

windows - mingw std::thread 与 Windows API

我开始使用C++11std::thread(mingw4.8)到目前为止一切顺利。我遇到了重叠I/O的情况,其中sleepEx用于将线程置于可警告的等待状态。这工作得很好,直到必须使用QueueUserAPC,它返回一个“无效句柄错误”。经过一番查找,发现std::thread使用的是Windows下的pthread库。有没有什么方法可以使用WindowsAPI调用,它需要一个带有std::thread的线程句柄?或者我是否需要坚持使用Windows线程来处理重叠I/O? 最佳答案 为了解决您的问题,MinGW-w64winpthr

windows - 错误 1334。在 Data1.cab 中找不到文件

我在Win7-64位机器上工作。我有一个软件安装包,其中包含.msi文件、CAB文件和一些MST文件。我想修改cabinet文件。所以我使用CABARC提取了cab文件公用事业。但在对提取的文件进行任何更改之前,为了测试实用程序,我从当前目录中删除了原始cab文件。并再次使用CABARC实用程序从原始cab文件中提取的文件创建一个新的cab文件。但现在如果我运行.msi文件,它会显示错误:ERROR:1334.Thefile"XYZ"cannotbeinstalledbecausethefilecannotbefoundinthecabinetfileData1.cab.Thiscou

linux - ansible 2.3> 在检查 Windows 主机时,错误 : Thread failed to start

我正在通过ansible连接到Windows主机。但是我从win_shell得到一个错误。[as_user@ttansible-winconnect]$ansible-playbook-iWINwin_conn.yml-techo_test--ask-pass-vvvvfatal:[x.x.x.x]:FAILED!=>{"changed":true,"cmd":"echo%HOMEDIR%>print.txt","delta":"0:00:00.287028","end":"2017-05-2511:38:05.603907","failed":true,"rc":1,"start":

Elasticsearch集成之(Spring Data Elasticsearch)

Elasticsearch集成之(SpringDataElasticsearch)1、SpringData框架介绍SpringData是一个用于简化数据库、非关系型数据库、索引库访问,并支持云服务的开源框架。其主要目标是使得对数据的访问变得方便快捷,并支持map-reduce框架和云计算数据服务。SpringData可以极大的简化JPA(Elasticsearch…)的写法,可以在几乎不用写实现的情况下,实现对数据的访问和操作。除了CRUD外,还包括如分页、排序等一些常用的功能。SpringData的官网:https://spring.io/projects/spring-data2、Spri

c - 如何获取文件的 "valid data length"?

有一个函数可以设置“有效数据长度”值:SetFileValidData,但我没有找到获取“有效数据长度”值的方法。如果EOF与VDL不同,我想知道给定的文件,因为在VDL的情况下在VDL之后写入将导致性能损失,如here所述. 最佳答案 我找到了this页面,声称:thereisnomechanismtoquerythevalueoftheVDL所以答案是“你不能”。如果您关心性能,您可以将VDL设置为EOF,但请注意,您可能允许访问磁盘上的旧垃圾-这两个指针之间的部分,如果您不访问该文件则应该为零设置VDL指向EOF。

c - Windows 内核驱动程序 : How to determine if thread terminated?

我有一个线程用于某些操作,它需要保持事件状态,直到标志另有说明为止。我用PsCreateSystemThread创建线程,然后使用ObReferenceObjectByHandle获取ETHREAD在使用KeWaitForSingleObject卸载驱动程序之前等待线程终止的对象引用.Thefunctionthatcreatesthethreadandretrievesareferencetoit:ntStatus=PsCreateSystemThread(&hThread,(ACCESS_MASK)0,NULL,(HANDLE)0,NULL,ThreadRoutine,(PVOID)

windows - 域兼容性 : where should shared data be written?

我们编写的应用程序在XP中运行良好,但在迁移到Vista和Windows7时遇到了严重的问题,这可能是由于用户数据的写入位置。用例是这样的:个人用户需要登录机器并使用它来获取数据。主管用户需要能够从各个用户的肩膀上看到并验证他们是否正确地执行了他们的工作。这些主管还需要检查系统日志以确保系统正常运行。我们在XP中完成这些任务的方法是直接写入C:\驱动器上的文件夹。也许这是不好的做法,也许不是,但基本上系统的所有用户都需要能够将此数据作为共享数据进行访问。在该程序的某些安装中,IT环境根本不安全,计算机只有一个用户,然后每个人分别登录到我们的程序。在该程序的其他安装中,IT人员是能干的,

java - Thread.currentThread().getContextClassLoader().getResource (".") 在 windows 和 linux 上有不同的结果

我有一个简单的Java类:publicclassT{publicstaticvoidmain(String[]args){System.err.println(Thread.currentThread().getContextClassLoader().getResource("."));}}在我得到的windows上运行上面的类:file:/T:/java/在Linux上运行时我得到了不同的东西:jar:file:/usr/lib/jvm/java-6-openjdk-common/jre/lib/ext/pulse-java.jar!/这个问题导致我的程序在Linux上失败,因为它

c++ - 什么在Windows Server 2003上使用了这么多未提交的 “private data”?

因此,我有一个nativeC++应用程序,它需要长时间跟踪很多事情。当任务管理器说进程到达800到1200MB内存之间的某个地方时,内存用完了,而限制应该是2GB。我终于对我对进程运行VMMap时发生的事情有了一个线索,但这给了我更多的问题。我发现:的总大小(类型:总计,列:大小)比任务管理器/流程资源管理器报告的大得多在我的程序内存不足之前,总大小似乎实际上不能超过2GB。内存使用差异几乎完全是由“私有(private)数据”引起的-“大小”比“已提交”多得多。我已经看到一些案例,其中大约有800MB的已提交私有(private)数据,但是“大小”约为1700MB。“私有(priva