不兼容的操作数类型 r.integer 和 int

incompatible operand types r.integer and int

我正在尝试比较微调器中的整数类型列表和位置。整数列表包含来自数据库的 ID 列表,微调器包含与 ID 相关的名称列表。 ID 和名称存储在数据库中,在比较列表中的 ID 和微调器中的位置后,两个编辑文本框被设置为与名称以外的特定 ID 对应的值。 ID 设置为自动递增。 这是 MainActivity:

public class LoginActivity extends AppCompatActivity {

Button b;
EditText ed1, ed2, ed3;
Spinner sp;
String url = "https://web.facebook.com/";
String urltest = "http://www.google.com/";
WebView wb;
database db;
String details[];

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_login);
    b = (Button) findViewById(R.id.button1);
    ed1 = (EditText) findViewById(R.id.editText1);
    ed2 = (EditText) findViewById(R.id.editText2);
    ed3 = (EditText) findViewById(R.id.editText3);
    wb = (WebView) findViewById(R.id.webView1);
    sp = (Spinner) findViewById(R.id.spinner1);
    db = new database(LoginActivity.this);

    // wb.loadUrl(url);
    List<String> l = db.userlist();
    final List<Integer> idlist = db.IDList();
    ArrayAdapter<String> sa = new ArrayAdapter<String>(LoginActivity.this, android.R.layout.simple_spinner_item, l);
    sp.setAdapter(sa);

    b.setOnClickListener(new OnClickListener() {

        @Override
        public void onClick(View v) {
            user u = new user();
            String name = ed1.getText().toString();
            String uname = ed2.getText().toString();
            String pass = ed3.getText().toString();

            if (name.length() > 0 && uname.length() > 0 && pass.length() > 0) {
                u.setName(name);
                u.setUname(uname);
                u.setPass(pass);

                db.insert(u);
                ed1.setText("");
                ed2.setText("");
                ed3.setText("");

            } else {
                Toast.makeText(LoginActivity.this, "Please enter the Name, User Name and password",
                        Toast.LENGTH_SHORT).show();
            }

            Toast.makeText(LoginActivity.this, "The user name details has been saved.", Toast.LENGTH_LONG).show();
        }
    });

    sp.setOnItemSelectedListener(new AdapterView.OnItemSelectedListener() {
        @Override
        public void onItemSelected(AdapterView<?> parent, View view, int position, long id) {
            // TODO Auto-generated method stub
            if (idlist.get(position) == position) {
                details = db.details(position);
                ed2.setText(details[0]);
                ed3.setText(details[1]);
            }
        }

        @Override
        public void onNothingSelected(AdapterView<?> parent) {
            // TODO Auto-generated method stub

        }
    });

}

}

我创建了另外两个 java 文件作为创建数据库的 database.java 和 returns:

public class database extends SQLiteOpenHelper {

    public static String dbname = "Personal";
    public static int version = 1;
    public static String tblname = "Data";
    public static String id = "ID";
    public static String name = "Name";
    public static String uname = "Username";
    public static String pass = "Password";

    public database(Context context) {
        super(context, dbname, null, version);
        // TODO Auto-generated constructor stub
    }

    @Override
    public void onCreate(SQLiteDatabase db) {
        // TODO Auto-generated method stub
        String sql1 = "create table " + tblname + " (" + id + " integer primary key autoincrement, " + name + " text, "
                + uname + " text, " + pass + " text)";
        db.execSQL(sql1);
    }

    @Override
    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
        // TODO Auto-generated method stub

    }

    void insert(user u) {

        SQLiteDatabase db = getWritableDatabase();
        ContentValues values = new ContentValues();
        values.put(name, u.getName());
        values.put(uname, u.getUname());
        values.put(pass, u.getPass());

        db.insert(tblname, id, values);
    }

    public List<String> userlist() {
        List<String> list = new ArrayList<String>();
        SQLiteDatabase db = getReadableDatabase();

        Cursor cursor = db.query(tblname, new String[] { name }, null, null, null, null, null);

        while (cursor.moveToNext()) {

            String data = cursor.getString(0);
            list.add(data);
            // Log.e("1", data);
        }
        return list;
    }

    public List<integer> IDList() {
        List<integer> idlist = new ArrayList<integer>();
        SQLiteDatabase db = getReadableDatabase();
        Cursor cursor = db.query(tblname, new String[] { id }, null, null, null, null, null);

        while (cursor.moveToNext()) {
            String data = cursor.getString(0);
            idlist.add(Integer.parseInt(data), null);
        }
        return idlist;

    }

    public String[] details(int position) {
        String username = null, password=null;
        SQLiteDatabase db = getReadableDatabase();
        Cursor cursor = db.query(tblname, new String[] { id, uname, pass }, null, null, null, null, null);

        while (cursor.moveToNext()) {
            if (position == cursor.getInt(0)) {
                username = cursor.getString(1);
                password = cursor.getString(2);
            } else {
                return null;
            }
        }
        return new String[] {username, password};

    }

}

和一个 user.java 来获取和设置详细信息:

public class user {

    String id, name, uname, pass;

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public String getId() {
        return id;
    }

    public void setId(String id) {
        this.id = id;
    }

    public String getUname() {
        return uname;
    }

    public void setUname(String uname) {
        this.uname = uname;
    }

    public String getPass() {
        return pass;
    }

    public void setPass(String pass) {
        this.pass = pass;
    }


}

我在 MainActivity.java 文件中收到错误 incompatible operand types r.integer and int。这是在线 if(idlist.get(position)==position) ---- 它是在项目选择侦听器上设置的微调器中,现在通过将整数更改为整数来解决。但该声明在某种程度上是无效的。它不能比较 Integer 和 int。有什么纠正建议吗?

你必须使用:

List<Integer> list = new ArrayList<Integer>();

integerInteger有区别。

尝试使用这个,希望对你有所帮助。

'integer' 确实存在 nested class of class 'R' .因此,您的列表被解释为数据类型 R.integer 的列表,但 'R.integer' 和原始数据类型 'int' 不兼容。

由于class 'Integer'的目的是在需要的时候把整数变成对象,所以也不兼容。

编辑: 因此,您要做的第一件事是将代码中的每个 'integer' 更改为 'Integer',因为您要处理数字,而不是 android 资源。

查看发生崩溃的方法,很难说出您需要做什么才能使您的代码正常工作(不仅仅是 'not crash')。

'onItemSelected()' 方法中的 'position' 值将为您提供与所选 ListView 行对应的列表 'l' 的索引。

现在您似乎在检查一个用户名的列表索引是否等于您的SQLite 数据库中的userid。由于我不知道您的数据模型,因此我无法判断这样做是否有意义。我只知道您确实通过单独的查询将 'idlist' 和 'l' 填充到数据库中,而您没有包含 'ORDER BY',因此名称和 ID 的排序方式甚至可能不同。

但这是另一个问题... :)