不兼容的操作数类型 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>();
integer
和Integer
有区别。
尝试使用这个,希望对你有所帮助。
'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 的排序方式甚至可能不同。
但这是另一个问题... :)
我正在尝试比较微调器中的整数类型列表和位置。整数列表包含来自数据库的 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>();
integer
和Integer
有区别。
尝试使用这个,希望对你有所帮助。
'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 的排序方式甚至可能不同。
但这是另一个问题... :)