簡體   English   中英

為什么在 java 中的 for 循環中使用 f.length() 效率如此之低?

[英]Why is using f.length() in a for loop so inefficient in java?

我正在編寫一個程序,該程序使用文件 class 和緩沖輸入和 Output Streams 使用一些文件處理,發現當我使用以下代碼時

for(long j = 0; j < f2.length(); j++) {
    out.write(in.read());
}

效率非常低,大約需要 15251 毫秒。 但是,如果我先將 f2.length() 保存到變量中

long y = f2.length();
for(long j = 0; j < y; j++) {
    out.write(in.read());
}

它只需要 74 毫秒。 為什么第二個區塊效率更高?

是否有可能將 f2.length() 保存在變量 y 中只會計算一次 length() ,並且在 for 循環中它將計算每次迭代,將 f2.length() 計算乘以 n 次迭代 n 次。

我也很好奇。 :)

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM