καθορίζει τη σειρά με την οποία εκτελούνται οι δηλώσεις. Η Java παρέχει συνθήκες (, ), βρόχους (, , ) και δηλώσεις διακλάδωσης (, , ) — συν σύγχρονες βελτιώσεις όπως switch expressions.
ifswitchforwhiledo-whilebreakcontinuereturnif (score >= 90) {
grade = "A";
} else if (score >= 80) {
grade = "B";
} else {
grade = "F";
}
// ternary — concise if/else for a value
String status = (age >= 18) ? "adult" : "minor";
switch (day) {
case 1: name = "Mon"; break; // ⚠️ break needed — else it FALLS THROUGH
case 2: name = "Tue"; break;
default: name = "Unknown";
}
Η κλασική switch απαιτεί break μετά από κάθε case — η ξέχασμα αυτού προκαλεί fall-through (η εκτέλεση συνεχίζεται στο επόμενο case), μια臭 πηγή σφαλμάτων.
// arrow syntax: no fall-through, returns a value, more concise
String name = switch (day) {
case 1 -> "Mon";
case 2 -> "Tue";
case 6, 7 -> "Weekend"; // multiple labels
default -> "Unknown";
};
Η σύγχρονη switch expression εξαλείφει fall-through, μπορεί να επιστρέψει τιμή και είναι πιο καθαρή — προτιμάται στον νέο κώδικα.
// for — known iteration count
for (int i = 0; i < 10; i++) { ... }
// enhanced for-each — iterate a collection/array
for (String item : items) { ... }
// while — condition checked BEFORE each iteration
while (condition) { ... }
// do-while — body runs at least ONCE (condition checked after)
do { ... } while (condition);
for (int i = 0; i < 10; i++) {
if (i == 5) break; // exit the loop entirely
if (i % 2 == 0) continue; // skip to the next iteration
}
return result; // exit the method
// labeled break — exit nested loops
outer:
for (...) {
for (...) {
if (found) break outer; // breaks BOTH loops
}
}
Το break εξέρχεται ενός βρόχου, το continue παραλείπει στην επόμενη επανάληψη, το return εξέρχεται της μεθόδου και τα ονοματισμένα breaks μπορούν να εξέλθουν ένθετων βρόχων ταυτόχρονα.
Ο έλεγχος ροής είναι ο βασικός μηχανισμός για τη δήλωση λογικής και αποφάσεων σε οποιοδήποτε πρόγραμμα — κάθε μη-τετριμμένη μέθοδος το χρησιμοποιεί.
Η κατανόηση των κατασκευών και των λεπτοτήτων τους είναι απαραίτητη: η switch fall-through παγίδα (και η πιο ασφαλής σύγχρονη switch expression), η διαφορά μεταξύ while και do-while (εκτέλεση τουλάχιστον μία φορά), for-each για καθαρή επανάληψη συλλογής και δηλώσεις διακλάδωσης (συμπεριλαμβανομένων ονοματισμένων breaks για ένθετους βρόχους).
Η κυριαρχία αυτών — και η προτίμηση των σύγχρονων, λιγότερο απρόσεκτων μορφών (switch expressions, for-each) — είναι θεμελιώδης για τη σύνταξη σωστής, ευαναγνώστου λογικής Java και την αποφυγή κοινών σφαλμάτων ελέγχου ροής.