关闭

位运算与乘法速度比较

标签: timerconstructorclass编程测试
3122人阅读 评论(0) 收藏 举报
分类:
【IT168 编程开发】这里我主要和大家一起讨论乘法与位运算。一直以来,很多人都认为位运算要比乘法执行效率高,我一直也是这样认为的,但是真的是这样的吗?让我们看下面的代码:
 
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毫秒左右,这说明在使用位运算是没有必要的。

1
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:551384次
    • 积分:3002
    • 等级:
    • 排名:第13939名
    • 原创:90篇
    • 转载:41篇
    • 译文:0篇
    • 评论:24条
    最新评论