将String类型的二维数组中的元素用FileOutputStream的write方法生成一个文件
import java.io.File;
import java.io.FileOutputStream;
public class Test
{
protected static String tmpString[][]={{
"头目:蛇怪",
"建议级别:12级",
"推荐武器:苏格兰斩剑",
"建议直接使用初始给予",
"的武器,初始武器有比",
"较理想的附魔。",
"",
"技巧:不断地按跳跃可",
"以停留在空中躲避蛇怪",
"的攻击,趁她攻击的间",
"歇。落下去砍她头上的",
"召唤符,是不错的方法",
"",
"难点一:触手攻击",
"头目的触手很长,停留",
"在地面很难回避,所以",
"最 办法是跳到空中",
"这样不但可以躲避攻击",
"也能攻击蛇怪的弱点",
"",
"难点二:召唤鱼",
"头目会召唤很多的食人",
"鱼,这些鱼虽然伤害不",
"高,但是会妨碍你跳跃",
"所以有机会一定要先消",
"灭那些碍事的食人鱼。",
"",
"头目:血池蛇怪",
"建议级别:50级",
"推荐使用雷神战斧或其",
"他名称为蓝色的武器。",
"建议带附有雷电盾的武",
"器魔法再搭配攻击或魔",
"击附魔!"
},
{"头目:守门人",
"建议级别:25级",
"推荐武器:风暴巨剑",
"建议攻击附魔或是魔击",
"附魔,配合风暴巨剑的",
"魔法技能可以对头目造",
"成很可观的伤害",
"",
"技巧:头目会召唤浮游",
"雷。当头目在浮游雷附",
"近时攻击浮游雷,浮游",
"雷爆炸也会对头目造成",
"伤害。浮游雷很多的话",
"伤害也不低。",
"",
"难点一:瞬间消失",
"头目瞬间消失后会出现",
"在你正上方或是左右。",
"但他发起攻击之前会有",
"准备动作,趁那时候赶",
"紧躲避吧!",
"",
"难点二:大范围激光",
"头目会发射多道激光,",
"覆盖范围很广。一定要",
"趁他发出激光前跳到他",
"身后,实在不行就跳跃",
"或蹲下吧。",
"",
"头目:魔界死神",
"建议级别:57级",
"推荐使用冰雪女王或名",
"称为蓝色的武器。",
"建议附有高级以上的攻",
"击或魔击附魔。"
},
{
"头目:魔术师",
"建议级别:31级",
"建议武器:极光军刀",
"建议攻击附魔再配有吸",
"血附魔,可以保证自己",
"生命的同时,有效地攻",
"击头目!",
"",
"技巧:头目发出的一种",
"体积较大的牌是可以砍",
"回去的,当他发出这种",
"牌的时候看准机会砍回",
"去,可以对头目造成伤",
"害!",
"",
"难点一:上下调转",
"头目会掉转上下,把你",
"变到屋顶上。头目拿出",
"体积最大的牌就预示他",
"要调转方向。这个无法",
"躲避,但要有心理准备",
"然后迅速适应。",
"",
"难点二:散弹型飞牌",
"头目最多会飞出五张牌",
"五张牌形成的弧形很大",
"可以跳到不同的方向或",
"是站在两张牌之间躲避",
"",
"头目:地狱使者",
"建议级别:90级",
"推荐使用冰雪女王或其",
"他名称为紫色的武器。",
"建议附究级攻击性的武",
"器魔法再配有究级吸血",
"附魔!可以保证自己生",
"命的同时,有效地攻击",
"头目!"
},{
"头目:伯爵",
"建议级别:37级",
"建议武器:雷神战斧",
"建议攻击附魔再配有吸",
"血附魔,可以保证自己",
"生命的同时,有效地攻",
"击头目!",
"",
"技巧:头目移动时会变",
"成蝙蝠,伯爵变身之后",
"是他防御最弱的时候,",
"趁他变回来之前,一定",
"要尽可能多的攻击他。",
"",
"难点一:大范围放蝙蝠",
"头目放出的蝙蝠不仅面",
"积广,还会造成多次伤",
"害。所以看到他将要放",
"出蝙蝠,尽可能跳到他",
"身后,不行的话就依靠",
"跳跃来躲避吧。",
"",
"难点二:召唤飞剑",
"头目会召唤很多飞剑,",
"飞剑会妨碍跳跃,也可",
"能打断你的连击,而且",
"飞剑造成的伤害也不低",
"所以一旦头目召唤出飞",
"剑一定要尽快消灭。",
"",
"头目:魔鬼伯爵",
"建议级别:65级",
"推荐使用冰雪女王或者",
"浑沌审判者。",
"建议附究级攻击性的武",
"器魔法再配有究级吸血",
"附魔!可以保证自己生",
"命的同时,有效地攻击",
"头目!"
}};
public void show()
{
for(int i=0;i<tmpString.length;i++)
{
for(int j=0;j<tmpString[i].length;j++)
{
System.out.println("tmpString["+i+"]["+j+"]"+tmpString[i][j]);
}
}
}
public void output()throws Exception
{
FileOutputStream fos=new FileOutputStream(new File("e:/test.mid"));
byte[] bs = "测试java 文件操作".getBytes();
//bs原本应该是tmpString[][]数组中的内容
fos.write(bs);
}
public static void main(String args[])
{
Test t=new Test();
t.show();
try
{t.output();
}
catch(Exception e)
{
}
}
}
- Java code
-
// 写入
ByteArrayOutputStream baos = new ByteArrayOutputStream();
DataOutputStream dos = new DataOutputStream(baos);
dos.writeInt(tmpString.length);// 数组长度
for (int i = 0; i < tmpString.length; i++) {// 遍历数组
dos.writeInt(tmpString[i].length);// 子数组的长度
for (int j = 0; j < tmpString[i].length; j++) {// 遍历子数组
dos.writeUTF(tmpString[i][j]);//写入字符串
}
}
byte[] b = baos.toByteArray();
FileOutputStream fos = new FileOutputStream(new File("e:/test.mid"));
fos.write(b);
fos.close();
// 读取
DataInputStream dis = new DataInputStream(new FileInputStream("e:/test.mid"));
tmpString = new String[dis.readInt()][];//读取第一维长度
for (int i = 0; i < tmpString.length; i++) {//遍历数组
tmpString[i] = new String[dis.readInt()];//读取子数组长度
for (int j = 0; j < tmpString[i].length; j++)//遍历子数组
tmpString[i][j] = dis.readUTF();//读取字符串
}
dis.close();
- Java code
-
// 写入
ByteArrayOutputStream baos = new ByteArrayOutputStream();
DataOutputStream dos = new DataOutputStream(baos);
dos.writeInt(tmpString.length);// 数组长度
for (int i = 0; i < tmpString.length; i++) {// 遍历数组
dos.writeInt(tmpString[i].length);// 子数组的长度
for (int j = 0; j < tmpString[i].length; j++) {// 遍历子数组
dos.writeUTF(tmpString[i][j]);//写入字符串
}
}
byte[] b = baos.toByteArray();
FileOutputStream fos = new FileOutputStream(new File("e:/test.mid"));
fos.write(b);
fos.close();
// 读取
DataInputStream dis = new DataInputStream(new FileInputStream("e:/test.mid"));
tmpString = new String[dis.readInt()][];//读取第一维长度
for (int i = 0; i < tmpString.length; i++) {//遍历数组
tmpString[i] = new String[dis.readInt()];//读取子数组长度
for (int j = 0; j < tmpString[i].length; j++)//遍历子数组
tmpString[i][j] = dis.readUTF();//读取字符串
}
dis.close();
将String类型的二维数组中的元素用FileOutputStream的write方法生成一个文件的更多相关文章
- 功能要求:定义一个两行三列的二维数组 names 并赋值,使用二重循环输出二维数组中的元素。
功能要求:定义一个两行三列的二维数组 names 并赋值,使用二重循环输出二维数组中的元素 names={{"tom","jack","mike&qu ...
- php 向二维数组中追加元素
处理之前的数据: 处理后: //$consult 为往里插之前的数组 //把$arr的元素追加到$consult的最前面 $arr = []; $arr[0]['workplaceId'] = '0' ...
- 剑指offer:二维数组中的查找
目录 题目 解题思路 具体代码 题目 题目链接 剑指offer:二维数组中的查找 题目描述 在一个二维数组中(每个一维数组的长度相同),每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺 ...
- 【面试题003】c数组做为参数退化的问题,二维数组中的查找
[面试题003]c数组做为参数退化的问题,二维数组中的查找 一,c数组做为参数退化的问题 1.c/c++没有记录数组的大小,因此用指针访问数组中的元素的时候,我们要确保没有超过数组的边界, 通过下面 ...
- word search(二维数组中查找单词(匹配字符串))
Given a 2D board and a word, find if the word exists in the grid. The word can be constructed from l ...
- 剑指Offer-【面试题03:二维数组中的查找】
package com.cxz.question3; /* * 在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序. * 请完成一个函数,输入这样的一个二维数组和 ...
- 剑指offer系列——二维数组中,每行从左到右递增,每列从上到下递增,设计算法找其中的一个数
题目:二维数组中,每行从左到右递增,每列从上到下递增,设计一个算法,找其中的一个数 分析: 二维数组这里把它看作一个矩形结构,如图所示: 1 2 8 2 4 9 12 4 7 10 13 6 8 11 ...
- 《剑指Offer》之二维数组中的查找
1.题目描述 在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序.请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数. 2.代码实现 pu ...
- 剑指offer_快速查找递增二维数组中是否存在目标
[编程题]二维数组中的查找 在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序.请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数 ...
随机推荐
- 关于dwt文件和lbi文件
1,dwt 文件是网页模板文件(Dreamweaver Template), 在创建网站的多个网页的时候,通常可以将网页的共同部分创建成为一个模板, 然后给多个网页调用, 以实现网页代码的重复利用. ...
- android Xml生成一条细线,以及获取屏幕宽度和高度
<View android:layout_width="match_parent" android:layout_height="2dip" androi ...
- table的样式定义
table的cellpadding和cellpadding我们经常会用如下的方式来清除默认样式: <table cellspacing="0" cellpadding=&qu ...
- 原生应用native、Web应用、混合应用hybrid:3者的优缺点解析
最近原生应用.Web应用.混合应用的名字让我们听得比较熟悉了,现在我们就通过评析各种应用的优缺点来更进一步看看这三者的区别. 一. 原生应用: 你使用过微软PowerPoint 或者 Word吧?这些 ...
- [转]openlayer+geoserver实现WFS操作
From:http://liushaobo2005.blog.163.com/blog/static/253056702011541462372/ wfs是OGC的标准规范,主要用于提供对矢量地理数据 ...
- [Leetcode][Python]51: N-Queens
# -*- coding: utf8 -*-'''__author__ = 'dabay.wang@gmail.com' 51: N-Queenshttps://oj.leetcode.com/pro ...
- HBase 1、HBase介绍和工作原理
HBase是一个分布式的.面向列的开源数据库,该技术来源于 Fay Chang 所撰写的Google论文“Bigtable:一个结构化数据的分布式存储系统”.就像Bigtable利用了Google文件 ...
- Parallelogram Counting(平行四边形个数,思维转化)
1058 - Parallelogram Counting PDF (English) Statistics Forum Time Limit: 2 second(s) Memory Limit ...
- 基于Andoird 4.2.2的同步框架源代码学习——同步提供端
Android同步框架 同步(synchronization)允许用户将远程数据下载到新的设备上,同时将设备上的帐户数据上传到远端.同步还保证用户能够看到最新的数据. 开发者自然可以通过自己的方式来设 ...
- UVA 10131 Is Bigger Smarter?(DP)
Some people think that the bigger an elephant is, the smarter it is. To disprove this, you want to t ...