gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-11-30 01:56:03 24 4
gpt4 key购买 nike

我正在尝试比较微调器中的整数类型列表和位置。整数列表包含来自数据库的 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 文件中遇到一个错误,因为 不兼容的操作数类型 r.integer 和 int。这是在行 if(idlist.get(position)==position) ---- 它在项目选择监听器上的微调器中设置,现在通过将整数更改为整数来解决。但该声明在某种程度上是无效的。它不能比较 Integer 和 int。有什么纠正建议吗?

最佳答案

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

由于类“Integer”的目的是在需要时将整数转换为对象,因此它也不兼容。

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

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

“onItemSelected()”方法中的“位置”值将为您提供与所选 ListView 行相对应的列表“l”的索引。

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

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

关于java - 不兼容的操作数类型 r.integer 和 int,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32196289/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com