From c1ed83f99f365ce82a38e55c24da72bfb9403eac Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Recep=20Kadir=20Alt=C4=B1nta=C5=9F?= <126012220+kdraltntas@users.noreply.github.com> Date: Sun, 30 Nov 2025 01:23:19 +0300 Subject: [PATCH] Add performance decorator with memory and time tracking Implement a performance decorator to measure execution time and memory usage. --- ...tors_recepkadir_alt\304\261nta\305\237.py" | 26 +++++++++++++++++++ 1 file changed, 26 insertions(+) create mode 100644 "Week04/decorators_recepkadir_alt\304\261nta\305\237.py" diff --git "a/Week04/decorators_recepkadir_alt\304\261nta\305\237.py" "b/Week04/decorators_recepkadir_alt\304\261nta\305\237.py" new file mode 100644 index 00000000..8dfae49f --- /dev/null +++ "b/Week04/decorators_recepkadir_alt\304\261nta\305\237.py" @@ -0,0 +1,26 @@ +import time +import tracemalloc +import functools + +def performance(func): + @functools.wraps(func) + def wrapper(*args, **kwargs): + tracemalloc.start() + start_time = time.perf_counter() + + result = func(*args, **kwargs) + + current, peak = tracemalloc.get_traced_memory() + tracemalloc.stop() + end_time = time.perf_counter() + + performance.counter += 1 + performance.total_time += (end_time - start_time) + performance.total_mem += peak + + return result + return wrapper + +performance.counter = 0 +performance.total_time = 0 +performance.total_mem = 0