我创建了一个包含大量片段的应用程序。在我的最后一个片段中,我尝试在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”。但它开始在应用程序中加载一些片段进行打印。
对此有任何想法吗?
谢谢。
答案 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
使用PostDelayed
将Runnable
传递给它
new Handler().postDelayed(new Runnable(){
@Override
public void run() {
Log.d("PPP : ","456");
}
}, 10000);