簡體   English   中英

為什么我的應用程序暫停線程,我該如何解決這個問題?

[英]Why is my app suspending threads and how can I fix this?

這是我的代碼:

public class CustomSwipeAdaptor extends PagerAdapter {

    private int[] image_resources={R.drawable.aa,R.drawable.bb,R.drawable.cc};
    private Context ctx;
    private LayoutInflater layoutInflater;

    public CustomSwipeAdaptor(Context ctx)
    {
        this.ctx=ctx;
    }

    @Override
    public int getCount() {
        return image_resources.length;
    }

    @Override
    public boolean isViewFromObject(View view, Object object) {
        return (view==(LinearLayout)object);
    }

    @Override
    public Object instantiateItem(ViewGroup container, int position) {
        layoutInflater=(LayoutInflater)ctx.getSystemService(Context.LAYOUT_INFLATER_SERVICE );
        View item_view=layoutInflater.inflate(R.layout.swipe_layout,container,false);
        ImageView imageView=(ImageView)item_view.findViewById(R.id.image_view);
        imageView.setImageResource(image_resources[position]);
        container.addView(item_view);
        return item_view;
    }

    @Override
    public void destroyItem(ViewGroup container, int position, Object object) {
        container.removeView((LinearLayout)object);
    }
}


public class Chapter1 extends AppCompatActivity{

    ViewPager viewPager;
    CustomSwipeAdaptor adaptor;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_chapter1);
        viewPager=(ViewPager)findViewById(R.id.view_pager);
        adaptor=new CustomSwipeAdaptor(this);
        viewPager.setAdapter(adaptor);
    }


}

這是我的logcat:

06-12 18:45:05.631 341-349/com.example.kips.itapps W/art: Suspending all threads took: 7.170ms 
06-12 18:45:27.677 341-349/com.example.kips.itapps W/art: Suspending all threads took: 6.168ms 
06-12 18:47:31.577 341-349/com.example.kips.itapps W/art: Suspending all threads took: 7.052ms 
06-12 18:48:36.275 341-349/com.example.kips.itapps W/art: Suspending all threads took: 5.650ms 
06-12 18:56:21.208 341-349/com.example.kips.itapps W/art: Suspending all threads took: 8.523ms

這在很大程度上是無害的。 這里開始

Java代碼堆是一個共享資源。 對於ART中的GC暫停,必須暫停線程,以便它們不會更改堆並破壞GC不變量。 要掛起線程,GC會修改線程局部變量,然后線程會觀察到此更改並放棄mutator鎖定,然后GC將獨占地保持鎖定並運行。 當線程被掛起而其他線程放棄它們的mutator鎖的份額時,它對jank的重要性是線程及時響應。 5ms幾乎是16ms幀的1/3,因此當線程懸掛緩慢時,ART會發出警告。 正如+ Aladin Q所說,這可能會帶來很多負擔。 如果它經常發生或沒有負載,它可能是一個可能導致jank的bug的證據。

除非你有嚴重的問題阻止你的應用程序實現其目標,否則它是良性的,以及其他幾個類似的日志輸出

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM