Android UI耗时问题处理

问题描述:UI中btn的一个响应有耗时操作,另起线程来执行,UI依然有卡顿

代码描述如下:
public class MyActivity extends Activity {

Button btnSend;
protected void onCreate(Bundle savedInstanceState) {
    .....
    btnSend=(Button) findViewById(R.id.btn_send);
    btnSend.setOnclickListener(mListener);
}

OnClickListener mListener=new new View.OnClickListener() {

        @Override
        public void onClick(View v) {
         new Thread(sendable).start();  
        }
}

Runnable sendable = new Runnable() {
    @Override
    public void run() {
        String data="data";
        sendRemote(data);
    }
}

/***因为具体的发送方法在服务里,所以此处传递消息给
****服务处理,发送函数是一个耗时操作,发送之后等待回复或等至超时***/
private void sendRemote(String strData){    
    Intent iSend=new Intent("send");    
    iSend.putExtra("data", msg);
    startService(iSend);
}

}
在这种情况下会有一个明显的卡顿,我的疑问是:
1、另起线程并没有完全将耗时程序从UI中剥离开来吗?
2、即使未剥离开,UI线程启动服务的操作也要一直等到 服务按要求启动并执行相应的步骤(此处为发送信息)之后才算完成吗?要不然也不应该卡顿啊

求高手指点,谢谢

问题比较明显,肯定不是出在你贴出来的代码中,请检查你启动的service的oncreate函数,看里面是不是做了耗时操作,
service也是运行于UI线程,请在service的oncreate中创建thread做耗时操作

自己先补充一下,对于第一个问题,有测试过,若是不以启动服务的方式来执行发送操作,没有卡顿。

1 启动一个线程,就为了启动服务,个人认为这个完全没有必要。
2 卡,可能与服务中的实现有关,与 MyActivity 无关。

public int onStartCommand(Intent intent, int flags, int startId) {
    Log.v(strTag, "onStart");       
    if(intent.getAction().equals("connect")){
        Log.v(strTag, "df_connect");        
    .....
    }else if (intent.getAction().equals("send")) {
     final String bContent=intent.getStringExtra("data");
        Log.v(strTag, "接收到来自Activity的发送数据:"+bContent);          
        doSendData(bContent);
    }else if (intent.getAction().equals("close")) {
        isRun=false;
        stopService(intent);
        Log.v(strTag, "df_MainService has been stoped");
    }
    return super.onStartCommand(intent, flags, startId);
}

关键代码没有贴出来,先要确定是什么业务耗时,耗时业务不要放在ui线程里面处理,另开线程,不是另开服务。

在此处结个贴:
感谢大家的热心回答,盒子童鞋的回答是正解,问题的关键在于Service也运行于UI线程,所以,虽然在UI响应里另起了线程来处理耗时,但最后,新线程又
把问题抛回给了UI线程,所以导致卡顿,后来的处理是,在onStartCommond()方法里另起线程处理耗时,问题解决;

我不会告诉你,可以用postDelay