前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >RandomAccessFile&IO流&排序&方法论

RandomAccessFile&IO流&排序&方法论

作者头像
拾点阳光
发布2018-05-11 11:46:48
5720
发布2018-05-11 11:46:48
举报
文章被收录于专栏:码云1024码云1024

RandomAccessFile&IO流&排序&方法论

我们总觉得历史是极其遥远的东西,与我们并无关联,又觉得历史隐藏在图书馆的旧书之中。

然而,我们每个人都有真真切切的历史。那便是每日的历史。今天自己做了些什么,又是怎么做的,都会成为你历史中的一页。

是畏缩不前、碌碌无为,还是勇猛挑战,花心思比昨天做的更好。每种态度,都会写就属于你的历史。

——尼采 《快乐的知识》

RandomAccessFile

以下是昨天对RandomAccessFile的具体练习:

代码语言:javascript
复制
  1 package Zhang;
  2 
  3  
  4 
  5 import java.io.File;
  6 
  7 import java.io.IOException;
  8 
  9 import java.io.RandomAccessFile;
 10 
 11 import java.util.Arrays;
 12 
 13  
 14 
 15 public class RandomAccessFileTest {
 16 
 17       public static void main(String[] args) throws IOException {
 18 
 19            
 20 
 21             File demo=new File("demo");//相对路径
 22 
 23             if(!demo.exists()) demo.mkdir(); //如果目录不存在创建目录
 24 
 25            
 26 
 27             File file=new File(demo,"raf.dat");
 28 
 29             if(!file.exists()) file.createNewFile();//如果文件不存在,创建文件
 30 
 31            
 32 
 33             RandomAccessFile raf=new RandomAccessFile(file,"rw");
 34 
 35             //指针的位置
 36 
 37             System.out.println(raf.getFilePointer());
 38 
 39             raf.write('A');//只写了一个字节
 40 
 41             System.out.println(raf.getFilePointer());
 42 
 43             raf.write('B');
 44 
 45            
 46 
 47             int i=0x7fffffff;
 48 
 49             //底层的处理方法用write方法每次只能写一个字节,如果要把i写进去就要写四次
 50 
 51             raf.write(i>>>24);//右移24,把高八位写进去。>>>无符号右移
 52 
 53             raf.write(i>>>16);
 54 
 55             raf.write(i>>>8);
 56 
 57             raf.write(i);
 58 
 59             System.out.println(raf.getFilePointer());
 60 
 61             //其实可以直接写一个int
 62 
 63             raf.writeInt(i);//此处可以查看writeInt()的实现方法,与上面的基本一样。
 64 
 65            
 66 
 67             String s="中"; 
 68 
 69             byte[] gbk=s.getBytes("gbk");//gbk的中文占两个字节
 70 
 71             raf.write(gbk);
 72 
 73             System.out.println(raf.getFilePointer());//查看此时指针的位置
 74 
 75             System.out.println(raf.length());//查看文件的长度
 76 
 77            
 78 
 79             //读文件,必须把指针移动到文件的开始位置
 80 
 81             raf.seek(0);
 82 
 83             //一次性读取,把文件的内容都读取到字节数组中
 84 
 85             byte[] buf=new byte[(int)raf.length()];//字节数组的长度与文件的长度一致
 86 
 87             raf.read(buf);//读取到字节数组当中
 88 
 89             System.out.println(Arrays.toString(buf));
 90 
 91            
 92 
 93             String s1=new String(buf);//把字节数组构造成为字符串
 94 
 95             System.out.println(s1);
 96 
 97             //以十六进制的形式输出
 98 
 99             for(byte b:buf){
100 
101                   System.out.print(Integer.toHexString(b&0xff)+" ");
102 
103             }
104 
105            
106 
107             byte [] b=new byte[2];
108 
109             raf.seek(10);
110 
111             raf.read(b,0,2);
112 
113             String content=new String(b,"gbk");
114 
115             System.out.println(content);//输出 “中”
116 
117             raf.close();//关闭
118 
119       }
120 
121 }

IO流

下面是对明天即将进一步学习IO流做的准备:

IO流(输入流、输出流)

字节流、字符流(也就是以字节为单位,或者以字符为单位)

字节流:InputStream、OutputStream两个抽象类

InputStream抽象了应用程序读取数据的方式

OutputStream抽象了应用程序写出数据的方式

EOF=End 读到-1就读到结尾

重要的方法。in与out视为对象

输入流 键盘是一个输入

输入流基本方法:

lint b=in.read();读取一个byte到流,b的底8位

lin.read(byte[] buf);读取一个byte数组

lin.read(byte buf,int start,int size);从byte数组的start位置读取长度为size的字节

输出流基本方法:

lout.write(int b)写出一个byte到流,b的底八位。

lout.write(byte[] buf)将buf字节数组都写到流

