Java实现去除字符串中的英文字符后,倒序方式(第一个字符最后一个显示),以每行8个字符的格式输出到文件A中...

1、题目:去除字符串中的英文字符后,倒序方式(第一个字符最后一个显示),以每行8个字符的格式输出到文件A中

2、思路

使用正则表达式 + replaceAll()方法去除字符串中的英文字符后。

使用StringBuffer的reverse()方法倒序字符串,8 个字符后insert()方法插入了换行字符。

输出时自动解析换行字符到文件A中。

3、题解

import java.io.FileWriter;
import java.io.IOException;

public class Code2 {
    //去除字符串中的英文字符后,
    //倒序方式(第一个字符最后一个显示),
    //以每行8个字符的格式输出到文件A中
    public static void main(String[] args) throws IOException {

        String s = "~asd;4#1er&67qwe234#1&3sdBd1d1,@3ret#1&56ghk123#1A&34D";

        FileWriter fw = new FileWriter("C:/Users/log/A.txt");  
 
        s = s.replaceAll("[a-zA-Z]","" );   //正则表达式[a-zA-Z]空值替换,去除字符串中的英文字符

        StringBuffer sBuffer = new StringBuffer(s);

        sBuffer.reverse();  //倒序

        int counter = 0;  //记录插入了几个换行字符

        for(int i = 8;i < sBuffer.length()-1; i+=8){

            sBuffer.insert(i + counter, "\n");    //在下标 i + counter 位置处插入换行符

            counter++;  
        } 
            
        s = sBuffer.toString();

        fw.write(s);    

        fw.flush();
        
    }
    
}

4、扩展:write()方法和flush()的作用

冯诺依曼体系结构中,将计算机分为运算器,控制器,存储器,输入/输出设备。

存储器则可以分为主存(内存)和辅存(硬盘),

输入输出设备主要来完成系统的I/O操作,I/O操作主要是对硬盘中的数据进行读和取。

由于CPU的运算速度远远大于I/O操作,因此,当一个进程需要产生许多I/O操作,会耗费许多系统资源,

由于CPU不能直接访问外存(硬盘) ,需要借助内存来完成对硬盘中的数据的读/取。完成此操作又不得不借助于I/O

JAVA的输入/输出流在默认情况下 ,是不被缓存区缓存的,

因此每发生一次read()和write()方法都需要请求操作系统再分发/接受一个字节,这样运行效率必然会降低

相比之下,请求一个数据块并将其置于缓冲区中会显得更加高效。我们可以将硬盘中的数据事先添加到缓冲池来预存数据,待CPU产生I/O操作时

可以从这个缓存池中来读取数据,这样减少了CPU的I/O的次数提高了程序的运行效率

JAVA也采用了这种方式。通过为基本流添加了处理流来减少I/O操作的次数

发生read()/write()=》将内容存到缓冲区中=》flush()冲刷出流将所有的缓存数据强行发送到目的地====》完成OutputStream/Writer中的方法:

    abstract void write(int n) 写出一个字节的数据

    void write(byte[] b) 写出所有字节到数组中

    void write(byte[] b,int off, int len) 写出某个范围的字节 到数组b中 b数据写出的数组off第一个写出字节在b中的偏移量len 写出字节的最大数量

    void close() 冲刷并关闭输出流

    void flush() 冲刷出流,将所有缓冲的数据强制发送到目的地

read()方法和write()是线程阻塞的,

还有一种情况,当我们将数据预存到缓冲池中时,当数据的长度满足缓冲池中的大小后,

才会将缓冲池中的数据成块的发送,若数据的长度不满足缓冲池中的大小,需要继续存入,

待数据满足预存大小后再成块的发送。往往在发送文件过程中,文件末尾的数据大小不能满足缓冲池的大小。

最终导致这部分的数据停留在缓冲池无法发送。

这时,就需要我们在write()方法后,手动调用flush()方法,强制刷出缓冲池中的数据,即使数据长度不满足缓冲池的大小从而保证数据的正常发送。

当然,当我们调用流的close()方法后,系统也会自动将输出流缓冲区的数据刷出,同时可以保证流的物理资源被回收。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

CodeRain程序雨

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值