【问题标题】:incompatible operand types r.integer and int不兼容的操作数类型 r.integer 和 int
【发布时间】:2015-08-25 05:40:56
【问题描述】:

我正在尝试比较整数类型列表和微调器中的位置。整数列表包含来自数据库的 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,它创建数据库并返回:

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。有什么改正的建议吗?

【问题讨论】:

  • 你的代码编译了吗?通常Integer 以大写i 开头还是不是java.util.Integer
  • @Jens - 我想它正在编译并且android有一个描述int资源的'integer'类。但这只是猜测
  • 由于操作数类型不兼容而导致错误,但将整数转换为整数就可以了。谢谢。

标签: java android int


【解决方案1】:

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

由于类 'Integer' 的目的是在需要时将整数转换为对象,所以它也不兼容。

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

查看发生崩溃的方法,有点难以判断需要做什么才能使代码正常工作(不仅仅是“不崩溃”)。

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

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

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

【讨论】:

  • 是的,它也不起作用。你能提出正确的方法吗?
  • @ArpitKumar - 好的,我会想办法解决的。
【解决方案2】:

你必须使用:

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

integerInteger 之间存在差异。

试试这个,希望对你有帮助。

【讨论】:

  • 通过将所有整数转换为整数就可以了,但是为什么整数有这么多不同的类型,如 int、integer 和 Integer?
  • Integer 是一个包装类,主要用于解析,int 是代码中常用的数据类型。
  • 我不知道你打算用&lt;I&gt;做什么,但你可以看看你是否真的需要它。
  • @Tom:我应该在哪里添加这个语句?在这种情况下,列表是从 databse.java 文件中的函数获取值。我必须编辑函数本身吗?应该是什么语法? 0X0nosugar 正确表示 Integer 和 int 无法比较。代码正在编译,但它在启动之前就崩溃了。
  • 如果您有新信息,请编辑您的问题。但请追加/添加这些信息,不要从您当前的问题中删除内容。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2011-10-13
  • 1970-01-01
  • 1970-01-01
  • 2020-05-29
  • 1970-01-01
  • 1970-01-01
  • 2012-06-03
相关资源
最近更新 更多