| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 695 人关注过本帖
标题:位移运算问题
只看楼主 加入收藏
dary
Rank: 1
等 级:新手上路
帖 子:7
专家分:3
注 册:2009-11-22
结帖率:0
收藏
已结贴  问题点数:1 回复次数:4 
位移运算问题
下面红色部分 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
流星雨
Rank: 16Rank: 16Rank: 16Rank: 16
来 自:JAVA风暴
等 级:版主
威 望:43
帖 子:1854
专家分:1868
注 册:2004-5-30
收藏
得分:0 
与运算就是见0为0 ,| 符号是或运算,或运算是见1为1,
程序中0xFFFF明显是10进指,你先转成2进制,F明显是1111,16转2是最好转的,分别1位16进制转4位2进制,
位移也是一样,你先转成2进制,再移动。前后补0。
举个很简单的例子吧
1111&(与)0000 = 0000
1111| (或)0000 = 1111

感谢你们带我找到星空下美丽神话,无论经历多少苦痛也不放弃的梦;插上希望翅膀乘风我和你们飞翔,飞过海天尽头携手把梦想实现.....
2009-11-29 20:58
haizeng
Rank: 2
来 自:xdpsj.com
等 级:等待验证会员
帖 子:61
专家分:36
注 册:2009-11-30
收藏
得分:0 
只要 记住 对应为上只要是1 就是1 其他的统统为0

[url=http://www./]石料生产线[/url]
[url=http://www.]破碎机[/url]
2009-11-30 09:34
流星雨
Rank: 16Rank: 16Rank: 16Rank: 16
来 自:JAVA风暴
等 级:版主
威 望:43
帖 子:1854
专家分:1868
注 册:2004-5-30
收藏
得分:0 
以下是引用流星雨在2009-11-29 20:58:05的发言:

与运算就是见0为0 ,| 符号是或运算,或运算是见1为1,
程序中0xFFFF明显是10进指,你先转成2进制,F明显是1111,16转2是最好转的,分别1位16进制转4位2进制,
位移也是一样,你先转成2进制,再移动。前后补0。
举个 ...
昨天还有点晕呼,打错了,是16进制。

感谢你们带我找到星空下美丽神话,无论经历多少苦痛也不放弃的梦;插上希望翅膀乘风我和你们飞翔,飞过海天尽头携手把梦想实现.....
2009-11-30 10:11
快速回复:位移运算问题
数据加载中...
 
   



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

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