print  

是函数,可以返回一个值,只能有一个参数。

它的参数显示在命令窗口,不换行

println  

与print唯一的区别是println换行输出。

它的参数显示在命令窗口,换行

printf  

也是函数,把文字格式化以后输出,直接系统调用进行IO,他是非缓冲的。

printf是格式化输出的形式。

%d

按十进制整型数据的实际长度输出。

%ld

输出长整型数据。

%md

m 为指定的输出字段的宽度。如果数据的位数小于 m,则左端补以空格,若大于 m,则按实际位数输出。

%u

输出无符号整型(unsigned)。输出无符号整型时也可以用 %d,这时是将无符号转换成有符号数,然后输出。但编程的时候最好不要这么写,因为这样要进行一次转换,使 CPU 多做一次无用功。

%c

用来输出一个字符。

%f

用来输出实数,包括单精度和双精度,以小数形式输出。不指定字段宽度,由系统自动指定,整数部分全部输出,小数部分输出 6 位,超过 6 位的四舍五入。

%.mf

输出实数时小数点后保留 m 位,注意 m 前面有个点。

%o

以八进制整数形式输出,这个就用得很少了,了解一下就行了。

%s

用来输出字符串。用 %s 输出字符串同前面直接输出字符串是一样的。但是此时要先定义字符数组或字符指针存储或指向字符串,这个稍后再讲。

%x(或 %X 或 %#x 或 %#X)

以十六进制形式输出整数,这个很重要。

  1. printf("Hello World!\n");        // \n表示换行
  2. printf("%d\n", i);   //%d是输出控制符,d 表示十进制,后面的 i 是输出参数
  3. printf("%d %d\n", i, j);
  4. printf("i = %d, j = %d\n", i, j);

下在举个例子:

package other;

public class TestPrint {undefined

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"是一个字符值的点位符的意思。

如果只要输出量为小数,语句改为:System.out.printf("i的值为%d,j的值为%.2f", i,j);

这里的"%.2f"的意思是输出两位小数点。如果想输出三位那就"%.3f"。

printf可以控制输出的格式。

将代码改为以下:

public class TestPrint {undefined

public static void main(String[] args) {

   int i = 4;

   double j = 5.000f;

   System.out.printf("i的值为],\n", i);

   System.out.printf("i的值为=,j的值为%.2f", i,j); 

}

}

运行结果为:

i的值为    4,

i的值为 4,j的值为5.00

原来在"%"与"d"之间加个数5的意思是输出5个占位符。默认向右对齐。这样的输出是很有用的,比如你想输出一个表格,因各个数大小不一,有的5位有的4位,这样输出的的表格结果就对不齐了。如果将输出结果全部为同一样的占位符数。那样就对齐了。

除了"%d"可以这样外,别的也可以

我们再试着将代码改一下:

public class TestPrint {undefined

public static void main(String[] args) {undefined

   int i = 4;

   double j = 5.000f;

   System.out.printf("i的值为d,\n", i);

}

}

运行结果为:

i的值为00004,

原来"d"的意思是输出5个占位符,如果数字不足5的话就有左边以0相补