Table of Contents
Variable occlusion
Example Analysis
Solution
Things to note
Summarize
Home Java javaTutorial Common causes and solutions for failure of conditional judgment in Java

Common causes and solutions for failure of conditional judgment in Java

Aug 30, 2025 am 10:06 AM

Common causes and solutions for failure of conditional judgment in Java

This article aims to help developers solve the problem of invalidity of conditional judgment statements in Java programs. By analyzing an example of the principle of dependency inversion, we explore the concept of variable shadowing in depth and provide modified code examples to ensure that the program can run as expected and achieve the correct switching of switch states.

In Java programming, we often encounter conditional judgment statements (such as if statements) that cannot work as expected. This can be caused by a variety of reasons, one of the common reasons is variable shadowing. This article will explain the concept of variable occlusion through a concrete example and provide solutions to such problems.

Variable occlusion

Variable occlusion refers to a variable with the same name as the parent class in the subclass, which causes the subclass to actually access the subclass's own variable, not the parent class's variable when accessing the variable. This can lead to logical errors, especially when the parent class variables are used for conditional judgments.

Example Analysis

The following code is an example:

 public abstract class Switchable {
    public State state;
    abstract public void turn_on(); 
    abstract public void turn_off(); 
}

public class Lamp extends Switchable {
    public State state;
    public Lamp() {
        state = State.off;
    }
    public void turn_on() {
        this.state = State.on;
        System.out.println("lamp's on");
    }
    public void turn_off() {
        this.state = State.off;
        System.out.println("lamp's off");
    }
}

public class Television extends Switchable {
    public State state;
    public Television() {
        state = State.off;
    }
    public void turn_on() {
        this.state = State.on;
        System.out.println("lamp's on");
    }
    public void turn_off() {
        this.state = State.off;
        System.out.println("lamp's off");
    }
}

public class PowerSwitch {
    Switchable sw;  
    public PowerSwitch(Switchable sw) {
        this.sw = sw;
    }
    public void ClickSwitch() {
        if(sw.state == State.off) {
            sw.turn_on();
        } else {
            sw.turn_off();
        }
    }
}

public class Main {
    public static void main(String[] args) {
        Switchable sw = new Lamp(); 
        PowerSwitch ps = new PowerSwitch(sw);
        ps.ClickSwitch();
        ps.ClickSwitch();
    }
}

public enum State {
    on , off ; 
}

In this example, the Switchable class defines a state variable, and the Lamp and Television classes also define their own state variables respectively. This leads to variable occlusion. The ClickSwitch() method in the PowerSwitch class accesses the state variable of the Switchable class, while the turn_on() and turn_off() methods in the Lamp and Television classes modify their own state variables. Therefore, the conditional judgment in the PowerSwitch class is always true, resulting in the output always "lamp's off".

Solution

To resolve this problem, you need to remove the state variables in the Lamp and Television classes to make sure they are using the state variables in the Switchable class.

The modified code is as follows:

 public abstract class Switchable {
    public State state = State.off; // set up to off by default
    abstract public void turn_on(); 
    abstract public void turn_off(); 
}

public class Television extends Switchable {

    public Television(){}

    @Override
    public void turn_on() {
        this.state = State.on;
        System.out.println("television's on");
    }

    @Override
    public void turn_off() {
        this.state = State.off;
        System.out.println("television's off");
    }
}

public class Lamp extends Switchable {

    public Lamp(){}

    @Override
    public void turn_on() {
        this.state = State.on;
        System.out.println("lamp's on");
    }

    @Override
    public void turn_off() {
        this.state = State.off;
        System.out.println("lamp's off");
    }
}

In this modified code, the Lamp and Television classes no longer declare their own state variables, but directly use the state variables in the Switchable class. At the same time, in order to better distinguish, the output information of Television has also been modified. In this way, the conditional judgment in the PowerSwitch class can be correctly switched based on the state of Lamp or Television.

Things to note

  • When writing Java code, be careful to avoid variable occlusion, especially in inheritance relationships.
  • When using an IDE, pay attention to the warning information provided by the IDE. For example, IntelliJ IDEA will prompt variable occlusion.
  • When debugging a program, you can use a debugger to check the value of a variable to determine whether there is a problem with variable occlusion.

Summarize

Variable occlusion is a common pitfall in Java programming. It may cause conditional judgments to fail, thus affecting the correctness of the program. By understanding the concept of variable occlusion and taking corresponding measures, such problems can be avoided and the quality of the code can be improved. In this case, removing the variables that are repeatedly defined in the subclass and ensuring that the subclass uses the variables of the parent class is the key to solving the problem.

