java读取文件时如何获得已读取的字节大小

java读取文件时如何获得已读取的字节大小,第1张

// 查看copy例子即可。

import javaawtBorderLayout;

import javaawtCursor;

import javaawtToolkit;

import javaawteventActionEvent;

import javaawteventActionListener;

import javabeansPropertyChangeEvent;

import javabeansPropertyChangeListener;

import javaioFile;

import javaioFileInputStream;

import javaioFileOutputStream;

import javaioInputStream;

import javaioOutputStream;

import javaxswingJButton;

import javaxswingJFrame;

import javaxswingJProgressBar;

import javaxswingSwingWorker;

public class Bar extends JFrame implements PropertyChangeListener

{

private static final long serialVersionUID = 1L;

private static final int MIN = 0;

private static final int MAX = 100;

private JProgressBar progressBar;

private JButton copy;

private Task task;

public Bar(String title)

{

setTitle(title);

setLayout(new BorderLayout());

progressBar = new JProgressBar(MIN, MAX);

progressBarsetValue(MIN);

progressBarsetStringPainted(true);

add(progressBar, BorderLayoutCENTER);

copy = new JButton("拷贝");

copyaddActionListener(new ActionListener()

{

@Override

public void actionPerformed(ActionEvent e)

{

start();

copysetEnabled(false);

}

});

add(copy, BorderLayoutEAST);

}

class Task extends SwingWorker<Void, Void>

{

@Override

public Void doInBackground()

{

setProgress(MIN);

File file = new File("ajpg");

long size = filelength();

byte[] bts = new byte[(int) (size / (Mathrandom()  50 + MAX - 50))];

int length = 0;

long cLength = 0;

try

{

InputStream stream = new FileInputStream(file);

OutputStream os = new FileOutputStream(new File("copy_aajpg"));

while((length = streamread(bts)) > 0)

{

oswrite(bts, 0, length);

cLength += length;

setProgress((int) (cLength  MAX / size));

Threadsleep(30);

}

osflush();

osclose();

streamclose();

}

catch(Exception e)

{

eprintStackTrace();

}

return null;

}

@Override

public void done()

{

setTitle("拷贝完毕");

ToolkitgetDefaultToolkit()beep();

copysetEnabled(true);

setCursor(null);

}

}

public void propertyChange(PropertyChangeEvent evt)

{

if("progress" == evtgetPropertyName())

{

int progress = (Integer) evtgetNewValue();

progressBarsetValue(progress);

}

}

private void start()

{

task = new Task();

taskaddPropertyChangeListener(this);

taskexecute();

setTitle("正在拷贝");

setCursor(CursorgetPredefinedCursor(CursorWAIT_CURSOR));

}

private static void createAndShowGUI()

{

Bar frame = new Bar("Bar");

framesetAlwaysOnTop(true);

framesetSize(280, 60);

framesetResizable(false);

framesetLocationRelativeTo(null);

framesetDefaultCloseOperation(JFrameEXIT_ON_CLOSE);

framesetVisible(true);

}

public static void main(String[] args)

{

javaxswingSwingUtilitiesinvokeLater(new Runnable()

{

public void run()

{

createAndShowGUI();

}

});

}

}

首先先说一下JVM内存结构问题,JVM为两块:PermanentSapce和HeapSpace,其中

Heap = }。PermantSpace负责保存反射对象,一般不用配置。JVM的Heap区可以通过-X参数来设定。

当一个URL被访问时,内存申请过程如下:

A JVM会试图为相关Java对象在Eden中初始化一块内存区域

B 当Eden空间足够时,内存申请结束。否则到下一步

C JVM试图释放在Eden中所有不活跃的对象(这属于1或更高级的垃圾回收), 释放后若Eden空间仍然不足以放入新对象,则试图将部分Eden中活跃对象放入Survivor区

D Survivor区被用来作为Eden及OLD的中间交换区域,当OLD区空间足够时,Survivor区的对象会被移到Old区,否则会被保留在Survivor区

E 当OLD区空间不够时,JVM会在OLD区进行完全的垃圾收集(0级)

F 完全垃圾收集后,若Survivor及OLD区仍然无法存放从Eden复制过来的部分对象,导致JVM无法在Eden区为新对象创建内存区域,则出现”out of memory错误”

JVM调优建议:

