草庐IT

dynamic-sizing

全部标签

c++ - size_t 和 offset_t 的使用指南?

这可能是一个C++101问题:我很好奇使用size_t和offset_t的指南是什么,例如它们用于什么情况,它们不用于什么情况,等等。我没有做过很多可移植的编程,所以我通常只使用int或unsignedint这样的东西用于数组大小、索引等。但是,我发现最好尽可能使用这些更标准的typedef,所以我想知道如何正确地做到这一点。作为后续问题,对于使用VisualStudio2008在Windows上进行开发,我应该在哪里寻找实际的typedef?我发现size_t在VS安装目录中的许多header中定义,所以我不确定我应该使用哪一个,而且我找不到offset_t任何地方。

c++ - size of datatype 和 sizeof(data type) 的区别

我在学习C++时遇到了以下问题。我只是一个初学者,我很困惑。sizeof()函数不应该返回数据类型的大小吗?为什么数据对象的大小可能与其sizeof()不同?我不明白答案的解释。假设在一台假想的机器中,char的大小是32位。sizeof(char)会返回什么?一)4b)1c)依赖于实现d)机器相关答案:b说明:标准不要求char为8位,但确实要求sizeof(char)返回1。 最佳答案 sizeof运算符以bytes为单位生成类型的大小,其中字节定义为char的大小。所以根据定义,sizeof(char)始终为1,无论bitsc

c++ - 从 std::size_t* 到 long unsigned int* 的无效转换

在raspberrypi-arv7l上,我正在编译以下C++程序#includevoidfun(unsignedlongint*i){std::cout对于上面的代码,我收到以下错误:a.cpp:Infunction'intmain()':a.cpp:12:9:error:invalidconversionfrom'std::size_t*{akaunsignedint*}'to'longunsignedint*'[-fpermissive]fun(&i);^~a.cpp:3:6:note:initializingargument1of'voidfun(longunsignedint*

c++ - 使用 dynamic_cast 向下转型返回 null

我尝试使用dynamic_cast将基类对象转换为派生类对象,但dynamic_cast返回null。是否可以使用dynamic_cast向下转型?structA{virtual~A(){}};structB:A{};intmain(){A*a=newA();B*b=dynamic_cast(a);if(b){std::cout此代码打印出“无值”。 最佳答案 因为a实际上是指向A,而不是B,所以dynamic_cast会失败。Isitpossibletodowncastusingdynamic_cast?是的,你可以,例如如果a恰

c++ - MAC 操作系统 : dynamically linked library not found despite correct rpath

我有一个(相对)大的C++项目,它在ubuntu上编译和运行良好(使用cmake/catkin)。它在macos上编译得很好,但是当尝试启动可执行文件时,我收到错误消息:dyld:Librarynotloaded:.dylibReferencedfrom:/Reason:imagenotfound运行命令时:otool-l|grepLC_RPATH-A2我得到输出:cmdLC_RPATHcmdsize64path(offset12)cmdLC_RPATHcmdsize24path/sw/lib(offset12)cmdLC_RPATHcmdsize32path/usr/X11/lib(

c++ - Catch.hpp 单元测试 : How to dynamically create test cases?

我正在使用CATCHv1.1build14对我的C++代码进行单元测试。作为测试的一部分,我想检查代码中几个模块的输出。没有固定数量的模块;可以随时添加更多模块。但是,测试每个模块的代码是相同的。因此,我认为将测试代码放在for循环中是最理想的。事实上,使用catch.hpp,我已经验证了我可以在测试用例中动态创建部分,其中每个部分对应一个模块。我可以通过将SECTION宏包含在for循环中来做到这一点,例如:#include"catch.hpp"#include#include#include"myHeader.h"TEST_CASE("Moduletesting","[module

c++ - 对未知大小数组的引用的列表初始化 : is it supposed to deduce the array size?

以下代码在Clang中编译良好并输出int[3]数组的大小#includeintmain(){constint(&a)[]={1,2,3};std::cout但是,在GCC中,声明编译得很好,但是sizeofa没有:显然GCC拒绝“推断”数组大小并以a作为结尾对constint[]类型的引用,该类型不完整。此类初始化的预期行为是什么?9.3.4/3似乎是此类情况下标准的相关部分,但它本身似乎并不能最终回答这个问题。 最佳答案 标准在这一点上并不完全清楚,我认为GCC的解释很可能是WG21的意图,但我不确定。标准的相关部分是[dcl.

c++ - std::list 中的 max_size() 函数如何计算最大尺寸?

在std::list中,max_size()函数中的最大大小是如何计算的?现在我意识到这取决于实现,但假设我是制作标准库的人。我将如何确定可移植的特定类型T的list的最大限制? 最佳答案 它几乎总是N的最大值,其中容器最多可以有N个元素。这几乎总是意味着所讨论平台上无符号整数类型的最大值除以要存储在容器中的元素类型的大小。 关于c++-std::list中的max_size()函数如何计算最大尺寸?,我们在StackOverflow上找到一个类似的问题: h

c++ - 将 bool R vector 传递给 C dynamic_bitset

将Rboolvector传递给C++dynamic_bitsetvector的最佳方法是什么?有没有一种方法可以使用指针和vector长度来构造一个dynamic_bitset对象,就像vector类一样?您会推荐使用Rcpp吗?感谢您的帮助和时间... 最佳答案 我只想创建dynamic_bitset像这样:#include#includeusingnamespaceRcpp;//[[Rcpp::export]]voidcreate_dynamic_bitset(LogicalVectorx){intn=x.size();boos

c++ - unsigned long vs size_t 导致函数重载失败

我定义了一个函数:voidmyfunc(size_tparam1,size_tparam2){...}它工作正常。但是当我尝试重载这个函数时voidmyfunc(unsignedlongparam1,unsignedlongparam2){...}编译失败,提示如下:错误:无法重载myfunc(unsignedlongparam1,unsignedlongparam2)。如何在不将输入参数静态转换为size_t的情况下解决这个问题?谢谢! 最佳答案 听起来size_t和unsignedlong在您的系统上是同一类型;编译器提示你有两