\ b不清除特定实例中的最后一个字符

时间:2016-06-29 18:10:20

标签: java multithreading command-prompt unicode-escapes

class progReport extends Thread {

    // function for clearing the line by printing escape char '\b'
    private static void cls(){
        for (int i = 0; i <50; i++) {
            System.out.print("\b");
        }
    } //End of cls

    //Running a thread for printing the message every 100 ms.
    public void run(int prog) {
        int k;
        cls();

        try { 
            Thread.sleep(100);
        } catch(InterruptedException e) { 
            e.printStackTrace(); 
        }

        System.out.print("Scanning: " + (prog) + "%      ");
        k=prog%3;   // mod 3, so as to decide which symbol to be used for revolving animation

        switch (k) {
            case 0: 
                System.out.print("/");
                break;
            case 1: 
                System.out.print("--");  // LINE WITH THE PROBLEM
                break;
            default: 
                System.out.print("\\");
                break;
        } // End of switch
    } // End of run
} // end of class progReport

    // class with main
public class ProgressDemo {
    public static void main(String...a) {
        int prog = 0;
        progReport pr = new progReport();

        while(prog <= 100) 
            pr.run(prog++);

        System.out.println("\nScanning Complete!!");
    } // End of main
} // End of class ProgressDemo

在命令行上执行此代码时,它不会清除案例1的最后一个“ - ”:其中两个破折号打印为“ - ”,但如果我在其他情况下包含一个空格(即将“/”和“\\”更改为“/”和“\\”)然后正确清除整行。有人可以帮我指出为什么它表现得如此奇怪?

1 个答案:

答案 0 :(得分:1)

嗯。这是一个有趣的问题。您遇到的问题是退格字符就是那个。一个人物。如何处理这个角色取决于打印它的终端。

所以在我的情况下我使用的是OS X终端,这个程序只需要使用退格字符并将光标向后移动一个槽。然后,如果有后续字符,则删除这些字符。

所以当你打印时:

System.out.println("Hello\b");

什么都没发生。因为没有后续人物。另一方面,当你打印时:

System.out.println("Hello\b ");

然后删除&#34; o&#34;角色,因为有一个后续角色(一个空的空间)。我知道它很奇怪,但事实就是这样。

现在,在您的程序中,您基本上将50个退格字符打印到输出流中,然后打印您的消息。然后再次50退格。然后另一条消息。然后再次50退格。然后你的第三条消息等等。

邮件的长度为:

* 1 N

* 2 N + 1

* 3 N

在第二种情况下,邮件的长度比另一个长一个字符,因此即使您打印N + 1个字符,也只有N个退格字符处于活动状态,因为退格字符将查看您的上一条消息而不是后续信息。

将这两件事放在一起(在代码中查看,终端移动光标但不删除它),您将体验到您的体验。

一种解决方案是,您只需在cls函数的开头添加一个空格,如下所示:

// function for clearing the line by printing escape char '\b'
private static void cls(){
    System.out.print(" ");
    for (int i = 0; i < 50; i++) {
        System.out.print("\b");
    }
} //End of cls

这将确保即使您的消息仅为N长,也会激活N + 1个退格。

无论如何,你的程序根本没有在新线程中运行。您还应该学习多线程,以了解如何正确启动和使用线程。

对于扩展Thread类的启动程序,应该运行start()方法来激活它。否则你的代码只是在主线程上运行。