`
498320858
  • 浏览: 386659 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

依据记录总数和每页大小取页数

 
阅读更多

例如:总记录数为totalrow,每页显示数为pagesize,现在要求总页数totalpage

 

1 常用方法:整除,判断余数,余数大于0,整除结果加1。

 

if(totalrow%pagesize==0)

           totalpage=totalrow/pagesize;

else

           totalpage=totalrow/pagesize+1;

 

这种计算方法,会导致程序先取余数,再比较是否有余数,再进行整除操作,然后再进行相加操作

 

 

2 今天无意间发现还有另外一种计算方式(以前没怎么多想)

 

totalpage=(totalrow+(pagesize-1))/pagesize

 

由于余数最小为1,那么先加上最大的余数(pagesize-1)后,只要totalrow/pagesize余数不为0,(totalpage+(pagesize-1))/pagesize的结果一定会比totalrow/pagesize大1;否则结果相等;此计算公式结果和方法1中结果一致,但是写法简单,无需bool判断,而且整除或者取余数操作只进行了一步,相对来讲效率有所提升,效率比较代码

 

long t1=System.currentTimeMillis();
	for(int i=0;i<10000;i++){
		int totalrow=(int)(Math.random()*10000000.00);
		int pagesize=50;
		if(totalrow%pagesize==0){
			System.out.println(totalrow/pagesize);
		}else{
			System.out.println(totalrow/pagesize+1);
		}
	}

	long t2=System.currentTimeMillis();

	for(int i=0;i<10000;i++){
		int totalrow=(int)(Math.random()*10000000.00);
		int pagesize=50;
		System.out.println((totalrow+(pagesize-1))/pagesize);
	}

	long t3=System.currentTimeMillis();
	
	System.out.println("时间间隔:方法一耗时["+(t2-t1)+"]ms\t方法二耗时["+(t3-t2)+"]ms");

 连续执行4次,执行结果:

时间间隔:方法一耗时[277]ms    方法二耗时[223]ms

时间间隔:方法一耗时[281]ms    方法二耗时[256]ms

时间间隔:方法一耗时[335]ms    方法二耗时[248]ms

时间间隔:方法一耗时[281]ms    方法二耗时[215]ms

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics