java 乘法_〔Java〕乘除法和等效的位运算

/*******************************************************************************

*

* 乘除法和等效的位运算

*

* 1024 = 2*2*2*2*2*2*2*2*2*2 = 100 0000 0000

*

******************************************************************************/

class BitOperation

{

public static void main( String[] args )

{

//被除数

long dividend=182495073L;

long temp=0L;

long begin=0L;

//

// dividend/1024等效于dividend>>10

//

begin=System.currentTimeMillis();

for( int i=0; i<10000000; i++ )

{

temp=dividend/1024;

}

System.out.println( temp+" 总共耗时:"+( System.currentTimeMillis()-begin )+"毫秒" );

begin=System.currentTimeMillis();

for( int i=0; i<10000000; i++ )

{

temp=dividend>>10;

}

System.out.println( temp+" 总共耗时:"+( System.currentTimeMillis()-begin )+"毫秒\r\n" );

//

// dividend*1024等效于dividend<<10

//

begin=System.currentTimeMillis();

for( int i=0; i<10000000; i++ )

{

temp=dividend*1024;

}

System.out.println( temp+" 总共耗时:"+( System.currentTimeMillis()-begin )+"毫秒" );

begin=System.currentTimeMillis();

for( int i=0; i<10000000; i++ )

{

temp=dividend<<10;

}

System.out.println( temp+" 总共耗时:"+( System.currentTimeMillis()-begin )+"毫秒\r\n" );

//

// dividend%1024等效于dividend-( dividend>>10<<10 )

//

begin=System.currentTimeMillis();

for( int i=0; i<10000000; i++ )

{

temp=dividend%1024;

}

System.out.println( temp+" 总共耗时:"+( System.currentTimeMillis()-begin )+"毫秒" );

begin=System.currentTimeMillis();

for( int i=0; i<10000000; i++ )

{

temp=dividend-( dividend>>10<<10 );

}

System.out.println( temp+" 总共耗时:"+( System.currentTimeMillis()-begin )+"毫秒\r\n" );

}

}

posted on 2007-09-17 09:17 NeedJava 阅读(2951) 评论(3)  编辑  收藏 所属分类: Java

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值