secure_string 实现的 c++ 自定义分配器未被调用
Custom allocator in c++ for secure_string implementation not getting invoked
我正在为基于 https://en.cppreference.com/w/cpp/named_req/Allocator.
的 c++ 中的简单和基本 secure_string 实现开发自定义分配器
我的代码,如下图,编译执行。但是,我注意到我的分配器的分配、解除分配方法没有得到执行。我错过了什么?
static inline void secure_zero_memory(void *p, std::size_t n) noexcept
{
std::fill_n(static_cast<volatile unsigned char*>(p), n, 0);
}
template <typename T>
struct secure_allocator
{
using value_type = T;
secure_allocator() = default;
template <typename U>
secure_allocator(secure_allocator const&) noexcept {}
template <typename U>
secure_allocator& operator=(secure_allocator<U> const& ) { return *this;}
// define rebind structure for allocator
template <class U>
struct rebind { typedef secure_allocator<U> other; };
T* allocate(std::size_t n)
{
std::cout << "Allocating " << n << " bytes\n";
return std::allocator<T>{}.allocate(n);
}
void deallocate(T *p, std::size_t n) noexcept
{
secure_zero_memory(p, n * sizeof (*p));
std::cout << "secure_zeroed memory, deleting buffer\n";
std::allocator<T>{}.deallocate(p, n);
}
};
template <typename T, typename U>
constexpr bool operator==(secure_allocator<T> const&, secure_allocator<U> const&)
{
return true;
}
template <typename T, typename U>
constexpr bool operator!=(secure_allocator<T> const&, secure_allocator<U> const&)
{
return false;
}
using secure_string = std::basic_string<char, std::char_traits<char>, secure_allocator<char> >;
上面的 cout 语句不产生任何输出。
这是一个用法示例
{
secure_string ss = "";
std::cin >> ss;
std::cout << ss;
}
小字符串优化
您正在看到 小字符串优化(或者更确切地说,也许没有看到...)。尝试分配一个更大的字符串,您会看到您的分配器如您所愿地被调用。
我正在为基于 https://en.cppreference.com/w/cpp/named_req/Allocator.
的 c++ 中的简单和基本 secure_string 实现开发自定义分配器我的代码,如下图,编译执行。但是,我注意到我的分配器的分配、解除分配方法没有得到执行。我错过了什么?
static inline void secure_zero_memory(void *p, std::size_t n) noexcept
{
std::fill_n(static_cast<volatile unsigned char*>(p), n, 0);
}
template <typename T>
struct secure_allocator
{
using value_type = T;
secure_allocator() = default;
template <typename U>
secure_allocator(secure_allocator const&) noexcept {}
template <typename U>
secure_allocator& operator=(secure_allocator<U> const& ) { return *this;}
// define rebind structure for allocator
template <class U>
struct rebind { typedef secure_allocator<U> other; };
T* allocate(std::size_t n)
{
std::cout << "Allocating " << n << " bytes\n";
return std::allocator<T>{}.allocate(n);
}
void deallocate(T *p, std::size_t n) noexcept
{
secure_zero_memory(p, n * sizeof (*p));
std::cout << "secure_zeroed memory, deleting buffer\n";
std::allocator<T>{}.deallocate(p, n);
}
};
template <typename T, typename U>
constexpr bool operator==(secure_allocator<T> const&, secure_allocator<U> const&)
{
return true;
}
template <typename T, typename U>
constexpr bool operator!=(secure_allocator<T> const&, secure_allocator<U> const&)
{
return false;
}
using secure_string = std::basic_string<char, std::char_traits<char>, secure_allocator<char> >;
上面的 cout 语句不产生任何输出。 这是一个用法示例
{
secure_string ss = "";
std::cin >> ss;
std::cout << ss;
}
小字符串优化
您正在看到 小字符串优化(或者更确切地说,也许没有看到...)。尝试分配一个更大的字符串,您会看到您的分配器如您所愿地被调用。