缓冲流, 也叫高效流, 按照数据类型分类:
BufferedInputStream,BufferedOutputStreamBufferedReader,BufferedWriter缓冲流的基本原理,是在创建流对象时,会创建一个内置的默认大小的缓冲区数组,通过缓冲区读写,减少系统IO次数,从而提高读写的效率。
// 构造方法
public BufferedInputStream(InputStream in)
// 创建一个 新的缓冲输入流
public BufferedOutputStream(OutputStream out)
// 创建一个新的缓冲输出流。
// 字节输出缓冲流
OutputStream out = new BufferedOutputStream(new FileOutputStream("FileAndIoStream\\test\\4.txt"));
out.write("hello world\r\n".getBytes());
out.write("hello world\r\n".getBytes());
out.write("hello world\r\n".getBytes());
out.write("hello world\r\n".getBytes());
out.close();
// 字节输入缓冲流
InputStream in = new BufferedInputStream(new FileInputStream("FileAndIoStream\\test\\4.txt"));
byte[] chs = new byte[1024];
int len = 0;
while ((len = in.read(chs)) != -1) {
System.out.println(new String(chs, 0, len));
}
in.close();
// 构造方法
public BufferedReader(Reader in)
// 创建一个 新的缓冲输入流
public BufferedWriter(Writer out)
// 创建一个新的缓冲输出流。
特有方法
public String readLine(): 读一行文字。public void newLine(): 写一行行分隔符,由系统属性定义符号。BufferedReader bufferedReader = new BufferedReader(new FileReader("FileAndIoStream\\test\\4.txt"));
String line = null;
while ((line = bufferedReader.readLine()) != null) {
System.out.println(line);
}
bufferedReader.close();
BufferedWriter bw = new BufferedWriter(new FileWriter("FileAndIoStream\\test\\4.txt"));
bw.write("你好");
bw.close();
3.侍中、侍郎郭攸之、费祎、董允等,此皆良实,志虑忠纯,是以先帝简拔以遗陛下。愚以为宫中之事,事无大小,悉以咨之,然后施行,必得裨补阙漏,有所广益。
8.愿陛下托臣以讨贼兴复之效,不效,则治臣之罪,以告先帝之灵。若无兴德之言,则责攸之、祎、允等之慢,以彰其咎;陛下亦宜自谋,以咨诹善道,察纳雅言,深追先帝遗诏,臣不胜受恩感激。
4.将军向宠,性行淑均,晓畅军事,试用之于昔日,先帝称之曰能,是以众议举宠为督。愚以为营中之事,悉以咨之,必能使行阵和睦,优劣得所。
2.宫中府中,俱为一体,陟罚臧否,不宜异同。若有作奸犯科及为忠善者,宜付有司论其刑赏,以昭陛下平明之理,不宜偏私,使内外异法也。
1.先帝创业未半而中道崩殂,今天下三分,益州疲弊,此诚危急存亡之秋也。然侍卫之臣不懈于内,忠志之士忘身于外者,盖追先帝之殊遇,欲报之于陛下也。诚宜开张圣听,以光先帝遗德,恢弘志士之气,不宜妄自菲薄,引喻失义,以塞忠谏之路也。
9.今当远离,临表涕零,不知所言。
6.臣本布衣,躬耕于南阳,苟全性命于乱世,不求闻达于诸侯。先帝不以臣卑鄙,猥自枉屈,三顾臣于草庐之中,咨臣以当世之事,由是感激,遂许先帝以驱驰。后值倾覆,受任于败军之际,奉命于危难之间,尔来二十有一年矣。
7.先帝知臣谨慎,故临崩寄臣以大事也。受命以来,夙夜忧叹,恐付托不效,以伤先帝之明,故五月渡泸,深入不毛。今南方已定,兵甲已足,当奖率三军,北定中原,庶竭驽钝,攘除奸凶,兴复汉室,还于旧都。此臣所以报先帝而忠陛下之职分也。至于斟酌损益,进尽忠言,则攸之、祎、允之任也。
5.亲贤臣,远小人,此先汉所以兴隆也;亲小人,远贤臣,此后汉所以倾颓也。先帝在时,每与臣论此事,未尝不叹息痛恨于桓、灵也。侍中、尚书、长史、参军,此悉贞良死节之臣,愿陛下亲之信之,则汉室之隆,可计日而待也。
public class test {
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new FileReader("FileAndIoStream\\test\\csb"));
TreeSet<String> set = new TreeSet<>(new Comparator<String>() {
@Override
public int compare(String o1, String o2) {
String num1 = o1.split("\\.")[0];
String num2 = o2.split("\\.")[0];
return Integer.parseInt(num1) - Integer.parseInt(num2);
}
});
String line = null;
while ((line = br.readLine()) != null) {
set.add(line);
}
br.close();
BufferedWriter bw = new BufferedWriter(new FileWriter("FileAndIoStream\\test\\csb"));
for (String s : set) {
bw.write(s);
bw.newLine();
bw.flush();
}
bw.close();
}
public static void mapToSort() throws IOException {
BufferedReader br = new BufferedReader(new FileReader("FileAndIoStream\\test\\csb"));
TreeMap<Integer, String> map = new TreeMap<>();
String line = null;
while ((line = br.readLine()) != null) {
String[] split = line.split("\\.");
map.put(Integer.parseInt(split[0]), line);
}
br.close();
BufferedWriter bw = new BufferedWriter(new FileWriter("FileAndIoStream\\test\\csb"));
for (Integer integer : map.keySet()) {
bw.write(map.get(integer));
bw.newLine();
bw.flush();
}
bw.close();
}
}
由于 FileReader 和 FileWriter 无法指定编码 仅可使用平台默认编码 因此若读取/写入其他编码文件会乱码
// java.io.InputStreamReader
// 构造方法
public InputStreamReader(InputStream in, String charsetName)
String charsetName 指定字符集, 不区分大小写
// java.io.OutputStreamWriter
// 构造方法
public InputStreamReader(OutputStream in, String charsetName)
String charsetName 指定字符集, 不区分大小写
Reader r = new InputStreamReader(new FileInputStream("FileAndIoStream\\test\\csbGBK.txt"), "gbk");
char[] chs = new char[1024];
int len = 0;
while ((len = r.read(chs)) != -1) {
System.out.println(new String(chs, 0, len));
}
r.close();
Writer w = new OutputStreamWriter(new FileOutputStream("FileAndIoStream\\test\\csbGBK.txt",true), "gbk");
w.write("\n11.END");
w.close();
复制文件并转换编码
Reader reader = new InputStreamReader(new FileInputStream("FileAndIoStream\\test\\csbGBK.txt"),"gbk");
Writer writer = new OutputStreamWriter(new FileOutputStream("FileAndIoStream\\test\\csbUTF8.txt"));
char[] chars = new char[1024];
len = 0;
while ((len = reader.read(chars)) != -1) {
writer.write(new String(chars, 0, len));
writer.flush();
}
reader.close();
writer.close();
Java 提供了一种对象序列化的机制。用一个字节序列可以表示一个对象,该字节序列包含该对象的数据、对象的类型和对象中存储的属性等信息。字节序列写出到文件之后,相当于文件中持久保存了一个对象的信息。
反之,该字节序列还可以从文件中读取回来,重构对象,对它进行反序列化。对象的数据、对象的类型和对象中存储的数据信息,都可以用来在内存中创建对象。
java.io.ObjectOutputStream 类,将Java对象的原始数据类型写出到文件,实现对象的持久存储。java.io.ObjectInputStream 反序列化流,将之前使用ObjectOutputStream序列化的原始数据恢复为对象// 构造方法
public ObjectOutputStream(OutputStream out)
// 创建一个指定OutputStream的ObjectOutputStream
public ObjectInputStream(InputStream in)
// 创建一个指定InputStream的ObjectInputStream
public class Demo {
public static void main(String[] args) throws IOException, ClassNotFoundException {
writeObject();
readerObject();
}
// 序列化
public static void writeObject() throws IOException {
ObjectOutputStream oos = new ObjectOutputStream(new FileOutputStream("FileAndIoStream\\test\\Person.txt"));
// 序列化单个对象
// oos.writeObject(new Person("张三", 17, 1));
// 序列化多个对象
List<Person> list = new ArrayList<Person>();
list.add(new Person("张三",11,1));
list.add(new Person("李四",15,0));
list.add(new Person("王五",17,1));
list.add(new Person("刘六",10,0));
oos.writeObject(list);
oos.close();
}
// 反序列化
public static void readerObject() throws IOException, ClassNotFoundException {
ObjectInputStream ois = new ObjectInputStream(new FileInputStream("FileAndIoStream\\test\\Person.txt"));
// 反序列化单个对象
// Person p = (Person) ois.readObject();
// System.out.println(p);
// 反序列化多个对象
Object obj = ois.readObject();
List<Person> list = (List<Person>) obj;
for (Person person : list) {
System.out.println(person);
}
ois.close();
}
}
class Person implements Serializable {
// 静态内容不能序列化
private static String className;
private String name;
private int age;
// transient 关键字 瞬态, 不可被序列化
private transient int sex;
private static final long serialVersionUID = 1L;
// 反序列化 不调用构造方法
public Person() {}
public Person(String name, int age) {
this.name = name;
this.age = age;
}
public Person(String name, int age, int sex) {
this.name = name;
this.age = age;
this.sex = sex;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
@Override
public String toString() {
return "Person{" +
"name='" + name + '\'' +
", age=" + age +
", sex=" + sex +
'}';
}
}
反序列化时, 若找不到class文件, 则反序列话失败, 抛出异常 ClassNotFoundException
当jvm反序列化对象时, 能找到class文件, 但在序列化对象后class文件发生了改变, 则反序列化失败, 抛出异常 InvalidClassException
当类作为Serializable 的实现类初始化时, 会同时生成一个序列号, 反序列化时检测到序列号不一致
平时我们在控制台打印输出,是调用print方法和println方法完成的,这两个方法都来自于java.io.PrintStream类,该类能够方便地打印各种数据类型的值,是一种便捷的输出方式
public PrintStream(String fileName) : 使用指定的文件名创建一个新的打印流。
public class Demo {
public static void main(String[] args) throws IOException {
PrintWriter p = new PrintWriter("FileAndIoStream\\test\\print1.txt");
p.print("abc");
p. println(10);
p.println(true);
p.close();
PrintWriter pw = new PrintWriter(new FileWriter("FileAndIoStream\\test\\print2.txt"),true);
pw.println("你好");
// 设置输出位置, 将 输出到控制台 改为 输出到文件
System.setOut(new PrintStream(new FileOutputStream("FileAndIoStream\\test\\print2.txt", true)));
System.out.println("输出到文件1");
System.out.println("输出到文件2");
pw.close();
}
}
我的目标是转换表单输入,例如“100兆字节”或“1GB”,并将其转换为我可以存储在数据库中的文件大小(以千字节为单位)。目前,我有这个:defquota_convert@regex=/([0-9]+)(.*)s/@sizes=%w{kilobytemegabytegigabyte}m=self.quota.match(@regex)if@sizes.include?m[2]eval("self.quota=#{m[1]}.#{m[2]}")endend这有效,但前提是输入是倍数(“gigabytes”,而不是“gigabyte”)并且由于使用了eval看起来疯狂不安全。所以,功能正常,
我想将html转换为纯文本。不过,我不想只删除标签,我想智能地保留尽可能多的格式。为插入换行符标签,检测段落并格式化它们等。输入非常简单,通常是格式良好的html(不是整个文档,只是一堆内容,通常没有anchor或图像)。我可以将几个正则表达式放在一起,让我达到80%,但我认为可能有一些现有的解决方案更智能。 最佳答案 首先,不要尝试为此使用正则表达式。很有可能你会想出一个脆弱/脆弱的解决方案,它会随着HTML的变化而崩溃,或者很难管理和维护。您可以使用Nokogiri快速解析HTML并提取文本:require'nokogiri'h
我需要读入一个包含数字列表的文件。此代码读取文件并将其放入二维数组中。现在我需要获取数组中所有数字的平均值,但我需要将数组的内容更改为int。有什么想法可以将to_i方法放在哪里吗?ClassTerraindefinitializefile_name@input=IO.readlines(file_name)#readinfile@size=@input[0].to_i@land=[@size]x=1whilex 最佳答案 只需将数组映射为整数:@land边注如果你想得到一条线的平均值,你可以这样做:values=@input[x]
这道题是thisquestion的逆题.给定一个散列,每个键都有一个数组,例如{[:a,:b,:c]=>1,[:a,:b,:d]=>2,[:a,:e]=>3,[:f]=>4,}将其转换为嵌套哈希的最佳方法是什么{:a=>{:b=>{:c=>1,:d=>2},:e=>3,},:f=>4,} 最佳答案 这是一个迭代的解决方案,递归的解决方案留给读者作为练习:defconvert(h={})ret={}h.eachdo|k,v|node=retk[0..-2].each{|x|node[x]||={};node=node[x]}node[
我真的很习惯使用Ruby编写以下代码:my_hash={}my_hash['test']=1Java中对应的数据结构是什么? 最佳答案 HashMapmap=newHashMap();map.put("test",1);我假设? 关于java-等价于Java中的RubyHash,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/22737685/
我正在使用Rails构建一个简单的聊天应用程序。当用户输入url时,我希望将其输出为html链接(即“url”)。我想知道在Ruby中是否有任何库或众所周知的方法可以做到这一点。如果没有,我有一些不错的正则表达式示例代码可以使用... 最佳答案 查看auto_linkRails提供的辅助方法。这会将所有URL和电子邮件地址变成可点击的链接(htmlanchor标记)。这是文档中的代码示例。auto_link("Gotohttp://www.rubyonrails.organdsayhellotodavid@loudthinking.
我正在尝试使用boilerpipe来自JRuby。我看过guide从JRuby调用Java,并成功地将它与另一个Java包一起使用,但无法弄清楚为什么同样的东西不能用于boilerpipe。我正在尝试基本上从JRuby中执行与此Java等效的操作:URLurl=newURL("http://www.example.com/some-location/index.html");Stringtext=ArticleExtractor.INSTANCE.getText(url);在JRuby中试过这个:require'java'url=java.net.URL.new("http://www
给定一个复杂的对象层次结构,幸运的是它不包含循环引用,我如何实现支持各种格式的序列化?我不是来讨论实际实现的。相反,我正在寻找可能会派上用场的设计模式提示。更准确地说:我正在使用Ruby,我想解析XML和JSON数据以构建复杂的对象层次结构。此外,应该可以将该层次结构序列化为JSON、XML和可能的HTML。我可以为此使用Builder模式吗?在任何提到的情况下,我都有某种结构化数据-无论是在内存中还是文本中-我想用它来构建其他东西。我认为将序列化逻辑与实际业务逻辑分开会很好,这样我以后就可以轻松支持多种XML格式。 最佳答案 我最
我收到格式为的回复#我需要将其转换为哈希值(针对活跃商家)。目前我正在遍历变量并执行此操作:response.instance_variables.eachdo|r|my_hash.merge!(r.to_s.delete("@").intern=>response.instance_eval(r.to_s.delete("@")))end这有效,它将生成{:first="charlie",:last=>"kelly"},但它似乎有点hacky和不稳定。有更好的方法吗?编辑:我刚刚意识到我可以使用instance_variable_get作为该等式的第二部分,但这仍然是主要问题。
我只想对我一直在思考的这个问题有其他意见,例如我有classuser_controller和classuserclassUserattr_accessor:name,:usernameendclassUserController//dosomethingaboutanythingaboutusersend问题是我的User类中是否应该有逻辑user=User.newuser.do_something(user1)oritshouldbeuser_controller=UserController.newuser_controller.do_something(user1,user2)我