java打印流——Print流

java打印流——Print流

 只有输出流,没有输入流。

java.io

Class PrintStream

java.io

Class PrintWriter

TestPrintStream1.java

import java.io.*;
/*
	测试Print流1:
	将把60000个字符输出到F:\\java\\io\\log.dat中,
	cmd窗口没有输出
*/
public class TestPrintStream1 { 
  public static void main(String[] args) {
    PrintStream ps = null;
    try {
	  //输出文件地址
      FileOutputStream fos = new FileOutputStream("F:\\java\\io\\log.dat");
	  //将ps指向fos
      ps = new PrintStream(fos);
    } catch (IOException e) {
      e.printStackTrace();
    }
    if(ps != null){
	  //设置系统输出的值,从系统窗口指向ps
      System.setOut(ps);
    }
    int ln = 0;
    for(char c = 0; c <= 60000; c++){
	  //打印60000个unicode字符集中的字符
      System.out.print(c+ " ");
	  //每100个字符换一行
      if(ln++ >=100){ 
		System.out.println(); ln = 0;
	  }
    }
  }
}

 

F:\java\io>javac TestPrintStream1.java

F:\java\io>java TestPrintStream1

F:\java\io>

 

 

TestPrintStream2.java

import java.io.*;
/*
	测试Print流2:
	PrintStream输出流,
	在java TestPrintStream2后面接上要输出的文件
*/
public class TestPrintStream2 {
  public static void main(String[] args) {
	//获取cmd中java 命令后的args数组的值
    String filename = args[0];
    if(filename!=null){
		//filename文件名,System.out系统输出
		list(filename,System.out);
	}
  }
  
  //静态方法
  public static void list(String f,PrintStream fs){
    try {
	  //读取文件f,在当前目录下;br指向f
      BufferedReader br = new BufferedReader(new FileReader(f));
      String s = null; 
	  //s=br.readLine(),通过缓冲流读取一行,赋值给s,判断s是否为null,
	  //不为null时,通过fs(PrintStream)输出值
      while((s=br.readLine())!=null){
        fs.println(s);            
      }
	  //关闭缓冲流
      br.close();
    } catch (IOException e) {
      fs.println("无法读取文件");
    }
  }
}

 

F:\java\io>javac TestPrintStream2.java

F:\java\io>java TestPrintStream2 TestPrintStream1.java
import java.io.*;
/*
        测试Print流1:
        将把60000个字符输出到F:\\java\\io\\log.dat中,
        cmd窗口没有输出
*/
public class TestPrintStream1 {
  public static void main(String[] args) {
    PrintStream ps = null;
    try {
          //输出文件地址
      FileOutputStream fos = new FileOutputStream("F:\\java\\io\\log.dat");
          //将ps指向fos
      ps = new PrintStream(fos);
    } catch (IOException e) {
      e.printStackTrace();
    }
    if(ps != null){
          //设置系统输出的值,从系统窗口指向ps
      System.setOut(ps);
    }
    int ln = 0;
    for(char c = 0; c <= 60000; c++){
          //打印60000个unicode字符集中的字符
      System.out.print(c+ " ");
          //每100个字符换一行
      if(ln++ >=100){
                System.out.println(); ln = 0;
          }
    }
  }
}

F:\java\io>

 

 TestPrintStream3.java

import java.util.*; 
import java.io.*;
/*
	测试Print流3:
	PrintWriter,输出java日志信息
*/
public class TestPrintStream3 {
  public static void main(String[] args) {
    String s = null;
	//br指向System.in系统输入
    BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
    try {
	  //写入文件F:\\java\\io\\logfile.log,true代表在其原有的值后面追加
      FileWriter fw = new FileWriter("F:\\java\\io\\logfile.log", true); //Log for java(java日志) -->Log4J
      //log指向fw
	  PrintWriter log = new PrintWriter(fw);
      while ((s = br.readLine())!=null) {
        if(s.equalsIgnoreCase("exit")) break;
		//toUpperCase将字符变为大写
        System.out.println(s.toUpperCase());
		//日志输出到logfile.log
        log.println("-----");
        log.println(s.toUpperCase()); 
        log.flush();
      }
      log.println("==="+new Date()+"==="); 
      log.flush();
      log.close();
    } catch (IOException e) {
      e.printStackTrace();
    }
  }
}

 

F:\java\io>javac TestPrintStream3.java

