Close Menu
Datormagazin
    Facebook
    Senaste testerna
    • Test: Huawei Watch 5 & Fit 4 Pro
    • Test: Huawei Watch GT 3 SE
    • Test: Beoplay EX
    • Test: Sony Xperia 1 III
    • Test: Cooler Master Masterair MA624 Stealth och MA612 Stealth ARGB
    DatormagazinDatormagazin
    • Hem
    • Nyheter
    • Tester
      1. Toppklass
      2. DMZ Rekommenderar
      3. Gaming
      4. Jämförande test
      5. View All

      Test: OnePlus Pad 3 och Smart Keyboard

      10 juni, 2025

      Test: Huawei Watch 5 & Fit 4 Pro

      15 maj, 2025

      Motorola Razr 60 Ultra

      6 maj, 2025

      Test: Sennheiser HD 550

      7 april, 2025

      Test: Xiaomi POCO F7 Ultra

      6 juni, 2025

      Test: Kioxia Exceria Plus G4

      28 maj, 2025

      Test: AOC AGON PRO AG456UCZD

      21 maj, 2025

      Test: Asus ZenScreen Duo OLED MQ149CD

      18 maj, 2025

      Test: Kioxia Exceria Plus G4

      28 maj, 2025

      Test: AOC AGON PRO AG456UCZD

      21 maj, 2025

      Test: Cooler Master Masterliquid 360 ION & Hyper 612 APEX

      18 april, 2025

      Test: Sennheiser HD 550

      7 april, 2025

      Test: Logitech Ergo K860 vs. Microsoft Sculpt Ergonomic Keyboard

      19 augusti, 2021

      Vi utser den bästa multiskrivaren

      20 maj, 2021

      Test: Cooler Master Masterair MA624 Stealth och MA612 Stealth ARGB

      12 maj, 2021

      Test: Oneplus 9 Pro och Oneplus 9

      21 april, 2021

      Test: OnePlus Pad 3 och Smart Keyboard

      10 juni, 2025

      Test: Xiaomi POCO F7 Ultra

      6 juni, 2025

      Teknologin som driver e-sportturneringar: Hur allt hänger ihop

      2 juni, 2025

      Test: Asus NUC 15 Pro+

      1 juni, 2025
    • DMZ-riggen
    • Programtips
    • Gaming
    • Fråga experten
      • Hårdvara
      • Mjukvara
    • DMZ Retro
    • Shop
    • Om DMZ
      • Om Datormagazin
      • Annonsera
      • Nyhetsbrevet
      • Kundtjänst
      • Press & PR
    Facebook
    Datormagazin
    Hem » Fråga experten » Rekursivitet i PHP
    Fråga experten

    Rekursivitet i PHP

    redaktionenBy redaktionen16 februari, 20092 Mins Read

    Fråga

    Jag håller på med ett rekursivt script. Jag har testat det och det fungerar bra upp till en viss nivå, men när det blir fråga om lite mer komplicerad input stannar det utan felmeddelande. Precis som om minnet tar slut eller nåt sådant. I Apache-loggen står det: child pid 7638 exit signal Segmentation fault (11)

    Jag har gjort det som ett CLI och då får jag ”Segmenteringsfel”.

    Koden är rätt, men förmodligen gör jag något logiskt fel. Har försökt googla, men segmenteringsfel verkar kunna vara i stort sett vilket programmeringsfel som helst som orsakas av att man försöker komma åt minnet på ett felaktigt sätt.

    Jag har ändrat error reporting mm:

    ini_set(”error_reporting”, ”E_ALL”); ini_set(”display_errors”, ”On”); ini_set(”memory_limit”, -1); ini_set(”max_execution_time”, 0);

    men det verkar som om det inte spelar någon roll. Får inget meddelande om vad som är fel.

    Det finns ett Return, men det kan ta ca 5-6 tusen rekursiva anrop innan detta inträffar. Själva funktionen är liten och tar inte mycket minne. Ska inte detta gå?

    /Hälsningar jodomama

    Svar

    Hej Jodomama.

    När man använder rekursivitet så kommer varje anrop att använda en del av stacken, bland annat för parameteröverföring men även för lokala variabler och återhoppsadress.

    Ett sätt att minska mängden allokerad data på stacken är att använda heapen istället. Dock kommer eventuella pekare ta plats i stacken.

    Vid några tester i PHP5.2.8 kom vi fram till följande minnesgränser,

    memory_limit: 1M
    rekursioner 5421
    fel: Fatal error: Allowed memory size of 1048576 bytes exhausted (tried to allocate 40 bytes) in

    memory_limit: 2M
    rekursioner 11126
    fel: Fatal error: Allowed memory size of 2097152 bytes exhausted (tried to allocate 40 bytes) in

    memory_limit: 4M
    rekursioner 19184
    fel (i syslog): child pid 2066 exit signal Segmentation fault (11)

    memory_limit: 128M
    rekursioner 19184
    fel (i syslog): child pid 2066 exit signal Segmentation fault (11)

    memory_limit: 256M
    rekursioner 19184
    fel (i syslog): child pid 2066 exit signal Segmentation fault (11)

    Som du ser har vi provat att utöka minnet, vilket hjälper till en viss mån. Men tillsist uppkommer ändå en gräns som begränsar antalet anrop (19184 st anrop)

    På http://bugs.php.net/bug.php?id=43187 kan man läsa mer om PHPs ståndpunkt i denna fråga.

    Är det tail recusion (se http://en.wikipedia.org/wiki/Tail_recursion) kan man lätt skriva om metoden. Självklart kan du även skriva om andra typer av rekursioner, men det kan vara besvärligare.

    Oavsett ser det tyvärr ut som du får skriva om din källkod.

    Lycka till

    Share. Facebook Twitter LinkedIn Email WhatsApp

    Missa inte

    Fråga experten

    Konvertera till Windows 11

    8 november, 20211 Min Read
    linuxtips

    Minitips – Fånga ett fönster som rymt

    22 oktober, 20211 Min Read
    Fråga experten

    Hur får jag Wi-Fi genom betongvägg?

    26 augusti, 20212 Mins Read
    Fråga experten

    Hur kan jag slippa nätverkskabel till övervåningen?

    6 augusti, 20212 Mins Read
    Add A Comment

    Leave A Reply Cancel Reply

    Senaste kommentarerna
    • Andreas Rejbrand om Test: Samsung Galaxy watch 7
    • Petter om Test: Samsung Galaxy watch 7
    • Anders Öhman om Test: Samsung Galaxy watch 7
    • Tobias om Test: Samsung Galaxy watch 7
    • Anders om Test: HP Envy X360
    Fler nyheter

    Glorious Gamings Pro-möss lanseras i vit

    25 september, 2024

    Gen Z och kvinnor väljer mobilen framför sex

    25 september, 2024

    Många Svenska företag lever inte upp till sina visioner gällande hållbarhet.

    21 augusti, 2024

    Nya Philips 49B2U6903CH – en skärm för ”den moderna arbetsplatsen”

    28 juni, 2024

    Toppklass

    Test: Huawei Watch 5 & Fit 4 Pro

    15 maj, 2025

    Test: OnePlus 12

    23 februari, 2024

    Test: Philips Evnia 49M2C8900

    7 januari, 2024

    Test: Corsair Dominator Titanium DDR5

    28 september, 2023
      Kontaktinformation
      Kontaktinformation

      Omsoc Publishing AB
      Datormagazin
      Box 440 73
      100 73 Stockholm
      Sweden

      Telefonnummer: +46 8–208 118
      E-post: datormagazin@datormagazin.se

      Missa inte

      M.2 optimerad NAS-prestanda

      2 september, 2024

      WiFi 7 – När, var, hur & varför

      23 augusti, 2023

      TCS digitala tvillingar och deras prediktiva kraft.

      4 juli, 2023
      Datormagazin
      Facebook YouTube RSS
      • Om cookies
      • Hantering av personuppgifter
      • Köpvillkor www.datormagazin.se
      © 2025 Datormagazin/Omsoc Publishing AB, org-nr: 559034-9014 – Ansvarig utgivare: Anders Öhman

      Type above and press Enter to search. Press Esc to cancel.