Log.d(TAG, "Build.VERSION_CODES.ICE_CREAM_SANDWICH: " + Build.VERSION_CODES.ICE_CREAM_SANDWICH);
Run Code Online (Sandbox Code Playgroud)
我写这样的代码,我使用sdk4.0来编译这个android程序,所以它不会导致编译错误.当我在运行Android 2.3.4的手机中运行此程序时,它运行良好.
为什么?我很困惑,版本2.3.4(api级别10)有Build.VERSION_CODES.ICE_CREAM_SANDWICH属性?而当我使用sdk2.3.4时会导致编译错误.
更多
我测试下面这些代码,
private ScaleGestureDetector mScaleGestureDetector;
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.ECLAIR_MR1) {
mScaleGestureDetector = new ScaleGestureDetector(this, new MyOnScaleGestureListener());
}
Run Code Online (Sandbox Code Playgroud)
这段代码在android 1.6 api 4级上运行良好,但是
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.ECLAIR_MR1) {
Log.d(TAG, "getx(0): " + event.getX(0));
}
Run Code Online (Sandbox Code Playgroud)
这个程序在android 1.6 api level 4上运行失败.
他们都运行在android 2.3.4上.
为什么?(在ScaleGestureDetector类中也使用event.getX(0)(因为api级别5))
我测试了一些代码..
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
Fragment f = new Fragment();
}
Run Code Online (Sandbox Code Playgroud)
当我在Android 1.6模拟器上运行它时会抛出java.lang.VerifyError,但是在我的手机上运行android 2.3.4它会抛出java.lang.NoClassDefFoundError.
为什么??
Alb*_*bin 12
它并不像看起来那么奇怪.它与Java如何处理基元的常量值有关.在编译期间,常量的值放在字节代码中,而不是对实际常量的引用.
例如:
Log.d(TAG,"Build.VERSION_CODES.ICE_CREAM_SANDWICH:"+ Build.VERSION_CODES.ICE_CREAM_SANDWICH);
将由编译器以实际方式翻译为:
Log.d(TAG,"Build.VERSION_CODES.ICE_CREAM_SANDWICH:"+ 14);
所以删除了对实际常量(和类)的引用.
关于不为你运行的代码,它与MotionEvent.getX(int n)api级别5之前的方法不可用有关.在此之前,不支持多点触控,因此不需要任何其他方法getX().
如果您实际调用不存在的方法并不重要.在平台加载和验证类时出现错误.您最有可能在日志中获得VerifyError,因为它会发现您在验证期间尝试调用不存在的方法.
另一方面,如果您尝试使用不存在的类,则会获得ClassNotFoundException.请注意,有时,即使文档没有说明,Android中也存在类.有些类存在于Android的早期版本中,但直到稍后才公开.有些甚至走了另一条路.
所以:
尝试使用不存在的类 - ClassNotFoundException尝试使用存在的类上不存在的方法 - VerifyError
(当涉及到使用Fragments时,它们可用于具有独立Android支持库的早期版本)
| 归档时间: |
|
| 查看次数: |
2019 次 |
| 最近记录: |