![]() |
![]() ![]() |
![]() |
![]()
Post
#1
|
|
Grupa: Zarząd Postów: 2 277 Pomógł: 6 Dołączył: 27.12.2002 Skąd: Wołów/Wrocław ![]() |
jednak php5 ciągle doskonałe nie jest... Dziś prawie zawału bym dostał przez beznadziejny błąd.
Jeśli moglibyście - sprawdźcie, jak to działa na waszych wersjach php - u mnie w każdym razie na php5.0.2 zarówno na windowsie jak i linuksie pojawił się ten sam błąd. Natomiast na php 5.1.0 alfa wszystko jest OK.
Jak łatwo zauważyć - wartość iForDestruct powinna się zwiększać co każde odświerzenie, tak jak to się dzieje w przypadku iForConstruct Niestety - nic takiego się nie dzieje. ++++++++++++++++++++++++++ Co ciekawe - na bugs.php.net otrzymałem informację, że jest to normalne i oczekiwane zachowanie, ponieważ "The session is ended before destructors are run." Cikawe, czy to oznacza, że aktualne zachowanie php5.1 zostanie zmodyfikowane, czy też ktoś jednak przekonał się, że jest to jednak niezgodne z oczekiwaniem większości? |
|
|
![]()
Post
#2
|
|
Grupa: Zarejestrowani Postów: 657 Pomógł: 2 Dołączył: 15.08.2003 Skąd: Łódź Ostrzeżenie: (0%) ![]() ![]() |
|
|
|
![]()
Post
#3
|
|
Grupa: Zarejestrowani Postów: 204 Pomógł: 0 Dołączył: 26.12.2003 Skąd: Rzeszów Ostrzeżenie: (0%) ![]() ![]() |
To raczej nie jest błąd. Osobiście nie radzę polegać na __destruct().
|
|
|
![]()
Post
#4
|
|
Grupa: Zarejestrowani Postów: 521 Pomógł: 0 Dołączył: 3.11.2003 Skąd: 3city Ostrzeżenie: (0%) ![]() ![]() |
IMHO to też nie jest błąd. Jeżeli sam nie zniszczysz obiektu, żyje aż do samego końca. Samiutkiego. Nie powinno być tak, że php niszczy wszystkie obiekty, a potem zaczyna robić coś z sesją. A jak do obsługi sesji potrzebne były jakieś obiekty? A jak ktoś ma własny session handler? To co, ma mu się sesja rozwalić bo jego kod już nie istnieje?
|
|
|
![]()
Post
#5
|
|
Grupa: Zarejestrowani Postów: 109 Pomógł: 1 Dołączył: 19.03.2004 Ostrzeżenie: (0%) ![]() ![]() |
Czy - mimo, ze tak powinno byc - w php 5.1.0 to sie zmineni??
|
|
|
![]()
Post
#6
|
|
Grupa: Zarząd Postów: 2 277 Pomógł: 6 Dołączył: 27.12.2002 Skąd: Wołów/Wrocław ![]() |
IMHO powinno być tak, że obiekty z destruktorem napisanym przez użytkownika są niszczone rzed zakończeniem sesji.
Następnie handler sesji uruchamia odpowiednie funkcje (może być to odbiekt sesji, byle nie zawierał metody __destruct() ) A na końcu niszczone pozostałe obiekty. Nie wiem na pewno, ale wydaje mi się, że jakoś tak działa to w 5.1 (a może inaczej rozwiazali problem session handlera, lub narazie w tym miejscu jest jakiś bug - nie wiem - nie korzystam z własnego) Ten post edytował DeyV 5.11.2004, 14:21:29 |
|
|
![]()
Post
#7
|
|
Grupa: Zarejestrowani Postów: 521 Pomógł: 0 Dołączył: 3.11.2003 Skąd: 3city Ostrzeżenie: (0%) ![]() ![]() |
To by było straszne. To, czy w danym momencie obiekt jeszcze istnieje, zależy od tego, czy użytkownik napisze sobie (nawet pustą) metodę __destruct?! (IMG:http://forum.php.pl/style_emoticons/default/blink.gif)
A jeżeli ja chcę miec obiekt do obsługi sesji, który ma destruktor? Np. przechowuję sesje w bazie danych i chcę zakończyć połączenie. Cokolwiek. To jest masakrycznie nieintuicyjne. "Jeżeli używasz jakiś klas w obsłudze sesji, to upewnij się, że żadna z nich nie ma metody __destruct. Oraz żadna z ich klas-rodziców. Oraz rodziców rodziców..." Poza tym, DeyV, w ten sposób kochani developerzy php spowodowaliby jeszcze jedną katastrofę. Wrzucasz jakiś obiekt do sesji. Proste. Koniec skryptu. Teraz php niszczy ten obiekt, a potem - uwaga - serializuje go i zapisuje do pliku (IMG:http://forum.php.pl/style_emoticons/default/blink.gif) . Jeżeli uda im się zserializować obiekt, który właśnie zniszczyli, to chyba dostaną Nobla. |
|
|
![]() ![]() |
![]() |
Aktualny czas: 16.09.2025 - 11:16 |