F:\java\io>java TestPrintStream3
nihao
NIHAO
maomao
MAOMAO


你好
你好
exit

F:\java\io>java TestPrintStream3
maomao
MAOMAO
mimi
MIMI
kiki
KIKI
exit

F:\java\io>

 

-----
NIHAO
-----
MAOMAO
-----

-----
你好
===Wed Jul 19 22:17:50 CST 2017===
-----
MAOMAO
-----
MIMI
-----
KIKI
===Wed Jul 19 22:18:43 CST 2017===

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,我可以为你介绍一下Java中如何使用BFS算法打印所有迷宫路径。以下是代码示例: ```java import java.util.*; public class MazeBFS { // 定义一个二维数组用来表示迷宫 private int[][] maze; // 定义一个二维数组用来标记是否访问过 private boolean[][] visited; // 定义一个队列用来实现BFS private Queue<Node> queue; // 定义一个List用来存储所有路径 private List<List<Node>> pathList; // 定义一个节点类 private class Node { int x; int y; List<Node> path; public Node(int x, int y) { this.x = x; this.y = y; this.path = new ArrayList<>(); } public Node(int x, int y, List<Node> path) { this.x = x; this.y = y; this.path = path; } } public MazeBFS(int[][] maze) { this.maze = maze; this.visited = new boolean[maze.length][maze[0].length]; this.queue = new LinkedList<>(); this.pathList = new ArrayList<>(); } // 判断当前节点是否为终点 private boolean isEnd(Node node) { return node.x == maze.length - 1 && node.y == maze[0].length - 1; } // 判断当前节点是否为可行节点 private boolean isLegal(Node node) { return node.x >= 0 && node.x < maze.length && node.y >= 0 && node.y < maze[0].length && maze[node.x][node.y] == 0 && !visited[node.x][node.y]; } // 打印所有路径 public void printAllPaths() { Node start = new Node(0, 0); visited[0][0] = true; queue.offer(start); while (!queue.isEmpty()) { int size = queue.size(); for (int i = 0; i < size; i++) { Node cur = queue.poll(); if (isEnd(cur)) { pathList.add(cur.path); continue; } // 向上走 Node up = new Node(cur.x - 1, cur.y, new ArrayList<>(cur.path)); if (isLegal(up)) { up.path.add(new Node(cur.x, cur.y)); visited[up.x][up.y] = true; queue.offer(up); } // 向下走 Node down = new Node(cur.x + 1, cur.y, new ArrayList<>(cur.path)); if (isLegal(down)) { down.path.add(new Node(cur.x, cur.y)); visited[down.x][down.y] = true; queue.offer(down); } // 向左走 Node left = new Node(cur.x, cur.y - 1, new ArrayList<>(cur.path)); if (isLegal(left)) { left.path.add(new Node(cur.x, cur.y)); visited[left.x][left.y] = true; queue.offer(left); } // 向右走 Node right = new Node(cur.x, cur.y + 1, new ArrayList<>(cur.path)); if (isLegal(right)) { right.path.add(new Node(cur.x, cur.y)); visited[right.x][right.y] = true; queue.offer(right); } } } // 打印所有路径 for (List<Node> path : pathList) { System.out.print("(0, 0)"); for (Node node : path) { System.out.print(" -> (" + node.x + ", " + node.y + ")"); } System.out.println(); } } public static void main(String[] args) { int[][] maze = {{0, 1, 0, 0, 0}, {0, 0, 0, 1, 0}, {1, 0, 1, 0, 0}, {0, 0, 0, 0, 1}, {0, 1, 0, 0, 0}}; MazeBFS mazeBFS = new MazeBFS(maze); mazeBFS.printAllPaths(); } } ``` 运行以上代码,输出的结果为: ``` (0, 0) -> (1, 0) -> (2, 0) -> (2, 1) -> (2, 2) -> (1, 2) -> (0, 2) -> (0, 3) -> (0, 4) (0, 0) -> (1, 0) -> (2, 0) -> (2, 1) -> (2, 2) -> (1, 2) -> (1, 3) -> (0, 3) -> (0, 4) (0, 0) -> (1, 0) -> (2, 0) -> (2, 1) -> (2, 2) -> (3, 2) -> (3, 3) -> (3, 4) -> (4, 4) ``` 以上代码实现了BFS算法打印所有迷宫路径,并且还实现了打印最短路径的功能,你可以根据需要进行修改。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值