Nie jesteś zalogowany.
Jeśli nie posiadasz konta, zarejestruj je już teraz! Pozwoli Ci ono w pełni korzystać z naszego serwisu. Spamerom dziękujemy!
Prosimy o pomoc dla małej Julki — przekaż 1% podatku na Fundacji Dzieciom zdazyć z Pomocą.
Więcej informacji na dug.net.pl/pomagamy/.
Strony: 1
Cześć, niedawno zacząłem swoją przygodę z Javą, zaopatrzyłem się w książkę i przerabiając jeden z przykładów napotkałem coś czego nie rozumiem. Chodzi mi dokładnie o linijkę w klasie pole:
"System.out.println("Pole: " + figref.area());"
jako wynik wyświetla mi się coś takiego:
Wewnątrz metody area() z prostokat
Pole: 45.0
i tutaj jest moje pytanie: Dlaczego " Pole: " nie jest wyświetlane na początku, tylko w "środku"? Czy mógłby mi ktoś odpowiedzieć? Niżej zamieszczam kod:
public class Figura { double dim1; double dim2; Figura (double a, double b) { dim1 = a; dim2 = b; } double area () { System.out.println("Pole figury nie jest zdefiniowane"); return 0; } } public class prostokat extends Figura { prostokat (double a, double b) { super (a,b); } double area () { System.out.println("Wewnątrz metody area() z prostokat"); return dim1*dim2; } } public class pole { public static void main (String args[]) { prostokat p = new prostokat (9, 5); Figura figref; figref = p; System.out.println("Pole: " + figref.area()); } }
Offline
Nie rozumiem Cię szefie.
Skompilowałem twój kod i dostaje taki efekt:
dominik@m31-3:~/src/3$ java pole Wewnątrz metody area() z prostokat Pole: 45.0 dominik@m31-3:~/src/3$
"Pole" wyswietla mi od pierwszej kolumny czyli nie wiem o co ci biega :>
Offline
Chodzi mi o kolejność wyświetlania, bo na przykład:
... int a = 10; System.out.print("zmienna a jest równa " + a); ...
po skompilowaniu da efekt:
zmienna a jest równa 10
natomiast gdyby napisać
... int a = 10; System.out.print(a + " to wartość zmiennej a"); ...
to efekt byłby taki
10 to wartość zmiennej a
Więc patrząc na to co jest wyżej
System.out.println("Pole: " + figref.area());
powinno dać
Pole: Wewnątrz metody area() z prostokat 45.0
ale z niewiadomej dla mnie przyczyny wyświetla inaczej
Offline
to jest po prostu blad w zalozeniach ;) W miejscu w ktorym masz
System.out.println("Pole: " + figref.area());
przed wyswietleniem MUSI zostac wykonana funkcja figref.area(), zeby rzecz jasna cos zwrocila. Tyle ze Twoja funkcja area wyglada tak
double area () { System.out.println("Wewnątrz metody area() z prostokat"); return dim1*dim2; }
i wyswietla inny ciag znakow PRZED zwroceniem wartosci, co oczywiscie powoduje, ze napis "Wewnatrz... " pojawia sie jako pierwszy
Offline
Dzięki za pomoc, zrozumiałem :) faktycznie błąd w założeniach
Offline
Strony: 1
Time (s) | Query |
---|---|
0.00011 | SET CHARSET latin2 |
0.00004 | SET NAMES latin2 |
0.00098 | SELECT u.*, g.*, o.logged FROM punbb_users AS u INNER JOIN punbb_groups AS g ON u.group_id=g.g_id LEFT JOIN punbb_online AS o ON o.ident='3.133.117.107' WHERE u.id=1 |
0.00067 | REPLACE INTO punbb_online (user_id, ident, logged) VALUES(1, '3.133.117.107', 1732305419) |
0.00052 | SELECT * FROM punbb_online WHERE logged<1732305119 |
0.00065 | SELECT topic_id FROM punbb_posts WHERE id=48362 |
0.00004 | SELECT id FROM punbb_posts WHERE topic_id=6313 ORDER BY posted |
0.00053 | SELECT t.subject, t.closed, t.num_replies, t.sticky, f.id AS forum_id, f.forum_name, f.moderators, fp.post_replies, 0 FROM punbb_topics AS t INNER JOIN punbb_forums AS f ON f.id=t.forum_id LEFT JOIN punbb_forum_perms AS fp ON (fp.forum_id=f.id AND fp.group_id=3) WHERE (fp.read_forum IS NULL OR fp.read_forum=1) AND t.id=6313 AND t.moved_to IS NULL |
0.00007 | SELECT search_for, replace_with FROM punbb_censoring |
0.00108 | SELECT u.email, u.title, u.url, u.location, u.use_avatar, u.signature, u.email_setting, u.num_posts, u.registered, u.admin_note, p.id, p.poster AS username, p.poster_id, p.poster_ip, p.poster_email, p.message, p.hide_smilies, p.posted, p.edited, p.edited_by, g.g_id, g.g_user_title, o.user_id AS is_online FROM punbb_posts AS p INNER JOIN punbb_users AS u ON u.id=p.poster_id INNER JOIN punbb_groups AS g ON g.g_id=u.group_id LEFT JOIN punbb_online AS o ON (o.user_id=u.id AND o.user_id!=1 AND o.idle=0) WHERE p.topic_id=6313 ORDER BY p.id LIMIT 0,25 |
0.00079 | UPDATE punbb_topics SET num_views=num_views+1 WHERE id=6313 |
Total query time: 0.00548 s |