ms/mx:定义YOUNG+OLD段的总尺寸,ms为JVM启动时YOUNG+OLD的内存大小;mx为最大可占用的YOUNG+OLD内存大小。在用户生产环境上一般将这两个值设为相同,以减少运行期间系统在内存申请上所花的开销。

NewSize/MaxNewSize:定义YOUNG段的尺寸,NewSize为JVM启动时YOUNG的内存大小;MaxNewSize为最大可占用的YOUNG内存大小。在用户生产环境上一般将这两个值设为相同,以减少运行期间系统在内存申请上所花的开销。

PermSize/MaxPermSize:定义Perm段的尺寸,PermSize为JVM启动时Perm的内存大小;MaxPermSize为最大可占用的Perm内存大小。在用户生产环境上一般将这两个值设为相同,以减少运行期间系统在内存申请上所花的开销。

SurvivorRatio:设置Survivor空间和Eden空间的比例

内存溢出的可能性

1 OLD段溢出

这种内存溢出是最常见的情况之一,产生的原因可能是:

1) 设置的内存参数过小(ms/mx, NewSize/MaxNewSize)

2) 程序问题

单个程序持续进行消耗内存的处理,如循环几千次的字符串处理,对字符串处理应建议使用StringBuffer。此时不会报内存溢出错,却会使系统持续垃圾收集,无法处理其它请求,相关问题程序可通过Thread Dump获取(见系统问题诊断一章)单个程序所申请内存过大,有的程序会申请几十乃至几百兆内存,此时JVM也会因无法申请到资源而出现内存溢出,对此首先要找到相关功能,然后交予程序员修改,要找到相关程序,必须在Apache日志中寻找。

当Java对象使用完毕后,其所引用的对象却没有销毁,使得JVM认为他还是活跃的对象而不进行回收,这样累计占用了大量内存而无法释放。由于目前市面上还没有对系统影响小的内存分析工具,故此时只能和程序员一起定位。

2 Perm段溢出

通常由于Perm段装载了大量的Servlet类而导致溢出,目前的解决办法:

1) 将PermSize扩大,一般256M能够满足要求

2) 若别无选择,则只能将servlet的路径加到CLASSPATH中,但一般不建议这么处理

3 C Heap溢出

系统对C Heap没有限制,故C Heap发生问题时,Java进程所占内存会持续增长,直到占用所有可用系统内存

参数说明:

JVM 堆内存(heap)设置选项

参数格式

说 明

设置新对象生产堆内存(Setting the Newgeneration heap size)

-XX:NewSize

通过这个选项可以设置Java新对象生产堆内存。在通常情况下这个选项的数值为1 024的整数倍并且大于1MB。这个值的取值规则为,一般情况下这个值-XX:NewSize是最大堆内存(maximum heap size)的四分之一。增加这个选项值的大小是为了增大较大数量的短生命周期对象

增加Java新对象生产堆内存相当于增加了处理器的数目。并且可以并行地分配内存,但是请注意内存的垃圾回收却是不可以并行处理的

设置最大新对象生产堆内存(Setting the maximum New generation heap size)

-XX:MaxNewSize

通过这个选项可以设置最大Java新对象生产堆内存。通常情况下这个选项的数值为1 024的整数倍并且大于1MB

其功用与上面的设置新对象生产堆内存-XX:NewSize相同

设置新对象生产堆内存的比例(Setting New heap size ratios)

-XX:SurvivorRatio

新对象生产区域通常情况下被分为3个子区域:伊甸园,与两个残存对象空间,这两个空间的大小是相同的。通过用-XX:SurvivorRatio=X选项配置伊甸园与残存对象空间(Eden/survivor)的大小的比例。你可以试着将这个值设置为8,然后监控、观察垃圾回收的工作情况

设置堆内存池的最大值(Setting maximum heap size)

-Xmx

通过这个选项可以要求系统为堆内存池分配内存空间的最大值。通常情况下这个选项的数值为1 024的整数倍并且大于1 MB

一般情况下这个值(-Xmx)与最小堆内存(minimum heap size –Xms)相同,以降低垃圾回收的频度

取消垃圾回收

-Xnoclassgc

这个选项用来取消系统对特定类的垃圾回收。它可以防止当这个类的所有引用丢失之后,这个类仍被引用时不会再一次被重新装载,因此这个选项将增大系统堆内存的空间

设置栈内存的大小

-Xss

