草庐IT

new_size

全部标签

c++ - GCC 拒绝在 PowerPC 上对 operator new/delete 发出长时间的调用

PowerPC分支只有24位可用于目标偏移量,因此如果文本部分变得太大,一端的分支将无法到达另一端的目标。有更长的指令序列可以到达更远的目标(偏移量是32位而不是24位),但GCC默认不使用它,除非您将其传递给-mlongcall选项。然而,即使打开了这个选项,GCC仍然会为某些函数生成短调用,即operatornew和operatordelete例如,给定以下代码:externvoidfoo();intmain(intargc,char**argv){foo();newchar;}正常运行GCC将生成程序集:bl_Z3foov//voidfoo()bl_Znwj//operatorn

c++ - GCC 拒绝在 PowerPC 上对 operator new/delete 发出长时间的调用

PowerPC分支只有24位可用于目标偏移量,因此如果文本部分变得太大,一端的分支将无法到达另一端的目标。有更长的指令序列可以到达更远的目标(偏移量是32位而不是24位),但GCC默认不使用它,除非您将其传递给-mlongcall选项。然而,即使打开了这个选项,GCC仍然会为某些函数生成短调用,即operatornew和operatordelete例如,给定以下代码:externvoidfoo();intmain(intargc,char**argv){foo();newchar;}正常运行GCC将生成程序集:bl_Z3foov//voidfoo()bl_Znwj//operatorn

c++ - 如何检测分配给 size_t 的负数?

此声明在g++-pedantic-Wall(版本4.6.3)中编译时没有警告:std::size_tfoo=-42;不那么明显的虚假是声明一个带有size_t参数的函数,并用一个负值调用它。这样的函数能否防止无意的否定论点(显示为无数个quintillion,遵守§4.7/2)?不完整的答案:只是将size_t更改为(signed)long会丢弃size_t的语义和其他优点。将其更改为ssize_t只是POSIX,而不是标准。将其更改为ptrdiff_t很脆弱,有时会损坏。测试大值(高位设置等)是任意的。 最佳答案 为此发出警告的问

c++ - 如何检测分配给 size_t 的负数?

此声明在g++-pedantic-Wall(版本4.6.3)中编译时没有警告:std::size_tfoo=-42;不那么明显的虚假是声明一个带有size_t参数的函数,并用一个负值调用它。这样的函数能否防止无意的否定论点(显示为无数个quintillion,遵守§4.7/2)?不完整的答案:只是将size_t更改为(signed)long会丢弃size_t的语义和其他优点。将其更改为ssize_t只是POSIX,而不是标准。将其更改为ptrdiff_t很脆弱,有时会损坏。测试大值(高位设置等)是任意的。 最佳答案 为此发出警告的问

c++ - 将 int 放入 char 数组中是否需要放置 new 合法?

由于C++别名规则,您不能随意将(一个int*)指向char数组,这似乎达成了一些共识。从另一个问题——Genericchar[]basedstorageandavoidingstrict-aliasingrelatedUB--似乎允许通过placementnew(重新)使用存储。alignas(int)charbuf[sizeof(int)];voidf(){//turnthememoryintoanint:(??)fromthePOVoftheabstractmachine!::new(buf)int;//isthisstrictlyrequired?(aside:it'sobvi

c++ - 将 int 放入 char 数组中是否需要放置 new 合法?

由于C++别名规则,您不能随意将(一个int*)指向char数组,这似乎达成了一些共识。从另一个问题——Genericchar[]basedstorageandavoidingstrict-aliasingrelatedUB--似乎允许通过placementnew(重新)使用存储。alignas(int)charbuf[sizeof(int)];voidf(){//turnthememoryintoanint:(??)fromthePOVoftheabstractmachine!::new(buf)int;//isthisstrictlyrequired?(aside:it'sobvi

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++ - 将 new 与 decltype 一起使用

T*t;//Tisanimplementationdetailt=newT;//wanttoavoidnamingTtoallowforflexibilityt=newdecltype(*t);//error:cannotuse'new'toallocateareferencet=newstd::remove_reference::type();//clunkyThis回答为什么decltype(*t)返回T&而不是T。我可以将我的最后一行放入宏中,但这似乎不是最理想的。有没有比我到目前为止更好的解决方案?这是否属于CodeReview? 最佳答案

c++ - 将 new 与 decltype 一起使用

T*t;//Tisanimplementationdetailt=newT;//wanttoavoidnamingTtoallowforflexibilityt=newdecltype(*t);//error:cannotuse'new'toallocateareferencet=newstd::remove_reference::type();//clunkyThis回答为什么decltype(*t)返回T&而不是T。我可以将我的最后一行放入宏中,但这似乎不是最理想的。有没有比我到目前为止更好的解决方案?这是否属于CodeReview? 最佳答案