c++ - 整数环绕?

标签 c++ casting queue bytearray void-pointers

我试图在队列中存储一些整数,该队列基本上是一个固定大小的 char 数组,逐字节存储整数(或每个值):

class fixed_size_queue{
    char *buffer;
    unsigned int head;
    int tail;
    q_typeinfo   tinfo;
public:
    fixed_size_queue(q_typeinfo tinfo_):tinfo(tinfo_) { 
    buffer = new char[MAX_SIZE*tinfo.get_size()];
    head = 0;
    tail = -1;
    }
    char* pop() {
    char* value = buffer+head;
    head++;
    return value;
    }
    void push(char* value) {
    tail++;
    buffer[tail] = *value;
    cout<<"pushing value = "<<(int)*value<<endl; //line 22
    }
};

当尝试将值推送到此队列时,我使用:

void push_q(void* value){
    q.push(value);
}

有了上面的内容,如果我将值从 0 插入到 127,它们将被正确地插入和弹出。如果我在第 22 行推送值 128,它会输出“推送值 -128”。插入 129 输出 -127 并继续直到它再次达到 127 并环绕。

队列数组中每个整数的大小为 8(由于某些原因我将其四舍五入)但我尝试使用 4 并出现相同的奇怪错误。

我也尝试过使用 reinterpret_cast,在推送或弹出值时将“值”转换并复制到 char*,但同样的事情发生了。有人发现问题吗? 谢谢!

--更新: 最后,问题不在于类型。我只想存储任何变量的字节。例如,一个整数应拆分为 (4) 个字符字节并存储在数组中。需要的是将整数数据复制到 char 数组!上面的这个没有用,因为每次只复制一个字节。 head 和 tail 的增量也应该是 +=sizeof(int)。

最佳答案

您看到的是将数据存储在 char 数据类型中的效果 - 这通常是一个带符号的值,可以保存 -127 到 +127 之间的值(您会期望 -128,但这显然是 C++ 规范。

看看这个 SO 问题 size-of-int-long-etc并根据您对应用程序的了解来决定应该使用哪种数据类型。

关于c++ - 整数环绕?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14501191/

相关文章:

c++ - 从自定义类到内置类型的转换

c++ - 在换行后从文件中打印出字符串

c++ - 如何从(嵌套的)std::initializer_list 确定大小?

c# - 派生类的继承方式是否不同?

c# - 神秘的 System.Object.GetType() NullReferenceException

java - PriorityQueue 元素未排序

postgresql - 在 php 和 postgres 中排队

c++ - 在 CMake 中制作自定义中间体(改进 C 可编译测试器)

c++ - static_cast const 引用 void*

python多处理共享队列重新排序