summaryrefslogtreecommitdiffhomepage
path: root/examples
diff options
context:
space:
mode:
authorAmlal El Mahrouss <amlal@nekernel.org>2025-07-19 11:42:49 +0100
committerAmlal El Mahrouss <amlal@nekernel.org>2025-07-19 11:42:49 +0100
commit701789c70a006d349741ce97494b867b2e22c530 (patch)
tree96ff19ff3e98117b0934ce3ad1b912ec2cd5e04c /examples
parent0b293838b939e0288670893db281cbe4917141c9 (diff)
feat: better 'tracked_ptr' module, and added 'eval_true' and 'eval_false' to 'opt.hpp'
Signed-off-by: Amlal El Mahrouss <amlal@nekernel.org>
Diffstat (limited to 'examples')
-rw-r--r--examples/tracked_ptr/tracked_ptr.cc34
1 files changed, 28 insertions, 6 deletions
diff --git a/examples/tracked_ptr/tracked_ptr.cc b/examples/tracked_ptr/tracked_ptr.cc
index e77155d..c182494 100644
--- a/examples/tracked_ptr/tracked_ptr.cc
+++ b/examples/tracked_ptr/tracked_ptr.cc
@@ -1,4 +1,4 @@
-/*
+/*
tracked_ptr example
written by Amlal El Mahrouss.
licensed under the MIT license
@@ -7,24 +7,46 @@
#include <lib/memory/tracked_ptr.hpp>
#include <iostream>
-void foo()
+void summon_tracked_ptr()
{
snu::memory::tracked_ptr<int> ptr = snu::memory::make_tracked(42);
std::cout << ptr.data() << "=" << ptr.manager().allocator().allocated_count_ << std::endl;
}
+void summon_leak_tracked_ptr()
+{
+ snu::memory::tracked_ptr<int>* ptr = new snu::memory::tracked_ptr<int>(42);
+ std::cout << ptr->data() << "=" << ptr->manager().allocator().allocated_count_ << std::endl;
+}
+
/* finally test it */
int main(int argc, char** argv)
{
- foo();
- foo();
- foo();
- foo();
+ summon_tracked_ptr();
+ summon_tracked_ptr();
+ summon_tracked_ptr();
+ summon_tracked_ptr();
snu::memory::tracked_ptr<int> ptr;
std::cout << ptr.data() << "=" << ptr.manager().allocator().allocated_count_ << std::endl;
+
std::cout << "total=" << ptr.manager().allocator().deallocated_count_ << std::endl;
+ std::cout << "leak-detected=" << std::boolalpha << (ptr.manager().allocator().allocated_count_ > ptr.manager().allocator().deallocated_count_) << std::endl;
+
+ summon_leak_tracked_ptr();
+ summon_leak_tracked_ptr();
+ summon_leak_tracked_ptr();
+ summon_leak_tracked_ptr();
+ summon_leak_tracked_ptr();
+ summon_leak_tracked_ptr();
+ summon_leak_tracked_ptr();
+ summon_leak_tracked_ptr();
+
+ std::cout << "total=" << ptr.manager().allocator().deallocated_count_ << std::endl;
+
+ std::cout << "leak-detected=" << std::boolalpha << (ptr.manager().allocator().allocated_count_ > ptr.manager().allocator().deallocated_count_) << std::endl;
+
return 0;
}