草庐IT

int_temp

全部标签

c++ - 2 成员结构是否可以安全地替代位压缩 int?

我有一些现有的C++代码可以通过网络发送和接收uint32_t数组。由于我的协议(protocol)发生了变化,我想用一对两个uint16_t替换这个数组中的每个条目,如果可能的话,我想这样做而不改变我发送的位数网络。将两个uint16_t值组合成单个32位宽值的一种明显方法是将低级位打包到uint32_t中,并保持数组定义不变.所以发件人的代码看起来像这样:uint32_titems[ARR_SIZE];for(std::size_ti=0;i(static_cast(field2)(field1));}接收方的代码如下所示://receiveitemsfor(std::size_t

c++ - 将 std::map<int, std::shared_ptr<Base>> 转换为 std::map<int, std::shared_ptr<Derived>> 的最有效安全方法

我们目前存储了几个不同的数据模型集合,如下所示:std::map>>models;字符串映射到一个已知的类型列表,这都是通过序列化处理的。嵌套映射包含“对象ID”和关联(反序列化)std::shared_ptr的集合DataObject是一个基类,我们从中派生出多种类型。我们有一个方法来获取给定类型的所有数据对象:staticstd::map>*getAll(std::stringtype);这只是在给定的“类型”键处返回指向map的指针。今天我遇到了一个代码审查来添加我认为调用UB但似乎起作用的以下内容。这让我有点紧张并寻找有效的解决方案:templatestaticstd::map

c++ - 为什么这个 EXC_BAD_ACCESS 发生在 long long 而不是 int 上?

我遇到了一个EXC_BAD_ACCESS,其中包含一段处理数据序列化的代码。该代码仅在设备(iPhone)上失败,在模拟器上不会。它还仅在某些数据类型上失败。这是重现问题的测试代码:templatevoidtest_alignment(){//allocatememoryandrecordtheoriginaladdressunsignedchar*origin;unsignedchar*tmp=(unsignedchar*)malloc(sizeof(unsignedshort)+sizeof(T));origin=tmp;//pushdatawithsizeof2bytes*((u

c++ - 重载 ‘QString(int)’ 不明确

下面的代码片段给出了编译错误重载“QString(int)”的调用不明确与qt4.7.3(系统是linux64bit,debian不稳定)structQSAConnection{QSAConnection():sender(0),signal(0),function_ref(){}QSAConnection(QObject*send,constchar*sig,QSObjectref):sender(send),signal(QLatin1String(sig)),function_ref(ref){}QObject*sender;QStringsignal;QSObjectfunct

c++ - 使用 int 和 string boost::interprocess 映射

我有以下代码使用boost进程间将映射保存到共享内存中usingnamespaceboost::interprocess;//Sharedmemoryfront-endthatisabletoconstructobjects//associatedwithac-string.Eraseprevioussharedmemorywiththename//tobeusedandcreatethememorysegmentatthespecifiedaddressandinitializeresourcesshared_memory_object::remove("MySharedMemory

c++ - `mpl::plus< mpl::int_<1>, mpl::int_<2>>::type` 与 `mpl::int_<3>` 不是同一类型?

下面的代码再现了一个我真的不理解boostMPL库的行为:#include#include#includeusingnamespaceboost;intmain(){typedefmpl::int_one;typedefmpl::int_two;typedefmpl::int_three;//Thefollowinglinebreakscompilation...//static_assert(is_same::type,three>::type::value,"Notthesametype");//...whilethisworksstatic_assert(mpl::plus::t

c++ - vector < vector < int >> 在第一个维度上的点积

我有vector>data_mat(3,vector(4));vectordata_vec(3);哪里data_mat可以被认为是一个矩阵和data_vec作为列vector,我正在寻找一种方法来计算data_mat的每一列的内积与data_vec,并将其存储在另一个vectordata_out(4)中.例子http://liveworkspace.org/code/2bW3X5%241使用for_each和transform,可用于计算矩阵的列和:sum=vector(data_mat[0].size());for_each(data_mat.begin(),data_mat.end

c++ - 如何将int转换为char C++

我在分配时遇到问题,我必须在方法中将时钟的三个变量(inthour、intminutes和boolafternoon)转换为字符串。我尝试将int转换为char,然后用char替换每个字符串。如果转换成功与否,该函数应该返回T/F。这是我目前所拥有的:classTime{private:inthour;intminutes;boolafternoon;public:voidsetHour(inthr);voidsetMinutes(intmin);voidsetAfternoon(boolaft);intgetHour();intgetMinutes();boolgetAfternoo

c++ - vector<bool> 可以由 int 初始化吗

我想枚举[0,31]的bool表示并将其存储在tries中供以后使用。staticconstintN=5;vectortries(N);for(inti=0;iinitializedbyint?//soIdon'thavetodobitoperationfor(intt=0;t 最佳答案 std::vector不能这样做,但是std::bitset能够。由于vector的大小在您的情况下是恒定的,因此您应该使用std::bitset.只需使用您想要的非负整数值对其进行初始化即可。请注意bitset不提供(或模仿)Container接

c++ - 为什么 int 不能用作返回类型的左值,而用户定义的类可以?

structA{};Af1(){returnA();}intf2(){returnint();}intmain(){f1()=A();//OKf2()=int();//errorC2106:'=':leftoperandmustbel-value}为什么f1()=A();正常而f2()=int();失败? 最佳答案 f1()返回A的实例。由于您没有覆盖复制/移动赋值运算符,因此编译器会为您生成一个。您实际上是在调用成员函数:f1()=A();//callsA&operator=(A&&)第二个不起作用,因为int不是类类型。