Android studio常量表達式的錯誤

  • 1

點擊打開鏈接

 今天我是在合併幾個工程的時候,出現這個問題:常量表達式的錯誤


這個錯誤是switch case的問題,提示換成if else 
在AS中我們使用Alt+Enter(opt+Enter for Mac)快捷鍵直接將switch轉換爲if else,如下圖所示:

這裏寫圖片描述

在Tools Android的網站上有詳細的說明,主要是避免多個庫之間出現資源衝突

Non-constant Fields in Case Labels

In a regular Android project, constants in the resource R class are declared like this:

public static final int main=0x7f030004;
  • 1

However, as of ADT 14, in a library project, they will be declared like this:

public static int main=0x7f030004;
  • 1

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;
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12

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):

下圖爲Eclipse的快捷鍵方法

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();
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8

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()) {
  • 1

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.

原文:Non-constant Fields in Case Labels


有興趣的童鞋可以關注我的Blog,我的專欄會持續更新Android Studio 教程,以及2015 I/O大會上的NDK的配置和編譯,我也全部會分享給大家。 
並且我收到了CSND 的講師邀請,後期我會把這些Android Studio的使用教程錄製成視頻發佈在CSDN學院。


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章