生成字母序列,如A,AA,AAA

  • 不知道长度
  • 区分大小写
  1. 新建MAVEN工程
<dependency>
	<groupId>org.apache.poi</groupId>
	<artifactId>poi</artifactId>
	<version>3.16</version>
</dependency> 
<dependency>
	<groupId>org.apache.poi</groupId>
	<artifactId>poi-ooxml</artifactId>
	<version>3.16</version>
</dependency>
import java.io.ByteArrayInputStream;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;

import org.apache.poi.EncryptedDocumentException;
import org.apache.poi.openxml4j.exceptions.InvalidFormatException;
import org.apache.poi.ss.usermodel.WorkbookFactory;

public class App {
	public static void main(String[] args) throws Exception {
		InputStream is = new FileInputStream("D:\\aaa.xlsx");
		byte[] buff = new byte[is.available()]; // 将数据读取缓存, 避免频繁访问磁盘
		is.read(buff);
		is.close();

		int threadTotal = 2; // 线程数量
		int start = 1; // 循环开始位置, 便于中断后继续

		ExecutorService es = Executors.newFixedThreadPool(threadTotal);
		for (int i = 0; i < threadTotal; i++) {
			es.execute(new MyTask(start, threadTotal, i, buff));
		}
	}
}

/**
 * 任务
 *
 */
class MyTask implements Runnable {
	static String result = null; // 结果
	byte[] buf = null; // 数据缓存
	int start = 0; // 开始位置
	int step = 0; // 总的线程数量
	int mark = 0; // 运行标记, 用于分配任务

	/**
	 * 
	 * @param start
	 *            开始位置
	 * @param threadTotal
	 *            总线程数量
	 * @param mark
	 *            当前线程的标记
	 * @param buf
	 *            数据缓存
	 */
	public MyTask(int start, int threadTotal, int mark, byte[] buf) {
		this.start = start + mark;
		this.mark = mark;
		this.step = threadTotal;
		this.buf = buf;
	}

	/**
	 * 依据输入数字生成字符串[A-Za-z]
	 * 
	 * @param i
	 * @return
	 */
	public String mm(long i) {
		if (i < 52) {
			if (i < 26)
				return String.valueOf((char) (65 + i));
			else
				return String.valueOf((char) (97 + i - 26));
		} else {
			return mm(i / 52 - 1) + mm(i % 52);
		}
	}

	private boolean work(String pwd) {
		try {
			InputStream is = new ByteArrayInputStream(buf);
			WorkbookFactory.create(is, pwd);
		} catch (EncryptedDocumentException e) {
			return false;
		} catch (IOException e) {
		} catch (InvalidFormatException e) {
		}
		MyTask.result = pwd;
		return true;
	}

	@Override
	public void run() {
		Thread.currentThread().setName("T" + mark);
		int cnt = 0;
		while (MyTask.result == null) {
			if (cnt++ == 100 && this.mark == 0) {
				System.out.println(Thread.currentThread().getName() + " running at " + start + ", " + mm(start));
				cnt = 1;
			}
			if (work(mm(start)))
				break;
			start += step;
		}
		System.err.println(">>>>>>>>>>>>>>>>" + MyTask.result);
	}
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值