类定义中的方法和操作

时间:2012-11-04 06:13:26

标签: android arrays class methods

随着警告我对android编程相当新 我在沿着这些行的字符串数组声明时遇到了一些麻烦

String[] title = {
"Abundance",
"Anxiety",
"Breakups",
"Bruxism"};

String[] name = {
"test1",
"test2",
"test3",
"test4"};

当我做出这个改变时出现了问题

String[] title = {
"Abundance",
"Anxiety",
"Breakups",
"Bruxism"};

String urlbase = "http://www.somewhere.com/data/";
String imgSel = "/logo.png";
String[] mStrings = new String[title.length];

for(int i=0;i<title.length;i++) {
    mStrings[i] = urlbase + title[i].toLowerCase() + imgSel;
    System.out.println(mStrings[i]);
}

然后在System.out行上我看到了这个错误

Syntax error on token ";", { expected after this token

让我和其他人混淆了很长时间,直到我找到了一些我没有方法的东西,所有先前的陈述都是在班级宣言中作出的。

***在这里学到了一些东西

我在另一篇文章中看到了这个并尝试了他们的解决方案,即添加此

public static void main(String[] args) {


}

围绕我的'行动',这看起来是正确的事情并且有意义,所以我尝试了。 当我这样做时,日食吹了一个螺丝,没有给我一些非常奇怪的东西 我甚至无法复制它,但它出现在控制台窗口中

<terminated> MainActivity (1) [Java Application] /System/Library/Frameworks/JavaVM.framework/Version/1.4/Home/bin/java (Nov 3, 2012 9:47:42 PM)

不好的部分是,即使我擦除代码并清理项目,同样的错误一直发生,所以代码是有效的,我尝试这个更改看到它停止工作并删除代码sremains破碎

问题是两个部分我如何解决这个问题以及我需要采用的确切语法是什么,以便我可以在方法中进行操作

这是我的原始代码应该可以工作,但它没有上面提到的for循环被注释掉这实际上工作不是因为我想要它这是我的改变但现在它甚至不会运行由于我的最后一次尝试修复

import android.app.Activity;
import android.os.Bundle;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.ListView;

public class MainActivity extends Activity {

ListView list;
LazyAdapter adapter;

@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main);

    list=(ListView)findViewById(R.id.list);
    adapter=new LazyAdapter(this, mStrings);
    list.setAdapter(adapter);

    Button b=(Button)findViewById(R.id.button1);
    b.setOnClickListener(listener);
}

@Override
public void onDestroy()
{
    list.setAdapter(null);
    super.onDestroy();
}

public OnClickListener listener=new OnClickListener(){

    public void onClick(View arg0) {
        adapter.imageLoader.clearCache();
        adapter.notifyDataSetChanged();
    }
};    

String[] title = {
        "Abundance",
        "Anxiety",
        "Breakups",
        "Bruxism",
        "Decisions",
        "Zen"

};

 //I put my fix for the method issue here and eclipse blew up
 //I also uncommented the appropriate lines and commented out the mStrings declaration and
 //assignment



  //   String[] mStrings= new String[title.length];

 //   String urlbase = "http://somewhere.com/data/";
 //   String imgSel = "/logo.png";
 //   for(int i=0;i<title.length;i++){
 //     mStrings[i] =  urlbase + title[9].replaceAll("[^a-zA-Z]", "").toLowerCase() + imgSel;
 //   }

    //String[] mStrings = new String[title.length];

    private String[] mStrings={
        "http://somewhere.com/data/abundance/logo.png",
        "http://somewhere.com/data/anxiety/logo.png",
        "http://somewhere.com/data/breakups/logo.png",
        "http://somewhere.com/data/bruxism/logo.png",
        "http://somewhere.com/data/decisions/logo.png",
        "http://somewhere.com/data/zen/logo.png"
    };   
}

1 个答案:

答案 0 :(得分:1)

public static void main(String[] args)

以上属于基本Java程序,不适合Android。它处理自己的活动和其他程序入口点。

几乎所有代码都需要在方法中,尤其是ifwhilefor等语句。我们可以将此代码放在onCreate中,因为它将首先执行。

这是基本的想法:

public class MainActivity extends Activity {
    // List / Adapter variables here

    private String[] title = {
        "Abundance",
        "Anxiety",
        "Breakups",
        "Bruxism",
        "Decisions",
        "Zen"
    };

    private String[] mStrings = new String[title.length];

    // OnClickListener here

    @Override
    public void onCreate(Bundle savedInstanceState) {
        // super.onCreate and setContentView

        // Here is your for loop, untouched!
        String urlbase = "http://somewhere.com/data/";
        String imgSel = "/logo.png";
        for(int i=0;i<title.length;i++){
            mStrings[i] =  urlbase + title[9].replaceAll("[^a-zA-Z]", "").toLowerCase() + imgSel;
        }

        // More onCreate
    }

    // onDestroy method here
}