最近在做項目的時候,碰到方法的前面和類的前面有時會出現@SupPRessLint或者@SuppressWarnings這樣的黃色警告,看起來很不舒服,于是上網搜集了一些相關資料。發現這些警告的出現其實是由于我們編寫代碼時的一些不規范的寫法導致,解決這些問題其實是能提高我們程序的安全性、可用性和性能的。接下來就讓我為大家一一說明。 1、@SuppressLint(“DrawAllocation”) 原因:我們都知道View及其子類的OnDraw(Canvas canvas)方法會實時調用來更新界面的,然而有時我們會在onDraw(Canvas canvas)方法中實例化對象(如Paint paint=new Paint()),這樣就會影響我們程序的效率。 解決辦法:將這些對象改為類的成員變量。
2、@SuppressWarnings(“rawtypes”)和@SuppressWarnings({ “unchecked”, “rawtypes” }) 不規范寫法:Class clazz = Class.forName(“android.view.Display”); 正確寫法:Class<?> clazz = Class.forName("android.view.Display");
3、@SuppressLint(“HandlerLeak”) 原因:Handler在Android中用于消息的發送與異步處理,常常在Activity中作為一個匿名內部類來定義,此時Handler會隱式地持有一個外部類對象(通常是一個Activity)的引用。當Activity已經被用戶關閉時,由于Handler持有Activity的引用造成Activity無法被GC回收,這樣容易造成內存泄露。 解決辦法:將其定義成一個靜態內部類(此時不會持有外部類對象的引用),在構造方法中傳入Activity并對Activity對象增加一個弱引用,這樣Activity被用戶關閉之后,即便異步消息還未處理完畢,Activity也能夠被GC回收,從而避免了內存泄露。
public static class MyHandler extends Handler { private WeakReference<Activity> reference public MyHandler(Activity activity) { reference = new WeakReference<Activity>(activity); } @Override public void handleMessage(Message msg) { if (reference.get() != null) { switch (msg.what) { case 0: // do something... break; default: // do something... break; } } } }另一種情況:
不規范的寫法: private Handler mHandler = new Handler() { @Override public void handleMessage(Message msg) { }; };正確的寫法: private Handler mHandler = new Handler(new Handler.Callback() { @Override public boolean handleMessage(Message msg) { return false; } });4、@SuppressLint(“SimpleDateFormat”) 不規范寫法:SimpleDateFormat format = new SimpleDateFormat(pattern); 正確寫法:SimpleDateFormat format = new SimpleDateFormat(pattern, Locale.getDefault());
5、@SuppressLint(“DefaultLocale”) 不規范寫法:String lower = string.toLowerCase(); boolean b = “String”.toUpperCase().equals(“STRING”); 正確寫法:String lower = string.toLowerCase(Locale.getDefault()); boolean b = “String”.toUpperCase().equals(“STRING”);
新聞熱點
疑難解答