草庐IT

locator_params

全部标签

c++ - 使用 : Construction of objects at predetermined location in C++

在C++中在预定位置构造对象有什么用?以下代码说明了在预定位置的构造-void*address=(void*)0xBAADCAFE;MyClass*ptr=new(address)MyClass(/*argumentstoconstructor*/);这最终会在预定的“地址”处创建MyClass的对象。(假设address指向的存储足够大以容纳MyClass对象)。我想知道在内存中的这些预定位置创建对象的用途。 最佳答案 placementnew有用的一个场景是:您可以一次预分配大缓冲区,然后使用许多放置新运算符。这会给你更好的性能

c++ - timer_create 给出内存泄漏问题 "Syscall param timer_create(evp) points to uninitialised byte(s)"

structsigeventtimerEvent;memset(&timerEvent,0,sizeof(timerEvent));timerEvent.sigev_value.sival_int=0;timerEvent.sigev_value.sival_ptr=diaBase;timerEvent.sigev_notify=SIGEV_THREAD;timerEvent._sigev_un._sigev_thread._function=function;timerEvent._sigev_un._sigev_thread._attribute=NULL;timer_ttimer

c++ - 为什么 (void)sizeof(param) 不是 "using"参数?

我有一个定义如下的宏:#defineUNREF_PARAM_1(a)do{\(void)sizeof(a);\}\while(0)去除编译器警告。在我正在处理的一个新项目中,VS2013突然再次提示未引用的形式参数。奇怪的是,如果我只使用(void)param,它确实有效。有没有人知道为什么它在与(void)sizeof(param)一起使用时不起作用? 最佳答案 因为在sizeof(param)中,param是所谓的未计算的操作数,因此未被odr使用-也就是说,不是在运行时需要。但是,(void)param确实构成了odr-use

c++ - 编译时的 std::experimental::source_location

std::experimental::source_location可能会在某个时候添加到C++标准中。我想知道是否有可能将位置信息获取到编译时领域。本质上,我想要一个在从不同源位置调用时返回不同类型的函数。像这样的东西,虽然它没有编译因为location对象不是constexpr因为它是一个函数参数:#includeusingnamespacestd::experimental;constexprautoline(constsource_location&location=source_location::current()){returnstd::integral_constant

c++ - void(param); 的意义/用途是什么?在功能开始时?

我刚刚浏览了Yahoo'sTraficServer的源代码它是用C++编写的。在几乎所有方法中(来自模块之一),他们对函数接收的每个参数执行void(param)。(例如下面)谁能解释一下这是干什么用的?intsome_method_name(caddr_taddr,size_tlen,caddr_tend,intflags){(void)end;(void)addr;(void)len;(void)end;(void)flags;..........}附言:有关实际源代码,请参阅方法来自http://github.com/apache/trafficserver/blob/trunk

c++ - "the procedure entry point _ZNSt8_detail15_List_node_base7_M_hookEPS0_ could not be located in the dynamic link library libstdc -6.dll."

有个小问题。我有C++代码,它链接到一些库。我以前有源代码的(原始)exe,它在第一台机器上运行完美。还有第二台机器,我在那里处理源代码,更改它,等等。在第二台机器上,该源代码的构建工作正常,当我复制second.exe并尝试在第一台机器上运行它时萌芽它显示错误信息"theprocedureentrypoint_ZNSt8_detail15_List_node_base7_M_hookEPS0_couldnotbelocatedinthedynamiclinklibrarylibstdc++-6.dll."有一件事,second.exe被复制到与original.exe相同的文件夹中,

c++ - POD 结构(相同类型的成员): are members in contiguous memory locations?

给定templatestructVector3d{Tx,y,z;};假设x、y和z位于连续的内存位置是否安全?对于T=float和T=double至少可以安全地假设吗?如果不能,是否有可能以跨平台的方式实现?注意:只要x、y、z是连续的,我不介意在z之后填充 最佳答案 Isitsafetoassumethatx,y,andzareincontiguousmemorylocations?从技术上讲,语言没有这样的保证。另一方面,它们也没有必要不连续,实际上它们很可能是连续的。Ifnotisitpossibletoenforceinac

c++ - 为什么 boost::call_traits<double>::param_type 是 "const double&"而不是 "double"

我在win32program@windows7机器上使用代码“boost::call_traits::param_type”。令我惊讶的是,它不是“double”而是“constdouble&”。我认为所有原始类型都适合对函数参数使用“按值传递”,这不是常识吗?因为很多人会使用is_pod来判断是否使用引用,不是吗? 最佳答案 根据doc,该优化显然只适用于“小型”内置类型。.快速浏览source,看起来“小”类型被认为是满足sizeof(T)的类型.在32位机器上,这显然不包括double.在某些情况下,将参数传递为double可

c++ - 异常错误 : Access violation reading location 0xDDDDDDDD

我正在尝试用C++创建一个动态字符串数组。当尝试将我的动态字符串数组的内容显示到控制台时,我收到此错误:Exceptionthrownat0x0FD670B6(msvcp140d.dll)inAssignment4.exe:0xC0000005:Accessviolationreadinglocation0xDDDDDDDD.这是我的代码:DynamicStringArray.h#pragmaonce#include"stdafx.h"#include#includeusingnamespacestd;classDynamicStringArray{public:DynamicStri

c++ - 为什么我肯定会输入 "procedure entry point could not be located in dll"却不能?

我有一个非常模糊的问题,但我希望有人能帮忙解决。我正在修改一个C++项目,昨天它还在工作,但今天就不行了。我很确定我没有改变任何东西,但为了完全确定我再次从SVN中检查了项目,我什至恢复到以前的系统还原点(因为这是一台工作计算机,它有时会secret安装更新等。).编译成功后,程序可以启动,但是我和它交互后,却报错:过程入口点?methodName@className@@UAEXXZ无法位于动态链接库libName.dll中。我在网上搜索过,但大多数人的问题似乎是由使用的DLL的旧版本引起的。我搜索了我的电脑,没有旧版本。如果我删除正确的版本,应用程序不会启动。如果我随后重新编译该项目