Android 升級 ADT 之後報錯之一 case語句 .

來源:互聯網
上載者:User

標籤:android   des   style   blog   class   code   

轉:http://blog.csdn.net/wchinaw/article/details/7325641

下面文章大意是指:在一般的Android項目中,R類的常量都是用final定義的,但ADT 14之後,如果在library 項目中,它會沒有final關鍵字,

估計在新ADT中,資源檔會變成一個library...,

 

在switch語句的case中,如果使用 R.id.xxx 則會提示有問題,不允許非常量在case語句中。

Google提供的一個方法就是把它轉化為if-else語句,即在switch語句處 Ctrl+1 然後可以替換成if-else.語句。 

Non-constant Fields in Case Labels
In a regular Android project, constants in the resource R class are declared like this: publicstaticfinalintmain=0x7f030004;   However, as of ADT 14, in a library project, they will be declared like this: public static int main=0x7f030004;   In other words, the constants are not final in a library project. The reason for this is simple: When multiple library projects are combined, the actual values of the fields (which must be unique) could collide. Before ADT 14, all fields were final, so as a result, all libraries had to have all their resources and associated Java code recompiled along with the main project whenever they were used. This was bad for performance, since it made builds very slow. It also prevented distributing library projects that didn‘t include the source code, limiting the usage scope of library projects.   The reason the fields are no longer final is that it means that the library jars can be compiled once and reused directly in other projects. As well as allowing distributing binary version of library projects (coming in r15), this makes for much faster builds.

However, it has one impact on the source code of the library. Code of the following form will no longer compile:     int id = view.getId(); switch (id) {    case R.id.button1:         action1();         break;     case R.id.button2:         action2();         break;     case R.id.button3:         action3();         break; }     That‘s because the switch statement requires all the case labels, such as R.id.button1, to be constant at compile time (such that the values can be directly copied into the .class files).   The solution for this is simple: Convert the switch statement into an if-else statement. Fortunately, this is very easy in Eclipse. Just place the caret on the switch keyword, and press Ctrl-1 (or Cmd-1 on Mac): In the above scenario, it will turn the switch statement into this:   int id = view.getId(); if (id == R.id.button1) {     action1(); } else if (id == R.id.button2) {     action2(); } else if (id == R.id.button3) {     action3(); }     This is typically in UI code and the performance impact is negligible.   We have a detector which finds these errors (non-constant case labels referencing an R field) and provides a brief explanation of the problem (and points to this page for more information.) More information about the automatic detection.   P.S. If your switch statement looks like this:
switch (view.getId()) {   then you end up with an inefficient if/else chain where each if check repeats the view.getId() call. Just extract this expression first (using the "Extract Local Variable" refactoring keystroke), then convert the switch statement.   http://tools.android.com/tips/non-constant-fields
相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.