java 写文件 错误码_Java写文件错误行为

这是我的另一个Java问题。

请看一下这个代码:

public static void main(String[] args) {

if( args.length != 5) {

System.out.println("Error. Wrong number of params!");

System.exit(0);

}

File file = new File(args[0]);

try {

BufferedImage image = ImageIO.read(file);

FileWriter fstream = new FileWriter("output.txt");

BufferedWriter out = new BufferedWriter(fstream);

int avg = 0;

int w = image.getWidth();

int h = image.getHeight();

Rectangle r = new Rectangle();

double whiteHelp = Double.parseDouble(args[4]);

avg = (int) (avg / 1);

int startX = Integer.parseInt(args[2]);

int startY = Integer.parseInt(args[3]);

r.width = r.height = Integer.parseInt(args[1]);

for(int i = startY; i <= h - r.height; i += r.height) {

for(int j = startX; j &lt= w - r.width; j += r.width) {

r.x = j;

r.y = i;

avg = getTileColor(r, image, whiteHelp);

//System.out.print(avg);

out.write(avg);

}

//System.out.println();

out.write("\n");

}

out.close();

image.flush();

System.out.println("Finished parsing the image. Solving...");

} catch (Exception e) {

System.out.println("Error.");

e.printStackTrace();

}

}

在output.txt中,我只得到不可读的文本,就好像打开二进制文件一样。

BufferedImage和BufferedWriter同时实例化时是否存在一些问题?我正在使用相同的过程来写入另一个类中的文件,其中一个文件打开供读取,另一个文件打开供写入,一切正常。

P.S.如何在不破坏代码的情况下输入

谢谢

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
你可以使用 Java 中的 JDBC API 来读取 SQL 文件并执行其中的语句。具体步骤如下: 1. 使用 Java 中的 FileReader 类读取 SQL 文件,将其内容读入到一个字符串中。 2. 使用字符串的 split() 方法将 SQL 语句分割成一个个单独的语句。 3. 使用 JDBC API 中的 Connection、Statement 和 ResultSet 类来连接数据库并执行 SQL 语句。 4. 在循环中逐个执行 SQL 语句,如果遇到错误可以使用 try-catch 块来捕获异常并跳过该语句。 下面是一个简单的示例代码: ```java import java.io.BufferedReader; import java.io.FileReader; import java.sql.Connection; import java.sql.DriverManager; import java.sql.SQLException; import java.sql.Statement; public class ExecuteSqlFile { public static void main(String[] args) { String fileName = "test.sql"; // SQL 文件名 String url = "jdbc:mysql://localhost:3306/test"; // 数据库连接 URL String user = "root"; // 数据库用户名 String password = "123456"; // 数据库密码 try (Connection conn = DriverManager.getConnection(url, user, password); Statement stmt = conn.createStatement(); BufferedReader reader = new BufferedReader(new FileReader(fileName))) { String line; StringBuilder sb = new StringBuilder(); while ((line = reader.readLine()) != null) { sb.append(line); } String[] sqls = sb.toString().split(";"); // 分割 SQL 语句 for (String sql : sqls) { try { stmt.execute(sql); // 执行 SQL 语句 } catch (SQLException e) { System.err.println("Error executing SQL: " + sql); e.printStackTrace(); } } } catch (Exception e) { e.printStackTrace(); } } } ``` 注意:这只是一个简单的示例代码,实际应用中还需要考虑 SQL 注入等安全问题。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值