RandomAccessFile&IO流&排序&方法论
RandomAccessFile&IO流&排序&方法论
我们总觉得历史是极其遥远的东西,与我们并无关联,又觉得历史隐藏在图书馆的旧书之中。
然而,我们每个人都有真真切切的历史。那便是每日的历史。今天自己做了些什么,又是怎么做的,都会成为你历史中的一页。
是畏缩不前、碌碌无为,还是勇猛挑战,花心思比昨天做的更好。每种态度,都会写就属于你的历史。
——尼采 《快乐的知识》
RandomAccessFile
以下是昨天对RandomAccessFile的具体练习:
package Zhang;
import java.io.File;
import java.io.IOException;
import java.io.RandomAccessFile;
import java.util.Arrays;
public class RandomAccessFileTest {
public static void main(String[] args) throws IOException {
File demo=new File("demo");//相对路径
if(!demo.exists()) demo.mkdir(); //如果目录不存在创建目录
File file=new File(demo,"raf.dat");
if(!file.exists()) file.createNewFile();//如果文件不存在,创建文件
RandomAccessFile raf=new RandomAccessFile(file,"rw");
//指针的位置
System.out.println(raf.getFilePointer());
raf.write('A');//只写了一个字节
System.out.println(raf.getFilePointer());
raf.write('B');
int i=0x7fffffff;
//底层的处理方法用write方法每次只能写一个字节,如果要把i写进去就要写四次
raf.write(i>>>24);//右移24,把高八位写进去。>>>无符号右移
raf.write(i>>>16);
raf.write(i>>>8);
raf.write(i);
System.out.println(raf.getFilePointer());
//其实可以直接写一个int
raf.writeInt(i);//此处可以查看writeInt()的实现方法,与上面的基本一样。
String s="中";
byte[] gbk=s.getBytes("gbk");//gbk的中文占两个字节
raf.write(gbk);
System.out.println(raf.getFilePointer());//查看此时指针的位置
System.out.println(raf.length());//查看文件的长度
//读文件,必须把指针移动到文件的开始位置
raf.seek(0);
//一次性读取,把文件的内容都读取到字节数组中
byte[] buf=new byte[(int)raf.length()];//字节数组的长度与文件的长度一致
raf.read(buf);//读取到字节数组当中
System.out.println(Arrays.toString(buf));
String s1=new String(buf);//把字节数组构造成为字符串
System.out.println(s1);
//以十六进制的形式输出
for(byte b:buf){
System.out.print(Integer.toHexString(b&0xff)+" ");
}
byte [] b=new byte[2];
raf.seek(10);
raf.read(b,0,2);
String content=new String(b,"gbk");
System.out.println(content);//输出 “中”
raf.close();//关闭
}
}
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------->具体实现了在文件上读取数据
数组排序
今天课上我简单的练习了数组的常用排序:
package Zhang;
import java.util.Arrays;
public class ArrayTest {
/**
* 冒泡排序
* @param arrays 数组
* @author zhang
* */
public static void sort(int [] arrays){
for(int i=1;i<arrays.length;i++){
for(int j=0;j<arrays.length-i;j++){
if(arrays[j]>arrays[j+1]){
int tmp=arrays[j];
arrays[j]=arrays[j+1];
arrays[j+1]=tmp;
}
}
}
}
/**
* 直接排序
* @param arrays 数组
* @author zhang
* */
public static void sort2(int [] arrays){
for(int i=0;i<arrays.length-1;i++){
for(int j=i+1;j<arrays.length;j++){
if(arrays[i]<arrays[j]){
int tmp=arrays[i];
arrays[i]=arrays[j];
arrays[j]=tmp;
}
}
}
}
/**
* 快速排序
* @param a 数组
* @param low开始的位置
* @param high结束的位置
* @author zhang
*
* */
public static void sort3(int[] a,int low,int high){
if(low>=high) return;
int first=low;
int last=high;
int key=a[first];
while(first<last){
while(first<last&&a[last]>=key){
last--;
}
a[first]=a[last];
while(first<last&&a[first]<=key){
first++;
}
a[last]=a[first];
}
a[first]=key;
sort3(a,low,first-1);//当这个函数递归结束时下面的high是上一个函数的first-1.所以low与high不能写成0与a.length-1。
sort3(a,first+1,high);
}
public static void main(String[] args) {
int a[]={8,4,3,2,7,5,4,9,67,89,32,7,0,99,12};
sort3(a,0,a.length-1);
System.out.println(Arrays.toString(a));
Arrays.fill(a,100);
System.out.println(Arrays.toString(a));
Arrays.fill(a,3,6,200);
System.out.println(Arrays.toString(a));
}
}
更多的内容如果以后用的到,自己就去查阅官方说明文档。
方法论
学 习一个新知识,首先要对这个新的知识百度一下或者其他方式了解,这种新知识是为了解决什么问题而出现的。然后是知道些这种知识技术解决问题的原理,使用这 种知识的规则以及常用技术与思想。通过网上视频教程简单入门,深入下去是找权威书籍与官方的说明文档去阅读。之间要进行必要的练习,最后在实际的应用中灵 活运用。复杂的问题也是由简单的组成的,仔细分析他们是怎么系统的组成在一起的,互相之间是怎么起作用的,在注重基础的同时也不要在舒适区停留,不断的向 新的内容进军旧的知识才能更牢固和发挥力量。探索学习自己未知的是不容易的,但那也是走出没有新鲜感的唯一途径。对于卓越的人,自己不被理解是别人的问 题,对于最求卓越的自己,不能或不去理解卓越的人的成果是件悲哀的事。不进步不痛快!以我现在的时间和我根据自己的学习经历总结的学习方法,我应该下一步 做什么呢?先把前几天审视思考总结出来的问题在解决吧,问题是复杂的,自己就不要想太多给自己添乱了。
欲多则心散,心散则志衰,志衰则思不达。——《鬼谷子》
对的,当考虑整体的时候就不要深陷细节,专注细节的时候就不要过多分心其他。
2016-10-10
RandomAccessFile&IO流&排序&方法论的更多相关文章
- Java基础-IO流对象之随机访问文件(RandomAccessFile)
Java基础-IO流对象之随机访问文件(RandomAccessFile) 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.RandomAccessFile简介 此类的实例支持对 ...
- IO流 简介 总结 API 案例 MD
目录 IO 流 简介 关闭流的正确方式 关闭流的封装方法 InputStream 转 String 的方式 转换流 InputStreamReader OutputStreamWriter 测试代码 ...
- Java:IO流与文件基础
Java:IO流与文件基础 说明: 本章内容将会持续更新,大家可以关注一下并给我提供建议,谢谢啦. 走进流 什么是流 流:从源到目的地的字节的有序序列. 在Java中,可以从其中读取一个字节序列的对象 ...
- java IO流详解
流的概念和作用 学习Java IO,不得不提到的就是JavaIO流. 流是一组有顺序的,有起点和终点的字节集合,是对数据传输的总称或抽象.即数据在两设备间的传输称为流,流的本质是数据传输,根据数据传输 ...
- IO流
流的概念和作用 学习JavaIO,不得不提到的就是JavaIO流. 流是一组有顺序的,有起点和终点的字节集合,是对数据传输的总称或抽象.即数据在两设备间的传输称为流,流的本质是数据传输,根据数据传输特 ...
- Java IO流学习总结
Java流操作有关的类或接口: Java流类图结构: 流的概念和作用 流是一组有顺序的,有起点和终点的字节集合,是对数据传输的总称或抽象.即数据在两设备间的传输称为流,流的本质是数据传输,根据数据传输 ...
- java IO流 之 其他流
一.内存操作流(ByteArrayInputStream.ByteArrayOutputStream) (一). public class ByteArrayInputStream extends ...
- 二十一、Java基础--------IO流之综合案例分析
前三篇文章详细介绍了IO流体系所涉及的重点内容,为了帮助理解与学习,本片博客主要是分析一个与IO操作相关的题目. 例1:在我们观看视频时经常要关注的就是视频的时间长度,在学习了IO操作之后,就可以自己 ...
- Java IO流
File类 ·java.io.File类:文件和目录路径名的抽象表示形式,与平台无关 ·File能新建.删除.重命名文件和目录,但File不能访问文件内容本身.如果需要访问文件内容本身,则需要使用输入 ...
随机推荐
- centOs6.5配置jdk及其注意事项
1.下载jdk1.7 百度云链接: https://pan.baidu.com/s/15vXLO2eV18eVvmt-R5jGnQ 密码: 1gd6 2.解压压缩包 通过终端在/usr/local下新 ...
- SourceTree 01 - git 客户端介绍
SourceTree - git客户端介绍 SourceTree系列第1篇 --->> SourceTree 01 - git 客户端介绍(http://www.cnblogs.com/g ...
- Go-GRPC 初体验
grpc 跟常见的client-server模型相似(doubbo)grpc 编码之前需要准备以下环境: 安装protobuf,grpc的client与server之间消息传递使用的protoc格式消 ...
- Override与Overload
方法重写(Override) 方法重写是子类对父类(父类为抽象类)的允许访问的方法的实现过程进行重新编写, 返回值和形参都不能改变.即外壳不变,核心重写! 方法的重写规则 1.参数列表必须完全与被重写 ...
- [MongoDB教程] 1.简介
MongoDB (名称来自「humongous (巨大无比的)」), 是一个可扩展的高性能,开源,模式自由,面向文档的NoSQL,基于 分布式 文件存储,由 C++ 语言编写,设计之初旨在为 WEB ...
- redis安装异常的解决的办法
在开始redis安装的时候,先废话一下 官网: 英文 :https://redis.io/ 中文 :http://www.redis.cn/ 首先我们需要一个linux服务器,当然windows也是可 ...
- 从零开始搭建口袋妖怪管理系统(1)-从Angular1.x开始
开坑,一直喜欢口袋妖怪,想着能写点有关的程序. 最近项目要改写管理系统,所以用Angular1.x搭建一个口袋妖怪管理系统试试. 巩固Ng1.x的知识+学习库的用法,然后算是记录一个系统从零开始到成型 ...
- [ Java学习基础 ] String、StringBuffer、StringBuilder比较学习
首先讲获得字符串对象的方式有两种,一种是直接使用字符串常量,一种是使用new关键字创建,但它们之间是有一些区别,如下运行实例: String s1 = new String("Hello&q ...
- [Codeforces 235B]Let's Play Osu!
Description 题库链接 有一个长度为 \(n\) 的 "XO" 序列,其中第 \(i\) 个位置 "O" 出现的概率为 \(p_i\) .一个序列的价 ...
- [WC 2005]友好的生物
Description $W$ 星球是一个和地球一样气候适宜.物种聚集的星球.经过多年的研究,外星生物学家们已经发现了数万种生物,而且这个数字还在不断增大. $W$ 星球上的生物很有趣,有些生物之间很 ...