我有2个.java
个文件:AnswerActivity.java
public class AnswerActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_answer);
new JSONTask().execute("https://example.com/api.php");
}
}
和JSONTask.java
public class JSONTask extends AsyncTask<String, String, String> {
@Override
protected String doInBackground(String... params) {
//--- some code cut here ---//
}
@Override
protected void onPostExecute(String result) {
super.onPostExecute(result);
Intent i = new Intent(this, AnswerActivity.class);
Toast.makeText(i, result, Toast.LENGTH_LONG).show();
}
}
我的最后两行总是给我错误:
Intent i = new Intent(this, AnswerActivity.class);
Toast.makeText(i, result, Toast.LENGTH_LONG).show();
我希望将result
作为Toast显示在AnswerActivity中。但为什么我总是收到此错误消息?
Error:(68, 20) error: no suitable constructor found for Intent(JSONTask,Class<AnswerActivity>)
constructor Intent.Intent(String,Uri) is not applicable
(argument mismatch; JSONTask cannot be converted to String)
constructor Intent.Intent(Context,Class<?>) is not applicable
(argument mismatch; JSONTask cannot be converted to Context)
Error:(69, 14) error: no suitable method found for makeText(Intent,String,int)
method Toast.makeText(Context,CharSequence,int) is not applicable
(argument mismatch; Intent cannot be converted to Context)
method Toast.makeText(Context,int,int) is not applicable
(argument mismatch; Intent cannot be converted to Context)
我在这里想念的是什么?谢谢
答案 0 :(得分:5)
您需要一个上下文来显示Toast
。通常是具有上下文的Activity
或Fragment
。但由于您的AsyncTask
不是AnswerActivity
的内部类,因此您没有引用上下文。
所以你可以在构造函数中传递Activity
并使用
public class JSONTask extends AsyncTask<String, String, String> {
private Context context;
public JSONTask(Context context){
this.context = context;
}
@Override
protected void onPostExecute(String result) {
Toast.makeText(context, result, Toast.LENGTH_LONG).show();
}
}
并与
一起使用new JSONTask(this)... // and so on
这样做的一大优点是,您没有保留对Activity
的引用,只是传递Context
- 因为Activity确实扩展了上下文。
答案 1 :(得分:2)
删除它:
Intent i = new Intent(this, AnswerActivity.class);
Toast.makeText(i, result, Toast.LENGTH_LONG).show();
有了这个:
在Context
课程中传递AsyncTask
:
public class JSONTask extends AsyncTask<String, String, String> {
private Context context;
//in constructor:
public JSONTask(Context context){
this.context=context;
}
@Override
protected String doInBackground(String... params) {
//--- some code cut here ---//
}
@Override
protected void onPostExecute(String result) {
super.onPostExecute(result);
Toast.makeText(context, result, Toast.LENGTH_LONG).show();
}
}
并在Activity
:
new JSONTask(AnswerActivity.this).execute("https://example.com/api.php");
答案 2 :(得分:2)
你的JSONTask应该是
public class JSONTask extends AsyncTask<String, String, String> {
Context mContext;
public JSONTask(Context mContext) {
this.mContext = mContext;
}
@Override
protected String doInBackground(String... params) {
//--- some code cut here ---//
}
@Override
protected void onPostExecute(String result) {
super.onPostExecute(result);
Toast.makeText(mContext, result, Toast.LENGTH_LONG).show();
}
}
初始化
new JSONTask(this).execute("https://example.com/api.php");
答案 3 :(得分:0)
如果您未在其他任何地方使用JSONTask
课程,则可以在AnswerActivity
内将其定义为inner class。如果你这样做,那么这段代码应该可行,
Toast.makeText(AnswerActivity.this, result, Toast.LENGTH_LONG).show();
否则,您必须将应用程序上下文传递给JSONTask
并在Toast
中使用。
public class JSONTask extends AsyncTask<String, String, String> {
private Context appContext;
public JSONTask(Context context){
this.appContext= context;
}
@Override
protected String doInBackground(String... params) {
//--- some code cut here ---//
}
@Override
protected void onPostExecute(String result) {
super.onPostExecute(result);
Toast.makeText(appContext, result, Toast.LENGTH_LONG).show();
}
}
答案 4 :(得分:0)
更好的方法是在类
中创建一个构造函数read_file = "a.txt"
read_batch = "b.txt"
lines_batch = list()
with open(read_file) as r:
bigstat = r.read()
with open(read_batch) as b:
for batch in (line_batch.strip() for line_batch in b):
if batch in bigstat:
print(???)
然后你可以创建Toast
Context context;
public void init(Context ctx){
this.context = ctx;
}