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的最后一个“ - ”:其中两个破折号打印为“ - ”,但如果我在其他情况下包含一个空格(即将“/”和“\\”更改为“/”和“\\”)然后正确清除整行。有人可以帮我指出为什么它表现得如此奇怪?
答案 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()
方法来激活它。否则你的代码只是在主线程上运行。