Table of Contents

Class BufferPool

命名空間
easyar

BufferPool 實現了一個記憶體池,可用於自定義攝像頭接入等需要反覆分配相同大小記憶體的功能,降低記憶體分配耗時。

BufferPool

建構函式

BufferPool

block_size為每個 Buffer 的位元組大小。 capacity為最大 Buffer 數量。

void easyar_BufferPool__ctor(int block_size, int capacity, easyar_BufferPool * * Return)
BufferPool(int block_size, int capacity)
public BufferPool(int block_size, int capacity)
constructor(block_size: Int, capacity: Int)
+ (easyar_BufferPool *) create:(int)block_size capacity:(int)capacity
public convenience init(_ block_size: Int32, _ capacity: Int32)
public BufferPool(int block_size, int capacity)

參數

名稱 類型 描述
block_size Int32
capacity Int32

方法

block_size

每個 Buffer 的位元組大小。

int easyar_BufferPool_block_size(const easyar_BufferPool * This)
int block_size()
public int block_size()
fun block_size(): Int
- (int)block_size
public func block_size() -> Int32
public virtual int block_size()

傳回值

類型 描述
Int32

capacity

最大 Buffer 數量。

int easyar_BufferPool_capacity(const easyar_BufferPool * This)
int capacity()
public int capacity()
fun capacity(): Int
- (int)capacity
public func capacity() -> Int32
public virtual int capacity()

傳回值

類型 描述
Int32

size

當前外部獲得的 Buffer 數量。

int easyar_BufferPool_size(const easyar_BufferPool * This)
int size()
public int size()
fun size(): Int
- (int)size
public func size() -> Int32
public virtual int size()

傳回值

類型 描述
Int32

tryAcquire

嘗試獲得記憶體區塊。如果當前外部獲得的 Buffer 數量沒有達到最大 Buffer 數量,則取出或分配一個新的 Buffer ,否則返回空。

void easyar_BufferPool_tryAcquire(easyar_BufferPool * This, easyar_OptionalOfBuffer * Return)
std::optional<std::shared_ptr<Buffer>> tryAcquire()
public @Nullable Buffer tryAcquire()
fun tryAcquire(): Buffer?
- (easyar_Buffer *)tryAcquire
public func tryAcquire() -> Buffer?
public virtual Optional<Buffer> tryAcquire()

傳回值

類型 描述
Optional<Buffer>