这个选项用来控制本地线程栈的大小,当这个选项被设置的较大(>2MB)时将会在很大程度上降低系统的性能。因此在设置这个值时应该格外小心,调整后要注意观察系统的性能,不断调整以期达到最优

最后说一句,你的机器的连接数设置也至关重要,连接的关闭最好把时间设置的少些,那些连接非常耗费资源。也是引起内存泄露的主要原因。

试一下这个方法 thissetMaximizedBounds(new Rectangle(400,200,600,400));可以设置窗口最大的尺寸

public void setMaximizedBounds(Rectangle bounds)

设置此框架的最大化边界。

当帧处于最大化状态时,系统提供一些默认边界。 该方法允许覆盖那些系统提供的值中的一些或全部。

如果bounds为null ,则接受系统提供的边界。

如果非null可以通过将要从系统接受的字段设置为IntegerMAX_VALUE来接受其他系统提供的值。

注意,给定的最大化边界用作本机系统的提示,因为底层平台可能不支持设置最大化窗口的位置和/或大小。

如果是这种情况,提供的值不会影响最大化状态下的帧的外观。

参数

bounds - 最大化状态的界限

只需要使用递归就可以了

import javaioFile;

public class Demo {

    public static void main(String[] args) {

        File fileDir = new File("C:/Users/Administrator/Desktop/prex");

        getFiles(fileDir);

    }

    public static void getFiles(File fileDir) {// *** 作文件

        if (!fileDirexists()) {

            new RuntimeException();

        }

        File[] files = fileDirlistFiles();

        if (files != null) {// 判断是否还有子目录

            for (int i = 0; i < fileslength; i++) {

                if (files[i]isFile() && files[i]length() == 10 1024) {// 判断是文件,且大小为10k

                    files[i]renameTo(new File(// 转存储到指定的位置,名字和原来一样

                            "C:/Users/Administrator/Desktop/copy", files[i]

                                    getName()));

                } else {

                    getFiles(files[i]);// 递归调用,直到所有的文件都没有了子目录

                }

            }

        }

    }

}

import javaioFile;

import javautilArrayList;

import javautilCollection;

import javautilList;

import orgapachecommonsioFileUtils;

import orgapachecommonsioIOUtils;

public class Test {

public static void main(String[] args) throws Exception {

String searchStr = "APPTYPEID";

File searchDir = new File("D:\\xampp\\htdocs\\discuz");

List<Search> list = new ArrayList<Search>();

Collection<File> files = FileUtilslistFiles(searchDir, null, true);

List<String> lines = null;

for (File file : files) {

lines = FileUtilsreadLines(file);

for (int i = 0; i < linessize(); i++) {

if (linesget(i)indexOf(searchStr) != -1) {

Search s = new Search();

ssetFilename(filegetName());

ssetLine(i + 1);

ssetContent(linesget(i));

listadd(s);

}

}

}

StringBuffer sb = new StringBuffer();

for (Search s : list) {

sbappend(sgetFilename() + " , " + sgetLine() + " , " + sgetContent())append(

IOUtilsLINE_SEPARATOR);

}

FileUtilswriteStringToFile(new File("D:\\searchtxt"), sbtoString(), "UTF-8");

}

}

class Search {

private String filename;

private int line;

private String content;

public String getFilename() {

return filename;

}

public void setFilename(String filename) {

thisfilename = filename;

}

public String getContent() {

return content;

}

public void setContent(String content) {

thiscontent = content;

}

public void setLine(int line) {

thisline = line;

}

public int getLine() {

return line;

}

}

1、java file 获取文件大小 ,单位是kb,Filelength()获得文件字节大小/1024 获得 KB数, 由于整数运算省略小数部分,故加1。

2、目前Java获取文件大小的方法有两种:

1)通过file的length()方法获取。

2)通过流式方法获取。

3、通过length方法:

1)创建一个文件。

2)获取文件大小。

3)查看结果。

你使用urlConnectiongetContentLength()) 试一下吧, 不是所有的服务器都给你长度信息, 你给的url就不支持。 一般说来不读完文件不知道长度。另外: 你可以 用inavailable()获取本次读时缓冲区内容的长度。

>

以上就是关于java读取文件时如何获得已读取的字节大小全部的内容,包括:java读取文件时如何获得已读取的字节大小、怎样查看JAVA内存的大小、关于java中setMaximumSize等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/9667335.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-30
下一篇 2023-04-30

发表评论

登录后才能评论

评论列表(0条)

保存