lout.write(byte[] buf,int start,int size)字节数组buf从start位置开始写size长度的字节到流。

InputStream、OutputStream两个抽象类的第一组子类

FileInputStream------->具体实现了在文件上读取数据

数组排序

今天课上我简单的练习了数组的常用排序:

代码语言:javascript
复制
  1 package Zhang;
  2 
  3 import java.util.Arrays;
  4 
  5 public class ArrayTest {
  6 
  7      /**
  8 
  9      * 冒泡排序
 10 
 11      * @param arrays 数组
 12 
 13      * @author zhang
 14 
 15      * */
 16 
 17      public static void sort(int [] arrays){
 18 
 19           for(int i=1;i<arrays.length;i++){
 20 
 21                for(int j=0;j<arrays.length-i;j++){
 22 
 23                     if(arrays[j]>arrays[j+1]){
 24 
 25                          int tmp=arrays[j];
 26 
 27                          arrays[j]=arrays[j+1];
 28 
 29                          arrays[j+1]=tmp;
 30 
 31                     }
 32 
 33                }
 34 
 35           }
 36 
 37      }
 38 
 39      /**
 40 
 41      * 直接排序
 42 
 43      * @param arrays 数组
 44 
 45      * @author zhang
 46 
 47      * */
 48 
 49      public static void sort2(int [] arrays){
 50 
 51           for(int i=0;i<arrays.length-1;i++){
 52 
 53                for(int j=i+1;j<arrays.length;j++){
 54 
 55                     if(arrays[i]<arrays[j]){
 56 
 57                          int tmp=arrays[i];
 58 
 59                          arrays[i]=arrays[j];
 60 
 61                          arrays[j]=tmp;
 62 
 63                     }
 64 
 65                }
 66 
 67           }
 68 
 69      }
 70 
 71      /**
 72 
 73      *  快速排序
 74 
 75      * @param a 数组
 76 
 77      * @param low开始的位置
 78 
 79      * @param high结束的位置
 80 
 81      * @author zhang
 82 
 83      *
 84 
 85      * */
 86 
 87      public static void sort3(int[] a,int low,int high){
 88 
 89           if(low>=high) return;
 90 
 91           int first=low;
 92 
 93           int last=high;
 94 
 95           int key=a[first];
 96 
 97           while(first<last){
 98 
 99                while(first<last&&a[last]>=key){
100 
101                     last--;
102 
103                }
104 
105                a[first]=a[last];
106 
107                while(first<last&&a[first]<=key){
108 
109                     first++;
110 
111                }
112 
113                a[last]=a[first];
114 
115           }
116 
117           a[first]=key;
118 
119           sort3(a,low,first-1);//当这个函数递归结束时下面的high是上一个函数的first-1.所以low与high不能写成0与a.length-1。
120 
121           sort3(a,first+1,high);
122 
123      }
124 
125     
126 
127      public static void main(String[] args) {
128 
129           int a[]={8,4,3,2,7,5,4,9,67,89,32,7,0,99,12};
130 
131           sort3(a,0,a.length-1);
132 
133           System.out.println(Arrays.toString(a));
134 
135           Arrays.fill(a,100);
136 
137           System.out.println(Arrays.toString(a));
138 
139           Arrays.fill(a,3,6,200);
140 
141           System.out.println(Arrays.toString(a));    
142 
143      }
144 
145 }

更多的内容如果以后用的到,自己就去查阅官方说明文档。

方法论

学 习一个新知识,首先要对这个新的知识百度一下或者其他方式了解,这种新知识是为了解决什么问题而出现的。然后是知道些这种知识技术解决问题的原理,使用这 种知识的规则以及常用技术与思想。通过网上视频教程简单入门,深入下去是找权威书籍与官方的说明文档去阅读。之间要进行必要的练习,最后在实际的应用中灵 活运用。复杂的问题也是由简单的组成的,仔细分析他们是怎么系统的组成在一起的,互相之间是怎么起作用的,在注重基础的同时也不要在舒适区停留,不断的向 新的内容进军旧的知识才能更牢固和发挥力量。探索学习自己未知的是不容易的,但那也是走出没有新鲜感的唯一途径。对于卓越的人,自己不被理解是别人的问 题,对于最求卓越的自己,不能或不去理解卓越的人的成果是件悲哀的事。不进步不痛快!以我现在的时间和我根据自己的学习经历总结的学习方法,我应该下一步 做什么呢?先把前几天审视思考总结出来的问题在解决吧,问题是复杂的,自己就不要想太多给自己添乱了。

欲多则心散,心散则志衰,志衰则思不达。——《鬼谷子》

对的,当考虑整体的时候就不要深陷细节,专注细节的时候就不要过多分心其他。

2016-10-10

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2016-10-18 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • RandomAccessFile&IO流&排序&方法论
  • RandomAccessFile
  • IO流
  • 数组排序
  • 方法论
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档