System::Buffer‑Klasse

Buffer class

Enthält Methoden, die rohe Byte-Arrays manipulieren. Dies ist ein statischer Typ ohne Instanzdienste. Sie sollten niemals Instanzen davon auf irgendeine Weise erstellen.

class Buffer

Methoden

MethodeBeschreibung
static BlockCopy(const uint8_t *, int, uint8_t *, int, int)Kopiert eine angegebene Anzahl von Bytes vom Quell‑Puffer in den Ziel‑Puffer.
static BlockCopy(const SharedPtr<Array<TSrc>>&, int, const SharedPtr<Array<TDst>>&, int, int)Interpretieren zwei angegebene typisierte Arrays als rohe Byte‑Arrays und kopieren Daten von einem zum anderen.
static BlockCopy(const System::Details::ArrayView<TSrc>&, int, const System::Details::ArrayView<TDst>&, int, int)Interpretieren zwei angegebene typisierte Arrays als rohe Byte‑Arrays und kopieren Daten von einem zum anderen.
static BlockCopy(const SharedPtr<Array<TSrc>>&, int, const System::Details::ArrayView<TDst>&, int, int)Interpretieren zwei angegebene typisierte Arrays als rohe Byte‑Arrays und kopieren Daten von einem zum anderen.
static BlockCopy(const System::Details::ArrayView<TSrc>&, int, const SharedPtr<Array<TDst>>&, int, int)Interpretieren zwei angegebene typisierte Arrays als rohe Byte‑Arrays und kopieren Daten von einem zum anderen.
static BlockCopy(const System::Details::StackArray<TSrc, NS>&, int, const System::Details::StackArray<TDst, ND>&, int, int)Interpretieren zwei angegebene typisierte Arrays als rohe Byte‑Arrays und kopieren Daten von einem zum anderen.
static BlockCopy(const SharedPtr<Array<TSrc>>&, int, const System::Details::StackArray<TDst, ND>&, int, int)Interpretieren zwei angegebene typisierte Arrays als rohe Byte‑Arrays und kopieren Daten von einem zum anderen.
static BlockCopy(const System::Details::StackArray<TSrc, NS>&, int, const SharedPtr<Array<TDst>>&, int, int)Interpretieren zwei angegebene typisierte Arrays als rohe Byte‑Arrays und kopieren Daten von einem zum anderen.
static ByteLength(const SharedPtr<Array<T>>&)Bestimmt die Anzahl der Bytes, die von allen Elementen des angegebenen Arrays belegt werden.
static ByteLength(const System::Details::ArrayView<T>&)Bestimmt die Anzahl der Bytes, die von allen Elementen des angegebenen Arrays belegt werden.
static ByteLength(const System::Details::StackArray<T, N>&)Bestimmt die Anzahl der Bytes, die von allen Elementen des angegebenen Arrays belegt werden.
static GetByte(const SharedPtr<Array<T>>&, int)Interpretieren das angegebene typisierte Array als rohes Byte‑Array und rufen den Byte‑Wert am angegebenen Byte‑Offset ab.
static GetByte(const System::Details::ArrayView<T>&, int)Interpretieren das angegebene typisierte Array als rohes Byte‑Array und rufen den Byte‑Wert am angegebenen Byte‑Offset ab.
static GetByte(const System::Details::StackArray<T, N>&, int)Interpretieren das angegebene typisierte Array als rohes Byte‑Array und rufen den Byte‑Wert am angegebenen Byte‑Offset ab.
static SetByte(const SharedPtr<Array<T>>&, int, uint8_t)Interpretiert das angegebene typisierte Array als rohes Byte-Array und setzt den angegebenen Byte-Wert an der angegebenen Byte-Position.
static SetByte(const System::Details::ArrayView<T>&, int, uint8_t)Interpretiert das angegebene typisierte Array als rohes Byte-Array und setzt den angegebenen Byte-Wert an der angegebenen Byte-Position.
static SetByte(const System::Details::StackArray<T, N>&, int, uint8_t)Interpretiert das angegebene typisierte Array als rohes Byte-Array und setzt den angegebenen Byte-Wert an der angegebenen Byte-Position.

Hinweise

#include <system/buffer.h>

using namespace System;

void Print(const SmartPtr<Array<uint8_t>> &source, int size)
{
  for (auto i = 0; i < size; i++)
  {
    std::cout << static_cast<int>(source[i]) << ' ';
  }
  std::cout << std::endl;
}

int main()
{
  // Erstelle und fülle das Array.
  const int SIZE = 16;
  auto first = MakeObject<Array<uint8_t>>(SIZE);
  for (auto i = 0; i < SIZE; ++i)
  {
    first[i] = static_cast<uint8_t>(i * 2);
  }

  // Gib die Array-Elemente aus.
  Print(first, SIZE);

  // Erstelle ein Array, das einen Teil des ersten enthält.
  auto second = MakeObject<Array<uint8_t>>(SIZE / 2);
  Buffer::BlockCopy(first, SIZE / 2, second, 0, SIZE / 2);

  // Gib die Elemente des zweiten Arrays aus.
  Print(second, SIZE / 2);

  // Setze den Wert des Elements bei Index 0 und gib die Array-Elemente aus.
  Buffer::SetByte(second, 0, 128);
  Print(second, SIZE / 2);

  return 0;
}
/*
This code example produces the following output:
0 2 4 6 8 10 12 14 16 18 20 22 24 26 28 30
16 18 20 22 24 26 28 30
128 18 20 22 24 26 28 30
*/

Siehe auch