三组数据如下:

{19.99 , 9.99 , 15.99 , 3.99 , 4.99}

{12 , 8 , 13 ,29 ,50}

{"Java T-shirt" , "Java Mug" , "Duke Juggling Dolls" , "Java Pin" , "Java Key Chain"}

主要考查难点就是题目限制了只能用这两个类.

由于数据是三个不同类型的数组,而DataInputStream的读取方法都一次只能读取一个,像这种数组就得另想办法.

 import java.io.DataInputStream;
import java.io.DataOutputStream;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
/*将如下三组不同类型的数据利用DataInputStream和DataOutputStream写入文件,然后从文件中读出*/
public class Test3_2 {
public static void main(String[] args) throws IOException{
File f= new File("d:\\test.txt");
FileOutputStream fos=new FileOutputStream(f);
DataOutputStream dos=new DataOutputStream(fos);
FileInputStream fis=new FileInputStream(f);
DataInputStream dis=new DataInputStream(fis);
double[] d={19.99,9.99,15.99,3.99,4.99};
int[] in={12,8,13,29,50};
String[] s={"Java T-shirt","Java Mug","Duke Juggling Dolls","Java Pin","Java Key Chain"}; double d1[]=new double[5];
int i1[]=new int[5];
String s1[]=new String[5];//用于显示到控制台时控制输出 for(int i=0;i<5;i++){
dos.writeDouble(d[i]);
dos.writeInt(in[i]);
dos.writeUTF(s[i]);
}//写入到文件
fos.close();
dos.close();//关闭流
for(int i=0;i<5;i++){
d1[i]=dis.readDouble();
i1[i]=dis.readInt();
s1[i]=dis.readUTF();
}//从文件中读取,因为DataInputStream只有这种方法,依次只能读一个,所以依次存放到数组中
for(int i=0;i<5;i++)
System.out.print(d1[i]+" ");
System.out.println();
for(int i=0;i<5;i++)
System.out.print(i1[i]+" ");
System.out.println();
for(int i=0;i<5;i++)
System.out.print(s1[i]+" ");
System.out.println();//控制输出格式 }
}

可能是文件写入那一部分让我形成了惯性思维.因为它是以数组依次循环读入,所以我希望最好可以以数组的形式依次循环读出.

而如上所述,在题目所限制的类中没有这种方法.

既然只有一次只能读一个的方法,所以我想它每读取一个,我就把它放到数组中再print出来.

另外,字符串数组的读取,遇到了麻烦,我百度了一个方法,如下:

 char c;
while((c=inDat.readChar())!='\0'){
System.out.print("读出成功");
}

一度想把char强制转换为String????终究发现行不通

那用readUTF()方法,但是莫名其妙的有问题,我也不知道问题在哪儿,直到我看到DataOutputStream类的writeUTF方法,突然想到或许可以与其配对使用,而之前智障的我读取字符串时使用的是writeChars方法,从而导致读写时对文件的编码不一致.运行时总是乱码

