草庐IT

VARIABLE_SIZE_STRUCT

全部标签

c++ - 为什么 typedef struct 会产生链接失败

所以我有一段看起来像这样的代码。typedefstruct{intfoo;intbar;voidfoobar(int,char*);}mystruct;和voidmystruct::foobar(intx,char*y){return;}和mystructobj;obj.foobar(17,"X");这一切都可以完美地编译、链接和运行。除非它没有。在一个编译器上它可以工作,而在另一个编译器(AndroidGCC)上它失败并出现链接错误:不满意的引用。如果我这样更改它,它会编译并链接。structmystruct{intfoo;intbar;voidfoobar(int,char*);}

c++ - 为什么 typedef struct 会产生链接失败

所以我有一段看起来像这样的代码。typedefstruct{intfoo;intbar;voidfoobar(int,char*);}mystruct;和voidmystruct::foobar(intx,char*y){return;}和mystructobj;obj.foobar(17,"X");这一切都可以完美地编译、链接和运行。除非它没有。在一个编译器上它可以工作,而在另一个编译器(AndroidGCC)上它失败并出现链接错误:不满意的引用。如果我这样更改它,它会编译并链接。structmystruct{intfoo;intbar;voidfoobar(int,char*);}

c++ - 在哪里画 size_t 和 unsigned int 之间的界限?

这个问题在这里已经有了答案:unsignedintvs.size_t(8个回答)关闭8年前。我目前正在将我多年来一直在开发的代码库中的unsignedint的某些用途转换为size_t。我了解两者之间的区别,例如unsignedint可能是32位,而指针和size_t可能是64位。我的问题更多是关于我应该在哪里使用其中一个以及人们使用哪种约定在两者之间进行选择。很明显,内存分配应该使用size_t而不是unsignedint作为参数,或者容器类应该使用size_t作为大小和STL中的索引。这些是阅读size_t与unsignedint的好处时引用的常见案例。然而,在进行代码库转换时,我

c++ - 在哪里画 size_t 和 unsigned int 之间的界限?

这个问题在这里已经有了答案:unsignedintvs.size_t(8个回答)关闭8年前。我目前正在将我多年来一直在开发的代码库中的unsignedint的某些用途转换为size_t。我了解两者之间的区别,例如unsignedint可能是32位,而指针和size_t可能是64位。我的问题更多是关于我应该在哪里使用其中一个以及人们使用哪种约定在两者之间进行选择。很明显,内存分配应该使用size_t而不是unsignedint作为参数,或者容器类应该使用size_t作为大小和STL中的索引。这些是阅读size_t与unsignedint的好处时引用的常见案例。然而,在进行代码库转换时,我

c++ - 哪个 C++ 标准头文件定义了 SIZE_MAX?

我正在开发一个恰好在几个地方使用SIZE_MAX的现有C++代码库。我做了一些重构,现在SIZE_MAX没有在其中一个模块中定义。这个问题出现在Travis-CI试图在Linux上构建项目。在我重构之前它工作得很好,但是很难跟踪包含了哪些确切的头文件。为了在本地复制问题,我安装了一个带有默认gcc的UbuntuVM,并且能够重现它。以下是相关来源:#includeintmain(){size_ta=SIZE_MAX;}命令行很简单:g++a.cpp错误是:a.cpp:Infunction‘intmain()’:a.cpp:5:16:error:‘SIZE_MAX’wasnotdecla

c++ - 哪个 C++ 标准头文件定义了 SIZE_MAX?

我正在开发一个恰好在几个地方使用SIZE_MAX的现有C++代码库。我做了一些重构,现在SIZE_MAX没有在其中一个模块中定义。这个问题出现在Travis-CI试图在Linux上构建项目。在我重构之前它工作得很好,但是很难跟踪包含了哪些确切的头文件。为了在本地复制问题,我安装了一个带有默认gcc的UbuntuVM,并且能够重现它。以下是相关来源:#includeintmain(){size_ta=SIZE_MAX;}命令行很简单:g++a.cpp错误是:a.cpp:Infunction‘intmain()’:a.cpp:5:16:error:‘SIZE_MAX’wasnotdecla

c++ - 解决错误: Stack around the variable 'x' was corrupted的一般方法

我有一个程序在调试时提示我VS2010中的错误:Error:Stackaroundthevariable'x'wascorrupted这为我提供了可能发生堆栈溢出的函数,但我无法直观地看到问题出在哪里。有没有用VS2010调试这个错误的通用方法?是否有可能确定哪个写操作覆盖了不正确的堆栈内存?谢谢 最佳答案 IsthereageneralwaytodebugthiserrorwithVS2010?不,没有。您所做的是以某种方式调用未定义的行为。这些行为未定义的原因是一般情况很难检测/诊断。有时证明是不可能的。但是,通常会导致您的问题

c++ - 解决错误: Stack around the variable 'x' was corrupted的一般方法

我有一个程序在调试时提示我VS2010中的错误:Error:Stackaroundthevariable'x'wascorrupted这为我提供了可能发生堆栈溢出的函数,但我无法直观地看到问题出在哪里。有没有用VS2010调试这个错误的通用方法?是否有可能确定哪个写操作覆盖了不正确的堆栈内存?谢谢 最佳答案 IsthereageneralwaytodebugthiserrorwithVS2010?不,没有。您所做的是以某种方式调用未定义的行为。这些行为未定义的原因是一般情况很难检测/诊断。有时证明是不可能的。但是,通常会导致您的问题

c++ - 为什么顺序容器同时具有 size_type 和 difference_type?

vector两者都有vector::size_type和vector::difference_type.从size_type开始,两者似乎都没有必要存在。保证能够保存与vector的最大元素数一样大的值。可能包含在给定的系统上,并且在任何有效的用例中,difference_type必须小于或等于最大元素数,即顺序容器中两个元素之间的距离永远不会大于顺序容器可以包含的最大元素数。有人可以举个例子说明两者之间有什么区别吗? 最佳答案 container::difference_type存在是因为对于某些序列容器,您可以减去迭代器。该减法

c++ - 为什么顺序容器同时具有 size_type 和 difference_type?

vector两者都有vector::size_type和vector::difference_type.从size_type开始,两者似乎都没有必要存在。保证能够保存与vector的最大元素数一样大的值。可能包含在给定的系统上,并且在任何有效的用例中,difference_type必须小于或等于最大元素数,即顺序容器中两个元素之间的距离永远不会大于顺序容器可以包含的最大元素数。有人可以举个例子说明两者之间有什么区别吗? 最佳答案 container::difference_type存在是因为对于某些序列容器,您可以减去迭代器。该减法