2012-05-16 69 views
1

嗨,我一直在努力通過我的第一個Android應用程序,它開始變得有點慢和滯後。我之前做過iPhone應用程序,而且我知道我必須發佈一些東西。所以我想我的問題是什麼是在避免內存泄漏方面編碼android的最佳實踐。從JSON供稿中加載數據,只是簡化我的代碼,使其更有效地改善用戶體驗?Android編碼更有效率和更有效

您可以提供任何幫助,將不勝感激和熱愛機器人,但只是想確保我這樣做是正確

繼承人我的代碼示例到目前爲止

public class HomeActivity extends ListActivity { 

    private MergeAdapter adapter=null; 
    private ArrayAdapter<String> arrayAdapter=null; 
    private ArrayAdapter<String> arrayAdapter2=null; 
    private ArrayAdapter<String> arrayAdapter3=null; 
    private static final String apiKey = "46fhr636gdbc737hjd92932dd"; 
    private static final String apiUser = "android-app-v1"; 
    private static final String ChosenTeam = null; 
    private static String ChosenMethod = null; 
    public String fulldata = null; 
    public String chosenLeagueId = "40"; 
    public List<String> newsList = null; 
    public List<String> newsList2 = null; 
    public List<String> newsList3 = null; 

    public int newsAmount = 0; 


    long unixTimeStamp = System.currentTimeMillis()/1000L; 

    //add Time Stamp to URL 


    //public String chosenMethod; 


    String newsFeedRequest = "1.0/website/" + chosenLeagueId + "/news?timestamp=" + unixTimeStamp; 
    String fixturesFeedURL = "https://website.com/_services/api/" + newsFeedRequest; 
    private int container; 


    private static String buildHmacSignature(String pKey, String pStringToSign) 
    { 
     String lSignature = "None"; 
     try 
     { 
     Mac lMac = Mac.getInstance("HmacSHA256"); 
     SecretKeySpec lSecret = new SecretKeySpec(pKey.getBytes(), "HmacSHA256"); 
     lMac.init(lSecret); 

     byte[] lDigest = lMac.doFinal(pStringToSign.getBytes()); 
     BigInteger lHash = new BigInteger(1, lDigest); 
     lSignature = lHash.toString(16); 
     if ((lSignature.length() % 2) != 0) { 
      lSignature = "0" + lSignature; 
     } 
     } 
     catch (NoSuchAlgorithmException lEx) 
     { 
     throw new RuntimeException("Problems calculating HMAC", lEx); 
     } 
     catch (InvalidKeyException lEx) 
     { 
     throw new RuntimeException("Problems calculating HMAC", lEx); 
     } 

     return lSignature; 
    } 


    public void checkPreferences(){ 


     SharedPreferences preferences = getSharedPreferences("prefs", Context.MODE_PRIVATE); 
     final String ChosenMethodPref = preferences.getString("ChosenMethod", ChosenMethod); 
     Log.v("myapp", "ChosenMethod Home = " + ChosenMethodPref); 

     if (ChosenMethodPref.equals("Team")) { 
      setContentView(R.layout.homeactteam2); 
      newsAmount = 5; 

     } else { 
      setContentView(R.layout.homeact); 
      newsAmount = 10; 
     } 
} 

