草庐IT

max-size

全部标签

c++ - 将 int 转换为 size_t

我想知道当我传递integer时clang编译器的以下警告到std::initializer_list:non-constant-expressioncannotbenarrowedfromtype'int'to'unsignedlong'ininitializerlist为什么可以int被转换为size_t但是一个int不会传递给std::initializer_list,即intmain(){size_ts_t=0;inti=0;std::initializer_listi_l={i};//warnings_t=i;//nowarningreturn0;}

c++ - std::map::size_type 对于 std::map 其 value_type 是它自己的 size_type

我有一个std::map,float>这占用了太多内存,为了使用更少的内存,我决定将唯一字符串映射到整数(例如std::map,其中每个新的唯一字符串都映射到map的当前size()),并将这些整数值用作映射的成对键(例如,std::map,float>)。而不是int,我想用std::map::size_type:usingmap_index=std::map::size_type;std::pairkey;当然,这不会编译,因为我需要为map提供参数列表:vector.cc:14:19:error:invaliduseoftemplate-name`std::map'without

c++ - 如何实现 array::max_size()?

我正在构建自己的array用于娱乐和教育的类模板。C++0x标准草案规定了一个成员函数max_size()对于所有容器为distance(begin(),end())“为了尽可能大的容器”。如何为数组实现这个成员函数?我只是返回std::numeric_limits::max()吗?,还是结果应该取决于元素类型?嗯,都是std::array来自当前的g++和boost::array返回n来自max_size():#include#include#includeintmain(){std::arrayfoo;std::coutbar;std::cout 最佳答

【C++修行之道】竞赛常用库函数(sort,min和max函数,min_element和max_element、nth_element)

目录一、sort1.1sort简介语法参数功能适用容器1.2sort的用法1.3自定义比较函数 示例1265蓝桥题——排序二、min和max函数三、min_element和max_element 497蓝桥题——成绩分析四、nth_element一、sort1.1sort简介sort函数包含在头文件中。在使用前需要#include或使用万能头文件。sort是C++标准库中的一个函数模板,用于对指定范围内的元素进行排序。sort算法使用的是快速排序(QuickSort)或者类似快速排序的改进算法,具有较好的平均时间复杂度,一般为O(nlogn)语法Sort(start,end,cmp)参数(1)

用于负数组索引的 C++ size_t 和 ptrdiff_t

我很难在size_t之间做出选择和ptrdiff_t对于索引的类型,应该需要能够存储负值。准确地说,在我的代码中我需要实现一个数组。我收到它的长度(在构造函数中)作为size_t的类型,当我重载[]operator我需要索引的类型为ptrdiff_t(而不是size_t),因为我想允许负索引,如本例所示:std::size_tlength=50;MyVectorvec(length);vec[0]=10;MyVectorvec2=vec+1;std::cout上述设计引起的问题是可用索引的范围受限于ptrdiff_t的最大值。,在某些机器上,这个上限小于size_t的最大值。即std:

微信小程序上传时报错message:Error: 系统错误,错误码:80051,source size 2148KB exceed max limit 2MB

问题:微信小程序上传时错误码:80051,sourcesize2248KBexceedmaxlimit2MB问题原因:由于代码中的静态资源图片大小超了200k以及主包的体积超出1.5M解决办法分包tabBar是主包的,不需要分包处理,以下是分包示例项目目录如下首先将login,register、和webview进行分包,通过引入路由的方式进行分包处理router代码如下//router/index.tsconstwebview=require("./webview");constregister=require("./register");constlogin=require("./login

C++ "new T[size]"不起作用?

我有一个模板类定义为:#include#includeusingnamespacestd;templateclasstbufferpool{private:constintm_initial;constintm_size;constintm_total;T*m_buffer;vectorm_queue;public://constructortbufferpool(intinitial,intsize):m_initial(initial),m_size(size),m_total(initial*size){m_buffer=newT[m_total];T*next_buffer=m

c++ - Visual Studio 2017 : ambiguous symbol size_t in linux projects

在VisualStudio2017中创建Linux项目并在源代码中插入usingnamespacestd;时,如下所示:#include#includeusingnamespacestd;intmain(){size_ti=1;strings=to_string(i);coutVS下划线size_t说是有歧义的符号。如果我按F12(转到定义),它会为我提供两个定义位置:来自stddef.h(C:\ProgramFiles(x86)\MicrosoftVisualStudio14.0\VC\Linux\include\usr\include\x86_64-linux-gnu\5\incl

c++ - 为什么 unordered_set 操作像计数和删除返回一个 size_type?

显然,unordered_set::erase和unordered_set::count返回一些不是严格bool值的东西(从逻辑上讲,也就是说,我不是在谈论实际类型)。链接页面读取第三个版本的删除:size_typeerase(constkey_type&key);Removestheelementswiththekeyvaluekey这有一种语气,表明可能不止一个元素具有给定的键。它没有明确说明这一点,但听起来很像。现在,集合(即使是无序集合)的要点是每个元素都有一次。标准库承认bool类型的存在并将其用于bool值,如unordered_set::empty().那么,在上述情况下

c++ - RAND_MAX 和 UINT_MAX 之间的差异会有所不同吗?

我的作业涉及生成0和2^30之间的随机整数。现在,在过去我们了解到rand()只返回小于RAND_MAX的整数,这小于UINT_MAX,并且我们可以使用位移来填充UINT_MAX容量。从我所做的一些阅读中(这里,关于SO),我意识到如果这些数字的分布对我很重要,这可能不是一个好主意。话虽如此,我的教授已经指定了这种方法。我的问题是,位移多少?RAND_MAX和UINT_MAX之间的差异是否始终存在一个安全常数来进行位移?或者是否需要进行一些初始探测以确定要移位的数字?我是否应该保持位移一点点并检查UINT_MAX?我问的原因是,UINT_MAX被定义为至少是某个数字(65535),但在