如何在Android中的特定时间段后执行任务?

时间:2016-05-25 11:13:42

标签: java android android-fragments system-clock

我创建了一个包含大量片段的应用程序。在我的最后一个片段中,我尝试在10秒后在LogCat上打印一些内容。但它对我不起作用。

这是我的Fragment班级

public class StepTwentyTwoFragment extends Fragment {

    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
        View v = inflater.inflate(R.layout.step22_fragment, container, false);

        testMethod();
        return v;
    }

    public static StepTwentyTwoFragment newInstance() {

        StepTwentyTwoFragment f = new StepTwentyTwoFragment();
        Bundle b = new Bundle();

        f.setArguments(b);

        return f;
    }


    @Override
    public void setUserVisibleHint(boolean isVisibleToUser) {
        super.setUserVisibleHint(isVisibleToUser);
        if(isVisibleToUser) {
            Activity a = getActivity();
            if(a != null) a.setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_PORTRAIT);
        }
    }

    public void testMethod(){
        SystemClock.sleep(10000);
        Log.d("PPP : ","456");
    }

}

实际上我想在最后片段启动10秒后打印这个“PPP”。但它开始在应用程序中加载一些片段进行打印。

对此有任何想法吗?

谢谢。

6 个答案:

答案 0 :(得分:4)

您不应该睡觉,也不应该在不需要时创建线程。 Android的主要线程是基于事件循环的,您可以安排事件/代码在将来的某个时间执行。

您最简单的选择是使用

@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
    View v = inflater.inflate(R.layout.step22_fragment, container, false);
    Runnable delayedTask = new Runnable() {
        @Override
        public void run() {
            Log.d("PPP : ","456");
        }
    };
    v.postDelayed(delayedTask, 10000);
    return v;
}

如果您没有View,您也可以创建自己的处理程序。

private static final Handler mainThreadHandler = new Handler(Looper.getMainLooper());
public void testMethod(){
    Runnable delayedTask = new Runnable() {
        @Override
        public void run() {
            Log.d("PPP : ","456");
        }
    };
    mainThreadHandler.postDelayed(delayedTask, 10000);
}

答案 1 :(得分:3)

使用Handler.postDelayed方法实现此目的。

final Handler handler = new Handler();
handler.postDelayed(new Runnable() {
  @Override
  public void run() {
    //Do something after 10000ms

  }
}, 10000);

将您要执行的代码放在run()方法中。阅读here

中有关处理程序的更多信息

答案 2 :(得分:2)

可能你正在睡觉ui线程,这就是睡眠结束后你的日志出现的原因。

使用Timer和TimerTask。 TimerTask在与ui线程不同的线程上运行。

Timer timer          = new Timer();
TimerTask timer_task = new TimerTask() {
    @Override
    public void run() {
        Log.d("PPP : ","456");
    }
};
timer.schedule(timer_task, 10000);

答案 3 :(得分:1)

试试这个

public void executePeriodicTask() {
final Handler handler = new Handler();
Timer timer = new Timer();
TimerTask doAsynchronousTask = new TimerTask() {       
    @Override
    public void run() {
        handler.post(new Runnable() {
            public void run() {       
                try {

                  //Write your code here , which you want to execute periodically

                } catch (Exception e) {
                    // TODO Auto-generated catch block
                }
            }
        });
    }
};
timer.schedule(doAsynchronousTask, 0, 50000); //execute in every 50000 ms

}

答案 4 :(得分:1)

您可以为此简单地创建一个线程或处理程序。

如果你想使用Thread - >

new Thread(new Runnable() {
    @Override
    public void run() {
        try {
            Thread.sleep(10000);
        } catch (InterruptedException e) {}
        ((Activity)getActivity()).runOnUiThread(new Runnable() {
            @Override
            public void run() {
                Log.d("PPP : ","456");
                // Do other Stuff
            }
        });
    }
}).start();

答案 5 :(得分:1)

您可以Handler使用PostDelayedRunnable传递给它

 new Handler().postDelayed(new Runnable(){
        @Override
        public void run() {

             Log.d("PPP : ","456");
        }
    }, 10000);