Logo

Programming-Idioms

This language bar is your friend. Select your favorite languages!
  • Perl

Idiom #209 Type with automatic deep deallocation

Declare a type t which contains a string s and an integer array n with variable size, and allocate a variable v of type t. Allocate v.s and v.n and set them to the values "Hello, world!" for s and [1,4,9,16,25], respectively. Deallocate v, automatically deallocating v.s and v.n (no memory leaks).

use Moops;
class T {
    has 's', is => 'ro', isa => Str;
    has 'n', is => 'ro', isa => ArrayRef[Int];
}

{
    my $v = T->new(s => 'Hello, world!', n => [1,4,9,16,25]);
    # deallocation happens at closing brace, see explanation
}

Declaration of the variable and object instantiation/allocation for the attributes is combined into one statement for convenience. Separating this into three steps is also possible with attributes declared 'rw' (read-write).

Perl objects are reference counted. <http://p3rl.org/perlref#DESCRIPTION> When $v falls out of scope, its count is decreased to 0 and the dead object is garbage collected. <http://p3rl.org/Devel::Refcount> The memory it occupied is made available again for Perl to reuse.
#include <string>
using namespace std::string_literals;
#include <vector>
#include <memory>

struct t {
    std::string s;
    std::vector<int> n;
};

auto v = std::make_unique<t>(
    "Hello, world!"s,
    decltype(t::n){1, 4, 9, 16, 25}
);
v.reset();

// Automatically:
void fn(){
    auto v = std::make_unique<t>(
        "Hello, world!"s,
        decltype(t::n){1, 4, 9, 16, 25}
    );
}

v.reset() is explicit deallocation, the object is also automatically deallocated when it goes out of scope.

New implementation...
< >
tkoenig