java 多线程批量插入数据_多线程循环批量处理以及多线程操作文件写入相关思路...

文章介绍了如何使用Java实现多线程批量处理数据,避免重复,并在处理过程中高效地将结果写入文件,以提高执行效率。通过创建线程池,将任务平均分配给每个线程,确保数据的正确处理,同时避免文件写入时的乱码问题。测试结果显示,多线程处理速度远超单线程。
摘要由CSDN通过智能技术生成

前言:这篇文章来源于我写的一个小软件:多线程批量探测指定IP段的每个IP的服务器类型(Apache,tomcat,IIS。。。)并将探测结果写入到一个文件中。那么问题来了:如何保证在IP的循环递增过程中使用多线程而每个IP不被重复使用提交(PS:当然为了避免重复,可以用线程等待,唤醒,不过我个人觉得这种方式不一定比单线程强多少)?同时,在将结果写入到文件时,怎样避免因各个线程的抢占式写入导致文件乱码?

经过了一番思考,我觉得可以这样想:对于一个循环的连续数字段,我们可以在给定线程数时,就将这一段数字平均分配给每个线程,因此每个线程只需要按步处理它的任务就行。因为没有跟其他线程的数据发生耦合,所以就可以保证每个数字都只被处理一次,同时在文件写入时也不会出现问题。

接下来,我按照这个思路写了一段测试代码,完整代码如下:package thread;

import java.io.BufferedWriter;

import java.io.File;

import java.io.FileWriter;

import java.io.IOException;

public class Test1 {

public static void main(String[] args) {

long millis1 = System.currentTimeMillis();

int threadNum = 5; // 测试用的线程数目

String fileName = "C:\\Users\\Administrator\\Desktop

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值