Java线程创建和销毁的开销
server对于每一个新来的请求都创建一个新的线程去处理:
public class ThreadPerTaskWebServer {
public static void main(String[] args) {
ServerSocket socket = new ServerSocket(80);
while (true) {
final Socket connetion = socket.accept();
new Thread(() -> {
handleRequest(connetion);
}).start();
}
}
}
开销主要在于3点:
- 创建和销毁线程的开销,Java的线程对应的是OS的线程,创建时需要OS辅助操作,频繁的销毁对GC也有压力
- 线程会消耗内存,且可运行的线程越多所占用的内存越大(如果只是创建但是没有执行的话,由于有虚拟内存的存在所以OS只分配了虚拟内存,只有当真正去访问这些内存时,操作系统才会将虚拟内内存映射到物理内存上,才真正消耗物理内存),同时线程在竞争CPU资源时也会有性能的开销,因为需要频繁的发生上下文切换,在一个时间段内若上下文切换的时间越长那么CPU的利用率就越低
- OS通常设置最大线程数以及线程栈的大小,数量太多可能会出现问题
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 零经验选手,Compose 一天开发一款小游戏!
· 因为Apifox不支持离线,我果断选择了Apipost!
· 通过 API 将Deepseek响应流式内容输出到前端