| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 695 人关注过本帖
标题:位移运算问题
取消只看楼主 加入收藏
dary
Rank: 1
等 级:新手上路
帖 子:7
专家分:3
注 册:2009-11-22
结帖率:0
收藏
已结贴  问题点数:1 回复次数:1 
位移运算问题
下面红色部分 short num  用bb[0]<<8 | bb[1]  左移8位 在|bb[1]后面的8位 不是应该就可以了吗?
为什么还要bb[1] & 0xff 然后 num = num&0xFFFF;   呢?    谢谢给讲讲 最好举个列子  介绍我看看资料
import *;
public class ReaderDemo {
    public static void main(String[]args) {
        try {
            PushbackInputStream aa =new PushbackInputStream(new FileInputStream(args[0]));
            byte [] bb =new byte[2];
            ByteArrayInputStream cc =new ByteArrayInputStream(bb);
            InputStreamReader dd =new InputStreamReader(cc);
            int num =0;
            while(aa.read(bb)!=-1) {
                num =(short) ((bb[0]<<8) | (bb[1] & 0xff));
                num = num&0xFFFF;
                if(num >= 0xA440 && num < 0xFFFF) {
                    System.out.println("BIG5: "+(char) dd.read());
                    cc.reset();
                }
                else {
                    aa.unread(bb,1,1);
                    System.out.println("ASCII: "+(char) bb[0]);
                }
            }
            aa.close();
        }
        catch(Exception e) {
            e.printStackTrace();
        }
    }
}
搜索更多相关主题的帖子: 运算 位移 
2009-11-24 16:41
dary
Rank: 1
等 级:新手上路
帖 子:7
专家分:3
注 册:2009-11-22
收藏
得分:0 
有没好心人给讲讲啊
2009-11-25 16:32
快速回复:位移运算问题
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.017016 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved