Wiem, że std::array
jest całkowicie przydzielony na stosie, ale to pytanie jest uzasadnione względami bezpieczeństwa, które wymagają dwóch rzeczy:
- Dane
std::array
zostaną zerowane lub losowo po zniszczeniu - Dane
std::array
zostaną zablokowane , tak aby nigdy nie trafiały na dysk ani w przypadku awarii, ani w pamięci wymiany
Zwykle std::vector
rozwiązaniem jest utworzenie niestandardowego programu przydzielającego, który wykonuje te czynności . Jednak std::array
nie widzę, jak to zrobić, i stąd to pytanie.
Najlepsze, co mogłem zrobić, to:
template <typename T, std::size_t Size>
struct SecureArray : public std::array<T, Size>
{
static_assert(std::is_pod<T>::value, "Only POD types allowed")
static_assert(sizeof(T) == 1, "Only 1-byte types allowed")
virtual ~SecureArray()
{
std::vector<uint8_t> d = RandomBytes(Size); // generates Size random bytes
std::memcpy(this->data(), d.data(), Size);
}
}
Ale to oczywiście nie blokuje pamięci i komplikuje schemat wydajności, std::array
który należy uzyskać, używając std::array
w pierwszej kolejności.
Czy jest jakieś lepsze rozwiązanie?