概念上的區別是這樣得:
print將它的參數顯示在命令窗口,並將輸出光標定位在所顯示的最後一個字符之後。
println 將它的參數顯示在命令窗口,並在結尾加上換行符,將輸出光標定位在下一行的開始。printf是格式化輸出的形式。
舉個例子,代碼如下:
package other;
public class TestPrint {
public static void main(String[] args) {
int i = 4;
double j = 5;
System.out.print("用print輸出i:"+ i);
System.out.println( "用println輸出i:"+ i);
System.out.printf("i的值爲%d,j的值爲%f", i,j);
}
}
運行結果爲
用print輸出i:4用println輸出i:4
i的值爲4,j的值爲5.000000
可以看到,用print輸出i後,沒有換行,用println輸出的結果直接在print輸出語句後面,而輸出println後換行了,所以用printf輸出時,在第二行輸出。
這裏着重看printf
“i的值爲%d,j的值爲%f”這個字符串中的"%d"變爲i的值了,而"%f"變爲了j的值了!
這裏,"%d"的意思是一個int值的佔位符,"%f"爲一個double 或float值的點位符,這個變量的參數在後面提供。注意的是實參名必須按順序排。不然就會錯了。而且類型也要相符。如果我們把語句改爲System.out.printf("i的值爲%d,j的值爲%f", j,i);//i和j位置反了
這時就有錯了因爲"%d"對應的參數變爲j,"%f"對應的變爲i了,而j是double的,與"%d"是int形的不一致。所以有錯了。
還有"%s"是一個字符串值的點位符的意思。"%c"是一個字符值的點位符的意思。
可能讀者還會問爲什麼j輸出變成了5.000000?那是因爲double是默認有6位小數的(這個可能和系統電腦有關,有的不是6位吧)但是如果你想只要輸出兩位小數行不行?可以啊!只要改下語句就行了!
System.out.printf("i的值爲%d,j的值爲%.2f", i,j);
這裏的"%.2f"的意思是輸出兩位小數點。如果想輸出三位那就"%.3f"。
說到這裏你會發現原來printf也很有用的。這樣可以控制輸出的格式。
另外也可以有這樣的例子:
public class TestPrint {
public static void main(String[] args) {
int i = 4;
double j = 5.000f;
System.out.printf("i的值爲d,n", i);
}
}
運行結果爲:
i的值爲00004,
原來"d"的意思是輸出5個佔位符,如果數字不足5的話就有左邊以0相補。
注意這裏的%d與d的區別!!!