在run方法中使用static成员变量问题

         最近在写一个蓝牙的测试程序,里面定义了一个CommunicateThread 连接线程类继承于Thread;在该类中定义了一个run方法。run方法代码如下:

public void run() {
        byte[] buffer;//用于读数据的缓存区
        int size;//长度
        String data;//数据
        while (isRunning && isOverCount) {
            try {

                //System.out.println("isOverTime:"+" "+isOverTime);
                if (in != null) {
                    size = in.available();
                    //有数据就去拿出来
                    if (size > 0) {
                        buffer = new byte[size];
                        in.read(buffer);
                        data = new String(buffer);
                        //能过Handler把数据传出去
                        Message msg = mHandler.obtainMessage();
                        msg.what = BluetoothConstant.WHAT_RECEIVED_DATA;
                        msg.obj = data;
                        mHandler.sendMessage(msg);
                    }
                }
            } catch (IOException e) {
                //e.printStackTrace();
                isRunning = false;
                System.out.println("Error-CommunicateThread:run()");
            }
        }
    }

        

        本人的目的就是想通过其他类设置一个static成员变量来控制while()里面的循环标志位。无论我用什么方法都不能控制这个标志位;即在Communication类中的这个标志位与我一开始定义的那个标志有差别。这就是我要写这篇博客的原因了。

         通常,static成员变量在创建时只分配一次内存,它作用于全局范围,由类名直接调用。当我把static标志位在一个Fragment定义后,然后在while()里面调用Fragment.标志位;发现结果与我想象中的不一样。但在fragment里面该值已经变化了;也就是说run方法中这个值与Fragment中的值不同时变化。这就与我们所理解的static只分配一次内存的想法背向而驰。这期间我也在网上查找了一些资料,然而并没有查到什么结果。我们只能猜测在run方法中,该标志位被重新拷贝了一份。

        当然,出现这样的问题也是因为我在写程序想偷懒,或许我的想法比较奇特。正常的写法应该是在Communication类中定义一个Close()方法,在close()方法中令isRunning设置为false。然后在实例化Communication类的类中再调用Close()方法;这样就能控制标志位了。

         如果有知道导致该问题原因的大牛们,请留言告知,非常感谢了!

         另附上正常写法:

public void close() {
        if (mCommunicateThread != null) {
            mCommunicateThread.close();
        }
        try {
            if (mBluetoothSocket != null) {
                mBluetoothSocket.close();
            }
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
        这个close()方法是在Communication类实例化类中的方法。通过调用该方法就能控制了!

         

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值