草庐IT

c++ - 无法将 'int (*)[size]' 转换为 'int**'

我有一个256x256的二维float组,我试图将其传递给函数,但g++给我错误消息:无法将'int(*)[256]'转换为'int**'。我该如何解决这个问题?voidhaar2D(int**imgArr);intimageArray[256][256];haar2D(imageArray);我曾尝试将函数参数更改为int[256][256]和int*[256]类型,但没有成功。 最佳答案 必须按照编译器的要求声明函数参数。所以声明它要么像voidhaar2D(intimgArr[256][256]);或voidhaar2D(in

c++ - 从 'size_t' 到 'rapidjson::SizeType' 的转换

我有这个C++示例代码:voidtest(){rapidjson::Documentdoc;doc.SetObject();conststd::stringsource="Thequickbrownfoxjumpsoverthelazydog";rapidjson::Valuesource_val;source_val.SetString(source.c_str(),source.length(),doc.GetAllocator());}在编译时,在x64平台上,我收到此警告:warningC4267:'argument':conversionfromsize_ttorapidjs

c++ - size_t 数据类型可以安全地用于 str.find() 吗?

我一直在查看字符串的find()函数的代码,它们将结果存储在数据类型为size_t的变量中。然而,据我所知,size_t是一个无符号整数,如果find()没有找到预期的字符串,它会返回-1。例如,如果我有strings="asdf";size_ti=s.find("g")cout它给我4294967295。但是,如果我用int数据类型替换size_t,它会给我-1。奇怪的是,当我像这样进行比较时strings="asdf";size_ti=s.find("g")if(i==-1){do_something;}无论i是size_t还是int都有效。那我用哪个?int还是size_t?

c++ - 通过 C++ 模板元编程从数组名称推导数组维度

我记得十年前,有一段代码使用c++模板元编程,可以从数组名推导出数组维数。例如inta[2][3][4][5][6];cout输出:5但是我忘记了那个代码的细节。我记得它使用了sizeof(a)/sizeof(a[0])技巧。有谁知道怎么写吗? 最佳答案 原始代码可能构建了今天由std::rank提供的内容,请参阅“可能的实现”部分;因为不必继承整数常量(那时候不存在),它可以修改为:templatestructrank{staticsize_tconstvalue=0U;};templatestructrank{staticsiz

c++ - 如何使用 range-v3 库从 std::vector 获取列 View 和行 View ?

将7x5矩阵展平为std::vector,我想使用EricNiebler的range-v3库查看列和行。到目前为止,我设法(有改进的余地)获得单行、单列和连接行的View。参见:https://wandbox.org/permlink/8o4RgSucF3zSNuPNstd::vectornumbers={00,01,02,03,04,10,11,12,13,14,20,21,22,23,24,30,31,32,33,34,40,41,42,43,44,50,51,52,53,54,60,61,62,63,64,};constsize_tn=5;//numberofcolumns//R

c++ - 将 size_t 转换为 int 以声明 char 数组的大小

我正在尝试声明一个char数组的大小,我需要使用声明为size_t的变量的值来声明该大小。无论如何我可以将size_t变量转换为int以便我可以这样做吗? 最佳答案 size_t是一个整数类型,不需要转换。在C++中,如果您想拥有一个动态大小数组,您需要使用new来使用动态分配。也就是说,您不能使用:std::size_tsz=42;charcarray[sz];您需要改用以下内容:std::size_tsz=42;char*carray=newchar[sz];//...andlater,whenyouaredonewiththe

c++ - 在 C++ 中模拟 C# 索引器

如您所知,在C#类中,我们可以定义具有多个参数的索引器。但在C++中,运算符[]可以接受一个参数。有没有一种方法可以使用多个参数在C++中编写索引器?C#中的索引器:publicAnyTypethis[arg1,arg2,.....]{get{...};set{...};}[]C++运算符:AnyType&operator[](arg){//ourcode} 最佳答案 您可以返回一个临时文件,它包含第一个索引并引用数据源。private:classBoundArg{private:Data&data;size_ti;public:B

c++ - <cstdint> 与 std::size_t 类型

从我对boost的窥视中和libstdc++,库通常使用std::size_t和std::ssize_t每当事先不知道无符号/有符号索引的上限/下限时。我的问题是:为什么不使用uintmax_t来自而不是std::size_t和intmax_t而不是std::ssize_t? 最佳答案 前者是C++标准的一部分,后者不是。更准确地说,cstdintheader是最近才引入的(在C++11中)。这是因为stdint.h本身是C99的一部分,比C++98更新。 关于c++-与std::siz

c++ - 从连续的单词序列中提取任意范围的位的最有效方法是什么?

假设我们有一个std::vector,或任何其他序列容器(有时是双端队列),它存储uint64_t元素。现在,让我们将此vector视为size()*64的序列连续位。我需要找到由给定[begin,end)中的位组成的单词范围,鉴于end-begin所以它适合一个词。我现在的解决方案是找到其部分将构成结果的两个词,并将它们分别屏蔽和组合。因为我需要它尽可能高效,所以我尝试在没有任何if的情况下编写所有代码。分支不会导致分支预测错误,因此例如,当整个范围适合一个词或跨越两个词时,代码在两种情况下都有效,而不采用不同的路径。为此,我需要对这些shiftl进行编码和shiftr函数,除了将单

c++ - 通过来自任意索引的参数包初始化 std::array

通过可变模板参数初始化一个std::array,从给定的索引开始可以通过以下方式完成:#includetemplatestructA{templateA(size_ti,Ts...vals){constexprsize_tP=sizeof...(vals);std::arraytemp{vals...};for(size_tj=0;jarr;};但是否可以在不将参数包转换为临时元组或另一个std::array的情况下实现相同的目的? 最佳答案 您可以使用std::index_sequence和委托(delegate)构造函数:tem