我有一个固定大小的循环缓冲区(作为数组实现):在初始化时,缓冲区被指定的最大元素数填充,这允许使用单个位置索引来跟踪我们在圆中的当前位置。
访问循环缓冲区中元素的有效方法是什么?这是我目前的解决方案:
int GetElement(int index)
{
if (index >= buffer_size || index < 0)
{
// some code to handle the case
}
else
{
// wrap the index
index = end_index + index >= buffer_size ? (index + end_index) - buffer_size : end_index + index;
}
return buffer[index];
}
一些定义:
end_index
是紧跟在圆中最后一个元素之后的元素的索引(它也被认为与 start_index 或圆的第一个元素相同)。
buffer_size
是缓冲区的最大大小。