6

我在做什么::

  1. 我正在尝试为我的简单项目运行黄油刀库
  2. 我已按照文档中的所有步骤进行操作,但仍然出现日志错误
  3. 我该如何解决这个问题,我是否缺少任何步骤
  4. 我还在 libs 文件夹中添加了 jar

MainActivity.java

package com.example.butterknife;

import android.app.Activity;
import android.os.Bundle;
import android.widget.TextView;
import butterknife.ButterKnife;
import butterknife.InjectView;

public class MainActivity extends Activity {

    @InjectView(R.id.txtID) TextView title;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        ButterKnife.inject(this);
        title.setText("Hello Everyone !!");

    }
}

日志::

04-15 11:50:57.845: E/AndroidRuntime(913): FATAL EXCEPTION: main
04-15 11:50:57.845: E/AndroidRuntime(913): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.butterknife/com.example.butterknife.MainActivity}: java.lang.NullPointerException
04-15 11:50:57.845: E/AndroidRuntime(913):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1955)
04-15 11:50:57.845: E/AndroidRuntime(913):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1980)
04-15 11:50:57.845: E/AndroidRuntime(913):  at android.app.ActivityThread.access$600(ActivityThread.java:122)
04-15 11:50:57.845: E/AndroidRuntime(913):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1146)
04-15 11:50:57.845: E/AndroidRuntime(913):  at android.os.Handler.dispatchMessage(Handler.java:99)
04-15 11:50:57.845: E/AndroidRuntime(913):  at android.os.Looper.loop(Looper.java:137)
04-15 11:50:57.845: E/AndroidRuntime(913):  at android.app.ActivityThread.main(ActivityThread.java:4340)
04-15 11:50:57.845: E/AndroidRuntime(913):  at java.lang.reflect.Method.invokeNative(Native Method)
04-15 11:50:57.845: E/AndroidRuntime(913):  at java.lang.reflect.Method.invoke(Method.java:511)
04-15 11:50:57.845: E/AndroidRuntime(913):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784)
04-15 11:50:57.845: E/AndroidRuntime(913):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551)
04-15 11:50:57.845: E/AndroidRuntime(913):  at dalvik.system.NativeStart.main(Native Method)
04-15 11:50:57.845: E/AndroidRuntime(913): Caused by: java.lang.NullPointerException
04-15 11:50:57.845: E/AndroidRuntime(913):  at com.example.butterknife.MainActivity.onCreate(MainActivity.java:19)
04-15 11:50:57.845: E/AndroidRuntime(913):  at android.app.Activity.performCreate(Activity.java:4465)
04-15 11:50:57.845: E/AndroidRuntime(913):  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1049)
04-15 11:50:57.845: E/AndroidRuntime(913):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1919)
04-15 11:50:57.845: E/AndroidRuntime(913):  ... 11 more
04-15 11:51:06.722: I/Process(913): Sending signal. PID: 913 SIG: 9
4

3 回答 3

13

按照以下步骤[进入 Eclipse IDE]:

1)在包资源管理器中右键单击您的项目。到Java Compiler-->Annotation Processing并检查Enable project specific settings.

2) 展开Annotation Processing部分并选择Factory Path。检查Enable project specific settings然后单击Add JARs导航到项目的 libs/ 文件夹并选择ButterKnifejar。

3)点击Ok保存新设置。Eclipse将要求您重建您应该单击的项目Yes

注意:确保该.apt_generated/文件夹位于您的项目根目录中。它应该包含像YOURACTIVITY$$ViewInjector.java. 如果这些文件不存在,则通过选定的 Project → Clean 触发干净的构建。不应将此文件夹和文件签入修订控制。

参考->为 ButterKnife 注释设置手动配置

于 2014-04-15T06:40:17.680 回答
3

IntelliJ IDEA — 如果您的项目使用外部配置(如 Maven pom.xml),那么注释处理应该可以正常工作。

跟着这些步骤 :

  1. 打开IDEA的首选项:File-> Other Settings->Default Settings
  2. 导航到Compiler->Annotation Processors然后检查Enable annotation processing

参考 -> 为 ButterKnife 注释设置手动配置

2015 年 6 月 30 日更新

Intellij对于IDEA 14.0 ,请按照以下步骤操作:

  1. 打开 IDEA 的首选项:File->Settings 或点击ctl + alt + s

  2. 导航到Build, Execution and deployment-> Compiler->Annotation Processors并选择您的项目然后检查Enable annotation processing

于 2014-11-04T17:14:28.910 回答
0

@Bind 替换了@InjectView 和@InjectViews。ButterKnife.bind 和 ButterKnife.unbind 分别替换了 ButterKnife.inject 和 ButterKnife.reset。

看看这个:@InjectView 替换...

于 2015-10-05T07:08:51.530 回答