String的substring方法. 难道是JAVA的bug?

Java内存泄漏案例
本文介绍了一个使用Java进行网页内容抓取时遇到的内存泄漏问题。通过对比不同字符串处理方法的效果,作者发现直接使用substring方法可能导致内存占用持续上升,而通过创建新字符串对象则可以避免这一问题。
部署运行你感兴趣的模型镜像
前几天写个小东西有个大问题。
使用java获取网页的源代码截东西。后来发现内存光涨不降。

发现String.substring中内容如果过大就有问题。
后来使用
String content = //获取网页内容 最好大一点
String temp = content.subString(0, 10);
String result = new String(temp);

return result;

如果直接返回temp。。。内存就有好瞧的。。大家可以试试下面的代码。基本上一分钟就over了。。最好用jconsole看效果。 呵呵。 如果是我其它的地方写错了。 请大家指正了。

验证程序 HttpClientUtil就是一取网页内容的。可以用别的替代。:
public class Test {

/**
* @param args
*/
public static void main(String[] args) {

String s1 = "http://finance.sina.com.cn/realstock/company/sz000831/nc.shtml";

List<String> s = new ArrayList<String>();
while(true){//这里的true是我特意加的。为的是延长时间来看到问题的出现。呵呵。 评论的那几位如果空,请照着试一下就知道我说的情况了。 问题不在这个while的死循环。。。
String source = HttpClientUtil.getGetResponseWithHttpClient(s1, "gb2312");
String temp = source.substring(0, 10);
s.add(temp);
//s.add(new String(temp));
}

}

}

您可能感兴趣的与本文相关的镜像

Kotaemon

Kotaemon

AI应用

Kotaemon 是由Cinnamon 开发的开源项目,是一个RAG UI页面,主要面向DocQA的终端用户和构建自己RAG pipeline

HTTP状态 500 - 内部服务器错误 类型 异常报告 消息 Range [0, -1) out of bounds for length 11 描述 服务器遇到一个意外的情况,阻止它完成请求。 例外情况 java.lang.StringIndexOutOfBoundsException: Range [0, -1) out of bounds for length 11 java.base/jdk.internal.util.Preconditions$1.apply(Preconditions.java:55) java.base/jdk.internal.util.Preconditions$1.apply(Preconditions.java:52) java.base/jdk.internal.util.Preconditions$4.apply(Preconditions.java:213) java.base/jdk.internal.util.Preconditions$4.apply(Preconditions.java:210) java.base/jdk.internal.util.Preconditions.outOfBounds(Preconditions.java:98) java.base/jdk.internal.util.Preconditions.outOfBoundsCheckFromToIndex(Preconditions.java:112) java.base/jdk.internal.util.Preconditions.checkFromToIndex(Preconditions.java:349) java.base/java.lang.String.checkBoundsBeginEnd(String.java:4865) java.base/java.lang.String.substring(String.java:2834) org.jivesoftware.site.PluginDownloadServlet.parsePluginVersion(PluginDownloadServlet.java:677) org.jivesoftware.site.PluginDownloadServlet.parse(PluginDownloadServlet.java:524) org.jivesoftware.site.PluginDownloadServlet.doGet(PluginDownloadServlet.java:105) javax.servlet.http.HttpServlet.service(HttpServlet.java:529) javax.servlet.http.HttpServlet.service(HttpServlet.java:623) org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:51) com.opensymphony.sitemesh.webapp.SiteMeshFilter.obtainContent(SiteMeshFilter.java:182) com.opensymphony.sitemesh.webapp.SiteMeshFilter.doFilter(SiteMeshFilter.java:85) ):注意 主要问题的全部 stack 信息可以在 server logs 里查看 Apache Tomcat/9.0.87
最新发布
10-02
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值