将如下三组不同类型的数据利用DataInputStream和DataOutputStream写入文件,然后从文件中读出的更多相关文章

  1. java下DataInputStream与DataOutputStream写入数据的同时写入数据类型

    package cn.stat.p2.demo; import java.io.DataInputStream; import java.io.DataOutputStream; import jav ...

  2. 为GCD队列绑定NSObject类型上下文数据-利用__bridge_retained(transfer)转移内存管理权-备

    下面评论的好友“@Jim”给了种新的思路,就是在清除context的函数里面,用“_bridge_transfer”转换context,把context的内存管理权限重新交给ARC,这样,就不用显式调 ...

  3. Java -> 把Excel表格中的数据写入数据库与从数据库中读出到本地 (未完善)

    写入:没有关闭流,容错并不完善. private void insertFile(HttpServletRequest request, HttpServletResponse response) t ...

  4. 【java IO】使用Java输入输出流 读取txt文件内数据,进行拼接后写入到另一个文件中

    package com.sxd.test.util; import java.io.BufferedReader; import java.io.BufferedWriter; import java ...

  5. Python文件处理之文件写入方式与写缓存(三)

    Python的open的写入方式有: write(str):将str写入文件 writelines(sequence of strings):写多行到文件,参数为可迭代对象 首先来看下writelin ...

  6. PBOC金融IC卡,卡片与终端交互的13个步骤,简介-第三组

    七:终端风险管理-必选但包含可选步骤异常文件:终端检查应用主账号是否在异常文件列表(卡号黑名单)中.商户强制联机:商户可以将当前交易强制为联机处理.最低限额:控制交易当前交易金额或同一张卡片连续几笔交 ...

  7. select、poll、epoll三组IO复用

    int select(int nfds,fd_set* readfds,fd_set* writefds,fd_set* exceptfds,struct timeval* timeout)//其中n ...

  8. 向mysql中插入Date类型的数据

    先看数据库表的定义 date字段为sql.date类型.我要向其中插入指定的日期和当前日期. 一.插入当前日期 思路:先获取当前系统,在将当前系统时间转换成sql类型的时间,然后插入数据库.代码如下 ...

  9. SQL SERVER2005 的三种复制类型概述

    一.事务复制 事务性复制通常从发布数据库对象和数据的快照开始.创建了初始快照后,接着在发布服务器上所做的数据更改和架构修改通常在修改发生时(几乎实时)便传递给订阅服务器.数据更改将按照其在发布服务器上 ...

随机推荐

  1. HDU1054(KB10-H 最小顶点覆盖)

    Strategic Game Time Limit: 20000/10000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) ...

  2. linux新手向-文件的权限及修改

    如果访问或执行一个文件显示Permission deny,一般是权限问题. 使用"ls -l"可以查看该目录下文件的详细信息. 1.读懂权限 第一列就是权限信息,形如: drwxr ...

  3. 【代码笔记】iOS-字符串替换回车和换行

    一,代码. - (void)viewDidLoad { [super viewDidLoad]; // Do any additional setup after loading the view, ...

  4. ubuntu执行sudo apt-get update 时出现的错误及解决办法

    一.错误描述 W: GPG error: http://ppa.launchpad.net/fkrull/deadsnakes/ubuntu xenial InRelease: The followi ...

  5. Spring学习笔记(一):快速入门

    Spring简介:        Spring是一个开源框架,它由Rod Johnson创建.它是为了解决企业应用开发的复杂性而创建的.Spring使用基本的JavaBean来完成以前只可能由EJB完 ...

  6. Sql Server中的游标最好只用于有主键或唯一键的表

    游标cursor,我想大多数人都在sql server里面用过.当一个表数据量不太大的时候,游标还是可以用的,毕竟游标是循环一个表中每一行数据的最简便办法.但是如果你用一个游标去循环一个没有主键或唯一 ...

  7. web.config中的InProc模式 与 StateServer模式[转]

    开发asp.net应用时,修改web.config中的SessionState节点. <sessionState mode="StateServer" stateConnec ...

  8. NFS 系统的搭建

    问题: 由于工作,需要,不断得进行挂在硬盘重装系统,NFS 系统给了我一个很好的解决方案.于是决定写一篇博客,防止以后再次使用的时候,能够很快得重新建立NFS 文件系统. 调研: NFS(Networ ...

  9. [Python_6] Python 配置 MySQL 访问

    0. 说明 Python 访问 MySQL 数据库,需要安装 MySQL 的 Python 插件. 1. 安装 MySQL 插件 pip install PyMySQL 2. 编写代码 # -*-co ...

  10. [Python_3] Python 函数 & IO

    0. 说明 Python 函数 & IO 笔记,基于 Python 3.6.2 参考  Python: read(), readline()和readlines()使用方法及性能比较  Pyt ...