位运算效率 java_java位运算与乘法速度比较实例源码介绍

java位运算与乘法速度比较实例源码介绍这里我主要和大家一起讨论乘法与位运算。一直以来,很多人都认为位运算要比乘法执行效率高,我一直也是这样认为的,但是真的是这样的吗?让我们看下面的代码:

package Optimize;

import javax.microedition.midlet.MIDlet;

import javax.microedition.midlet.MIDletStateChangeException;

public class mulTest extends MIDlet {

public mulTest() {

super();

// TODO Auto-generated constructor stub

}

protected void startApp() throws MIDletStateChangeException {

// TODO Auto-generated method stub

long timer = 0L;

int i = 9876;

int j = i;

timer = System.currentTimeMillis();

for (int k = 100000; k > 0; k–) {

j = j << 7;

}

System.out.println(System.currentTimeMillis() – timer);

timer = System.currentTimeMillis();

for (int k = 100000; k > 0; k–) {

i = i * 128;

}

System.out.println(System.currentTimeMillis() – timer);

}

protected void pauseApp() {

// TODO Auto-generated method stub

}

protected void destroyApp(boolean arg0) throws MIDletStateChangeException {

// TODO Auto-generated method stub

}

}

测试出来的结果让我吃惊,位运算使用的时间还多点,在10万次的重复运算中,乘法要快30-40毫秒左右,这说明在使用位运算是没有必要的。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值