![]() |
![]() |
![]()
Post
#1
|
|
Grupa: Zarejestrowani Postów: 233 Pomógł: 9 Dołączył: 3.06.2007 Ostrzeżenie: (0%) ![]() ![]() |
czy jest mi ktoś w stanie powiedzieć dlaczego kod
produkuje takie wyjście: 10000000000000000000000000000000 11000000000000000000000000000000 będę wdzięczny Ten post edytował zimi 8.12.2007, 13:43:30 |
|
|
![]() |
![]()
Post
#2
|
|
Grupa: Przyjaciele php.pl Postów: 5 724 Pomógł: 259 Dołączył: 13.04.2004 Skąd: N/A Ostrzeżenie: (0%) ![]() ![]() |
i juz jasne? a licznby z 1ka na przedzie, w systemie U2 (uzupelnieniowym do 2ch) to liczby ujemne wiec 1<<31 to -2mld a (1<<31 >> 1) to -2mld/2, czyli -1mld edit: widocznie php uzywa http://en.wikipedia.org/wiki/Bitwise_opera...rithmetic_shift Ten post edytował dr_bonzo 8.12.2007, 14:33:07 |
|
|
![]()
Post
#3
|
|
Grupa: Zarejestrowani Postów: 233 Pomógł: 9 Dołączył: 3.06.2007 Ostrzeżenie: (0%) ![]() ![]() |
jasne, jasne, dzięki... a ja frajer myślałem że jak używam operatora przesunięcia bitowego to przesunę bity... a nie będę dzielił i mnożył przez 2... (IMG:http://forum.php.pl/style_emoticons/default/biggrin.gif) :P dopiero teraz jak zajrzałem do manuala zauważyłem:
Cytat Przesuwa bity w zmiennej $a o $b kroków w prawo (każdy krok znaczy "podzielone przez dwa"). mimo że przed napisaniem posta patrzyłem też na opis tych operatorów ;/ jeszcze raz dzięki Ten post edytował zimi 8.12.2007, 16:38:16 |
|
|
![]()
Post
#4
|
|
Grupa: Przyjaciele php.pl Postów: 5 724 Pomógł: 259 Dołączył: 13.04.2004 Skąd: N/A Ostrzeżenie: (0%) ![]() ![]() |
No bo przesuwanie bitow to ogolnie mnozenie i dzielenie przez 2. Ale gdy dochodzimy do granicy zakresu obliczen to sie "magia" dzieje (IMG:http://forum.php.pl/style_emoticons/default/smile.gif)
|
|
|
![]()
Post
#5
|
|
Grupa: Zarejestrowani Postów: 233 Pomógł: 9 Dołączył: 3.06.2007 Ostrzeżenie: (0%) ![]() ![]() |
super, ale...
jak chcesz sobie pomnożyć coś przez 2 to mnożysz sobie to przez 2 a nie przesuwasz o bit (zazwyczaj przynajmniej), a jak chcesz się przesunąć o 1 bit to co masz zrobić oprócz magicznej protezy...? dla mnie jest dość jasne że jak używasz operatorów bitowych to chcesz operować na maskach etc. a nie wykonać mnożenie... bo jest to w kodzie mało przejrzyste etc. w ogóle bezsensu wg mnie jedynie słusznym rozwiązaniem na przesunięcie bitowe jest przesunięcie bitowe "Logical shift" wypisane w linku który podałeś a problem z tego co zauważyłem pojawia się tylko gdy integer ma wartość ujemną i "chcesz dzielić" przez potęge dwójki w C to samo co w PHP niezrozumiałe jest to dla mnie... PS. jak chcesz się położyć do wyra (tak jak ja teraz po zabawie z bitami) to się kładziesz, a nie stawiasz łóżka pionowo żeby być "położonym względem łóżka"... Ten post edytował zimi 8.12.2007, 21:21:32 |
|
|
![]() ![]() |
![]() |
Aktualny czas: 15.09.2025 - 10:42 |