1.錯誤1: android mk文件沒有定義
$ ndk-build
Android NDK: Your APP_BUILD_SCRIPT points to an unknown file: /cygdrive/e/heima5
/day2/code/ndkhelloworld/jni/Android.mk
/cygdrive/d/TDDownload/android-ndk-r6-windows/android-ndk-r6/build/core/add-appl
ication.mk:116: *** Android NDK: Aborting... . Stop.java
錯誤2: c代碼編譯不經過
$ ndk-build
Compile thumb : hello <= Hello.c
E:/heima5/day2/code/ndkhelloworld/jni/Hello.c: In function 'Java_cn_itcast_ndk1_
DemoActivity_helloFromJNI':
E:/heima5/day2/code/ndkhelloworld/jni/Hello.c:8: error: 'ctr' undeclared (first
use in this function)
E:/heima5/day2/code/ndkhelloworld/jni/Hello.c:8: error: (Each undeclared identif
ier is reported only once
E:/heima5/day2/code/ndkhelloworld/jni/Hello.c:8: error: for each function it app
ears in.)
E:/heima5/day2/code/ndkhelloworld/jni/Hello.c:8: error: expected ';' before 'c'
make: *** [/cygdrive/e/heima5/day2/code/ndkhelloworld/obj/local/armeabi/objs/hel
lo/Hello.o] Error 1android
錯誤3:方法的簽名不對應
java.lang.reflect.Method.invokeNative
java.lang.UnsatisfiedLinkErrorwindows
錯誤5:
02-11 03:24:53.925: E/AndroidRuntime(5763): Caused by: java.lang.UnsatisfiedLinkError: Library Hello not found
靜態代碼塊裏面加載的庫文件不正確數組
6.C庫中邏輯錯誤:
02-11 03:28:59.074: INFO/ActivityManager(59): Displayed activity cn.itcast.ndk1/.DemoActivity: 1010 ms (total 246132 ms)
02-11 03:29:00.844: INFO/DEBUG(31): *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** ***
02-11 03:29:00.844: INFO/DEBUG(31): Build fingerprint: 'generic/sdk/generic/:2.2/FRF91/43546:eng/test-keys'
02-11 03:29:00.854: INFO/DEBUG(31): pid: 6262, tid: 6262 >>> gefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefgefge <<<
02-11 03:29:00.854: INFO/DEBUG(31): signal 11 (SIGSEGV), fault addr bee30000
02-11 03:29:00.854: INFO/DEBUG(31): r0 bee2f7c0 r1 bee2f7c4 r2 bee2f7c7 r3 00000839
02-11 03:29:00.854: INFO/DEBUG(31): r4 00000067 r5 00000004 r6 4185153f r7 4186bd14
02-11 03:29:00.854: INFO/DEBUG(31): r8 bee2f7d0 r9 4186bd0c 10 4186bcf4 fp 00000000
02-11 03:29:00.854: INFO/DEBUG(31): ip 80901428 sp bee2f7b8 lr 8090033b pc afd1cb6c cpsr 20000030
02-11 03:29:01.206: INFO/DEBUG(31): #00 pc 0001cb6c /system/lib/libc.so
02-11 03:29:01.214: INFO/DEBUG(31): #01 pc 00000338 /data/data/cn.itcast.ndk1/lib/libhello.so
02-11 03:29:01.214: INFO/DEBUG(31): code around pc:
02-11 03:29:01.224: INFO/DEBUG(31): afd1cb4c b005d1e8 bdf01c28 00023828 000000f0
02-11 03:29:01.224: INFO/DEBUG(31): afd1cb5c 1c02b510 3201e000 2b007813 5cccd1fb
02-11 03:29:01.224: INFO/DEBUG(31): afd1cb6c 330154d4 d1fa2c00 46c0bd10 428b7803
02-11 03:29:01.234: INFO/DEBUG(31): afd1cb7c 2b00d004 3001d001 2000e7f8 46c04770
02-11 03:29:01.234: INFO/DEBUG(31): afd1cb8c 2300b510 3301e004 d1012a00 e0042000
02-11 03:29:01.234: INFO/DEBUG(31): code around lr:
02-11 03:29:01.244: INFO/DEBUG(31): 80900318 4b0db510 a901b082 681b447b 46681c04
02-11 03:29:01.244: INFO/DEBUG(31): 80900328 23659300 2366700b 2367704b f7ff708b
02-11 03:29:01.244: INFO/DEBUG(31): 80900338 6822efea 23a74905 4479009b 1c2058d3
02-11 03:29:01.254: INFO/DEBUG(31): 80900348 b0024798 46c0bd10 00000034 00000016
02-11 03:29:01.265: INFO/DEBUG(31): 80900358 64636261 6c6c6568 7266206f 6a206d6f
02-11 03:29:01.265: INFO/DEBUG(31): stack:
02-11 03:29:01.274: INFO/DEBUG(31): bee2f778 00000000
02-11 03:29:01.284: INFO/DEBUG(31): bee2f77c afd103f0 /system/lib/libc.so
02-11 03:29:01.284: INFO/DEBUG(31): bee2f780 afd41724 /system/lib/libc.so
02-11 03:29:01.305: INFO/DEBUG(31): bee2f784 000000dc
02-11 03:29:01.305: INFO/DEBUG(31): bee2f788 000013fc
02-11 03:29:01.305: INFO/DEBUG(31): bee2f78c 000001b8
02-11 03:29:01.305: INFO/DEBUG(31): bee2f790 80813b00 /system/lib/libdvm.so
02-11 03:29:01.305: INFO/DEBUG(31): bee2f794 0000ccb0 [heap]
02-11 03:29:01.305: INFO/DEBUG(31): bee2f798 4186bcf4
02-11 03:29:01.305: INFO/DEBUG(31): bee2f79c afd0be39 /system/lib/libc.so
02-11 03:29:01.314: INFO/DEBUG(31): bee2f7a0 00000000
02-11 03:29:01.314: INFO/DEBUG(31): bee2f7a4 b0004998 /system/bin/linker
02-11 03:29:01.314: INFO/DEBUG(31): bee2f7a8 b0014df4
02-11 03:29:01.314: INFO/DEBUG(31): bee2f7ac 80900319 /data/data/cn.itcast.ndk1/lib/libhello.so
02-11 03:29:01.314: INFO/DEBUG(31): bee2f7b0 df002777
02-11 03:29:01.314: INFO/DEBUG(31): bee2f7b4 e3a070ad
02-11 03:29:01.314: INFO/DEBUG(31): #00 bee2f7b8 0000aa50 [heap]
02-11 03:29:01.314: INFO/DEBUG(31): bee2f7bc 8090033b /data/data/cn.itcast.ndk1/lib/libhello.so
02-11 03:29:01.334: INFO/DEBUG(31): #01 bee2f7c0 64636261
02-11 03:29:01.334: INFO/DEBUG(31): bee2f7c4 65676665
02-11 03:29:01.334: INFO/DEBUG(31): bee2f7c8 66656766
02-11 03:29:01.334: INFO/DEBUG(31): bee2f7cc 67666567
02-11 03:29:01.334: INFO/DEBUG(31): bee2f7d0 65676665
02-11 03:29:01.334: INFO/DEBUG(31): bee2f7d4 66656766
02-11 03:29:01.334: INFO/DEBUG(31): bee2f7d8 67666567
02-11 03:29:01.334: INFO/DEBUG(31): bee2f7dc 65676665
02-11 03:29:01.334: INFO/DEBUG(31): bee2f7e0 66656766
02-11 03:29:01.334: INFO/DEBUG(31): bee2f7e4 67666567
02-11 03:29:01.334: INFO/DEBUG(31): bee2f7e8 65676665
02-11 03:29:01.334: INFO/DEBUG(31): bee2f7ec 66656766
02-11 03:29:01.334: INFO/DEBUG(31): bee2f7f0 67666567
02-11 03:29:01.334: INFO/DEBUG(31): bee2f7f4 65676665
02-11 03:29:01.334: INFO/DEBUG(31): bee2f7f8 66656766
02-11 03:29:01.334: INFO/DEBUG(31): bee2f7fc 67666567
02-11 03:29:01.334: INFO/DEBUG(31): bee2f800 65676665
02-11 03:29:01.334: INFO/DEBUG(31): bee2f804 66656766 app
說明c語言代碼的庫掛掉了.ide
7.須要重啓模擬器:
02-11 04:00:33.934: D/dalvikvm(10670): No JNI_OnLoad found in /data/data/cn.itcast.ndk2/lib/libhello.so 0x44f3e910, skipping initui
8.c語言中的數組結束是經過\0來標記的故:this
char* arr[6] = {'h','e','l','l','o','\0'};//char* arr[5] = {'h','e','l','l','o'}這個會出問題code
而:char* arr = "hello";則沒有問題,且和上一行效果同樣。ip
9. 使用javah生成.h文件時,
若是在D:\Android\project\ndk\bin\classes中,執行javah com.heima.ndk.ndkActivity沒法訪問,找不到類文件的話
那就在D:\Android\project\ndk\src中,執行javah com.heima.ndk.ndkActivity,或許能成功