java生成有序的序号,java生成序号

本文介绍了一个Java程序,通过Calendar和HashMap实现生成包含年月日和递增序号的14位字符串,用于创建不重复的序列号。方法中还展示了如何处理序号不足6位的情况,并在main方法中进行了测试。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

序号有14位数字组成,前8位为年月日,后六位为序号。

1.[代码]Java生成序号

package com.wx.utils.tool;

import java.text.DateFormat;

import java.text.SimpleDateFormat;

import java.util.Calendar;

import java.util.Date;

import java.util.HashMap;

import java.util.Map;

/**

* 生成序号

* @author feizi

* @time 2014-11-5下午5:27:23

*/

public class CreateSerialNo {

private static Map map=new HashMap();

private static String STATNUM="000001";

/**

* 获取年月日

* @return

*/

public String getTime(){

Calendar cal = Calendar.getInstance();

cal.setTime(new Date());

DateFormat df = new SimpleDateFormat("yyyyMMdd");

return df.format(cal.getTime());

}

/**

* 判断序号是否到了最后一个

* @param s

* @return

*/

public String getLastSixNum(String s){

String rs=s;

int i=Integer.parseInt(rs);

i+=1;

rs=""+i;

for (int j = rs.length(); j <6; j++) {

//rs="0"+rs;

//直接使用StringUtils类的leftPad方法处理补零

rs = StringUtils.leftPad(rs,j+1, "0");

}

return rs;

}

/**

* 产生不重复的号码 加锁

* @return

*/

public synchronized String getNum(){

String yearAMon = getTime();

String last6Num=map.get(yearAMon);

if(last6Num==null){

map.put(yearAMon,STATNUM);

}else{

map.put(yearAMon,getLastSixNum(last6Num));

}

return yearAMon+map.get(yearAMon);

}

/**

* main测试

* @param args

*/

public static void main(String[] args) {

CreateSerialNo t= new CreateSerialNo();

for (int i = 0; i < 200; i++) {

System.out.println(t.getNum());

}

}

}

public synchronized String nextId() { long timestamp = timeGen(); //获取当前毫秒数 //如果服务器时间有问题(时钟后退) 报错。 if (timestamp < lastTimestamp) { throw new RuntimeException(String.format( "Clock moved backwards. Refusing to generate id for %d milliseconds", lastTimestamp - timestamp)); } //如果上次生成时间和当前时间相同,在同一毫秒内 if (lastTimestamp == timestamp) { //sequence自增,因为sequence只有12bit,所以和sequenceMask相与一下,去掉高位 sequence = (sequence + 1) & sequenceMask; //判断是否溢出,也就是每毫秒内超过4095,当为4096时,与sequenceMask相与,sequence就等于0 if (sequence == 0) { timestamp = tilNextMillis(lastTimestamp); //自旋等待到下一毫秒 } } else { sequence = 0L; //如果和上次生成时间不同,重置sequence,就是下一毫秒开始,sequence计数重新从0开始累加 } lastTimestamp = timestamp; long suffix = (datacenterId << datacenterIdShift) | (workerId << workerIdShift) | sequence; String datePrefix = DateFormatUtils.format(timestamp, "yyyyMMddHHMMssSSS"); return datePrefix + suffix; } protected long tilNextMillis(long lastTimestamp) { long timestamp = timeGen(); while (timestamp <= lastTimestamp) { timestamp = timeGen(); } return timestamp; } protected long timeGen() { return System.currentTimeMillis(); } private byte getLastIP(){ byte lastip = 0; try{ InetAddress ip = InetAddress.getLocalHost(); byte[] ipByte = ip.getAddress(); lastip = ipByte[ipByte.length - 1]; } catch (UnknownHostException e) { e.printStackTrace(); } return lastip; }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值