    public void loadData(){String myhash = buildHmacSignature(apiKey, fixturesFeedURL); 


    HttpClient client = new DefaultHttpClient(); 
    HttpPost post = new HttpPost(fixturesFeedURL); 

    List<NameValuePair> pairs = new ArrayList<NameValuePair>(); 
    pairs.add(new BasicNameValuePair("requestToken", myhash)); 
    pairs.add(new BasicNameValuePair("apiUser", apiUser)); 

    try { 
     post.setEntity (new UrlEncodedFormEntity(pairs)); 
     HttpResponse response = client.execute(post); 
     BufferedReader reader = new BufferedReader(new InputStreamReader(response.getEntity().getContent(), "UTF-8")); 
     String json = reader.readLine(); 
     fulldata = String.valueOf(json); 
     Log.v("myApp","newsdata" + fulldata); 

     newsList = new ArrayList<String>(); 
     newsList2 = new ArrayList<String>(); 
     newsList3 = new ArrayList<String>(); 

     JSONObject obj = new JSONObject(json);  
     JSONObject objData = obj.getJSONObject("data"); 
     JSONArray jArray = objData.getJSONArray("news"); 


      for(int t = 0; t < newsAmount; t++){ 
       JSONObject newsTitleDict = jArray.getJSONObject(t); 

      newsList3.add(newsTitleDict.getString("title")); 

      } 

      for(int t = 0; t < 1; t++){ 
       JSONObject newsTitleDict = jArray.getJSONObject(t); 

      newsList.add(newsTitleDict.getString("title")); 
      newsList2.add(newsTitleDict.getString("title")); 

      } 



    } catch (ClientProtocolException e) { 
     // TODO Auto-generated catch block 
     e.printStackTrace(); 
    } catch (IOException e) { 
     // TODO Auto-generated catch block 
     e.printStackTrace(); 
    } catch (JSONException e) { 
     // TODO Auto-generated catch block 
     e.printStackTrace(); 
    } 


    arrayAdapter = new ArrayAdapter<String>(this, R.layout.single_item, newsList); 
    arrayAdapter2 = new ArrayAdapter<String>(this, R.layout.single_item, newsList2); 
    arrayAdapter3 = new ArrayAdapter<String>(this, R.layout.single_item, newsList3); 

     ListView list = getListView(); 
      list.setTextFilterEnabled(true); 

      LayoutInflater inflater = (LayoutInflater) this.getSystemService(Context.LAYOUT_INFLATER_SERVICE); 
      View header = inflater.inflate(R.layout.homeheader, list, false); 
      View header2 = inflater.inflate(R.layout.homeheader2, list, false); 
      View header3 = inflater.inflate(R.layout.homeheader3, list, false); 


    //setListAdapter (arrayAdapter); 


     adapter = new MergeAdapter(); 
     adapter.addView(header); 
     adapter.addAdapter(arrayAdapter); 
     adapter.addView(header2); 
     adapter.addAdapter(arrayAdapter2); 
     adapter.addView(header3); 
     adapter.addAdapter(arrayAdapter3); 
     setListAdapter(adapter); 

    } 
@Override 
    protected void onCreate(Bundle savedInstanceState) { 
     // TODO Auto-generated method stub 
     super.onCreate(savedInstanceState); 

     checkPreferences(); 
     loadData(); 


     Button backbtn = (Button) findViewById(R.id.backbtn); 

     //Listening to button event 
     backbtn.setOnClickListener(new View.OnClickListener() { 

      public void onClick(View arg0) { 
       //Starting a new Intent 
       Intent previousScreen = new Intent(getApplicationContext(), ChooseTeamActivity.class); 
       ChosenMethod = "null"; 
       SharedPreferences preferences = getSharedPreferences("prefs", Context.MODE_PRIVATE); 
       SharedPreferences.Editor editor = preferences.edit(); 
       editor.putString("ChosenMethod", ChosenMethod);    
       editor.commit(); 
       previousScreen.putExtra("FullData", fulldata); 
       startActivity(previousScreen); 


      } 
     }); 

    } 


@Override 
public boolean onCreateOptionsMenu(Menu menu) { 
    MenuInflater inflater = getMenuInflater(); 
    inflater.inflate(R.menu.menu, menu); 
    return true; 
} 

@Override 
public boolean onOptionsItemSelected(MenuItem item) { 

    if (item.getItemId() == R.id.home) { 

     startActivity(new Intent(HomeActivity.this, HomeActivity.class)); 

     return(true); 
    } 


    if (item.getItemId() == R.id.match) { 

     startActivity(new Intent(HomeActivity.this, MatchActivity.class)); 

     return(true); 
    } 



    if (item.getItemId() == R.id.teams) { 

     startActivity(new Intent(HomeActivity.this, TeamsActivity.class)); 

     return(true); 
    } 



    if (item.getItemId() == R.id.twitter) { 

     startActivity(new Intent(HomeActivity.this, TwitterActivity.class)); 

     return(true); 
    } 

    if (item.getItemId() == R.id.info) { 

     startActivity(new Intent(HomeActivity.this, InfoActivity.class)); 

     return(true); 
    } 


    return(super.onOptionsItemSelected(item)); 


} 

} 
+5

我能看到的第一件事就是你在主線程中執行一個網絡任務,你應該使用一個AsyncTask在一個單獨的線程中執行。 – Demonick

+1

雖然你的問題是關於本網站的主題,但如果你在http://codereview.stackexchange.com/上發佈你的問題,你可能會得到更多的答案。 – THelper

回答

1

你應該採取看看這個awesome presentation by Romain Guy

它會給你一個你正在尋找的東西的內視圖,而你也將獲得一串方便的技巧:)

例如中除了使用AsyncTasksHandlers來避免重載gui線程,您可以將大部分變量聲明爲final。自定義的itemrenderer實現將顯着加快您的GUI(滾動),並且 - 儘管這不是一個好的Java實踐,但使用直接引用而不是getterssetters也會提高性能。