The above is the detailed content of Common causes and solutions for failure of conditional judgment in Java. For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undress AI Tool

Undress AI Tool

Undress images for free

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Comparing Java Frameworks: Spring Boot vs Quarkus vs Micronaut Comparing Java Frameworks: Spring Boot vs Quarkus vs Micronaut Aug 04, 2025 pm 12:48 PM

Pre-formanceTartuptimeMoryusage, Quarkusandmicronautleadduetocompile-Timeprocessingandgraalvsupport, Withquarkusoftenperforminglightbetterine ServerLess scenarios.2.Thyvelopecosyste,

What is a deadlock in Java and how can you prevent it? What is a deadlock in Java and how can you prevent it? Aug 23, 2025 pm 12:55 PM

AdeadlockinJavaoccurswhentwoormorethreadsareblockedforever,eachwaitingforaresourceheldbytheother,typicallyduetocircularwaitcausedbyinconsistentlockordering;thiscanbepreventedbybreakingoneofthefournecessaryconditions—mutualexclusion,holdandwait,nopree

How to join an array of strings in Java? How to join an array of strings in Java? Aug 04, 2025 pm 12:55 PM

Using String.join() (Java8) is the easiest recommended method for connecting string arrays, just specify the separator directly; 2. For old versions of Java or when more control is needed, you can use StringBuilder to manually traverse and splice; 3. StringJoiner is suitable for scenarios that require more flexible formats such as prefixes and suffixes; 4. Using Arrays.stream() combined with Collectors.joining() is suitable for filtering or converting the array before joining; To sum up, if Java8 and above is used, the String.join() method should be preferred in most cases, which is concise and easy to read, but for complex logic, it is recommended.

How to implement a simple TCP client in Java? How to implement a simple TCP client in Java? Aug 08, 2025 pm 03:56 PM

Importjava.ioandjava.net.SocketforI/Oandsocketcommunication.2.CreateaSocketobjecttoconnecttotheserverusinghostnameandport.3.UsePrintWritertosenddataviaoutputstreamandBufferedReadertoreadserverresponsesfrominputstream.4.Usetry-with-resourcestoautomati

How to compare two strings in Java? How to compare two strings in Java? Aug 04, 2025 am 11:03 AM

Use the .equals() method to compare string content, because == only compare object references rather than content; 1. Use .equals() to compare string values equally; 2. Use .equalsIgnoreCase() to compare case ignoring; 3. Use .compareTo() to compare strings in dictionary order, returning 0, negative or positive numbers; 4. Use .compareToIgnoreCase() to compare case ignoring; 5. Use Objects.equals() or safe call method to process null strings to avoid null pointer exceptions. In short, you should avoid using == for string content comparisons unless it is explicitly necessary to check whether the object is in phase.

How to send and receive messages over a WebSocket in Java How to send and receive messages over a WebSocket in Java Aug 16, 2025 am 10:36 AM

Create a WebSocket server endpoint to define the path using @ServerEndpoint, and handle connections, message reception, closing and errors through @OnOpen, @OnMessage, @OnClose and @OnError; 2. Ensure that javax.websocket-api dependencies are introduced during deployment and automatically registered by the container; 3. The Java client obtains WebSocketContainer through the ContainerProvider, calls connectToServer to connect to the server, and receives messages using @ClientEndpoint annotation class; 4. Use the Session getBasicRe

Correct posture for handling non-UTF-8 request encoding in Spring Boot application Correct posture for handling non-UTF-8 request encoding in Spring Boot application Aug 15, 2025 pm 12:30 PM

This article discusses the mechanism and common misunderstandings of Spring Boot applications for handling non-UTF-8 request encoding. The core lies in understanding the importance of the charset parameter in the HTTP Content-Type header, as well as the default character set processing flow of Spring Boot. By analyzing the garbled code caused by wrong testing methods, the article guides readers how to correctly simulate and test requests for different encodings, and explains that Spring Boot usually does not require complex configurations to achieve compatibility under the premise that the client correctly declares encoding.

Exploring Common Java Design Patterns with Examples Exploring Common Java Design Patterns with Examples Aug 17, 2025 am 11:54 AM

The Java design pattern is a reusable solution to common software design problems. 1. The Singleton mode ensures that there is only one instance of a class, which is suitable for database connection pooling or configuration management; 2. The Factory mode decouples object creation, and objects such as payment methods are generated through factory classes; 3. The Observer mode automatically notifies dependent objects, suitable for event-driven systems such as weather updates; 4. The dynamic switching algorithm of Strategy mode such as sorting strategies improves code flexibility. These patterns improve code maintainability and scalability but should avoid overuse.

See all articles