From a853f8733b1bbdcd304fab91514f9d1346a8feb1 Mon Sep 17 00:00:00 2001 From: Erbangurcan Date: Sun, 5 Apr 2026 20:00:30 +0300 Subject: [PATCH] Create decorators_erban_gurcan.py --- Week04/decorators_erban_gurcan.py | 37 +++++++++++++++++++++++++++++++ 1 file changed, 37 insertions(+) create mode 100644 Week04/decorators_erban_gurcan.py diff --git a/Week04/decorators_erban_gurcan.py b/Week04/decorators_erban_gurcan.py new file mode 100644 index 00000000..22aa19c6 --- /dev/null +++ b/Week04/decorators_erban_gurcan.py @@ -0,0 +1,37 @@ +import time +import tracemalloc +from functools import wraps + +def performance(fn): + """Bir fonksiyonun performansını (zaman ve bellek kullanımı) ölçen dekoratör.""" + + @wraps(fn) + def wrapper(*args, **kwargs): + # Statik değişkenleri wrapper üzerinde tanımlıyoruz ki her fonksiyonun kendi sayacı olsun + if not hasattr(wrapper, "counter"): + wrapper.counter = 0 + wrapper.total_time = 0 + wrapper.total_mem = 0 + + # Çağrı sayacını artır + wrapper.counter += 1 + + # Bellek ve zaman takibini başlat + tracemalloc.start() + start_time = time.perf_counter() + + # Dekore edilen fonksiyonu çalıştır + result = fn(*args, **kwargs) + + # Zamanı ve bellek kullanımını hesapla, takibi durdur + end_time = time.perf_counter() + current, peak = tracemalloc.get_traced_memory() + tracemalloc.stop() + + # Toplam bellek ve zamanı güncelle + wrapper.total_mem += peak + wrapper.total_time += (end_time - start_time) + + return result + + return wrapper