3

我创建了一个包含很多片段的应用程序。在我的最后一个片段中,我尝试LogCat在 10 秒后打印一些东西。但这对我不起作用。

这是我的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”。但它开始打印在应用程序中加载一些片段。

对此有什么想法吗?

谢谢你。

4

6 回答 6

8

您不应该睡觉,也不应该在不需要线程时创建线程。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);
}
于 2016-05-25T11:31:49.170 回答
5

使用 Handler.postDelayed 方法来实现这一点。

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

  }
}, 10000);

将要执行的代码放在 run() 方法中。从此处阅读有关处理程序的更多信息

于 2016-05-25T11:28:47.720 回答
2

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

使用定时器和定时器任务。TimerTask 在与 ui 线程不同的线程上运行。

Timer timer          = new Timer();
TimerTask timer_task = new TimerTask() {
    @Override
    public void run() {
        Log.d("PPP : ","456");
    }
};
timer.schedule(timer_task, 10000);
于 2016-05-25T11:23:01.213 回答
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

}

于 2016-05-25T11:23:13.367 回答
1

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

如果你想使用线程 ->

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();
于 2016-05-25T11:24:18.337 回答
1

您可以使用HandlerwithPostDelayed传递Runnable给它

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

             Log.d("PPP : ","456");
        }
    }, 10000);
于 2016-05-25T11:26:53.433 回答