Innholdsfortegnelse:
- Posting a new tweet
- I MyAsyncTaskTweet blir parameteren som sendes til doInBackground, behandlet som en tweet. Men i MyAsyncTaskTimeline er parameteren som sendes til doInBackground, et brukernavn. Koden passerer dette brukernavnet til getUserTimeline-metoden.
Video: Android 101 by Fred Widjaja 2024
En AsyncTask er hva du bruker når noe tar for mye tid i løpet av Android-appen din. For eksempel ber brukeren en nettside. Hvem vet hvor lang tid det tar å hente siden? Tjenesten som er vert for nettsiden, kan oppstå høyt volum. Eller brukeren kan være på et tog som passerer gjennom en tunnel.
Alle typer ting kan redusere sidens gjenfinning. Og under denne hentingen vil brukeren kanskje klikke på knapper, bla et dokument, eller gjøre noe annet som krever et svar fra appen din.
Du kan ikke stoppe showet mens appen din venter på en nettside, henter en Twitter-tidslinje, eller oppdaterer brukerens Twitter-status. Derfor kodes du nettverksforespørselen i en AsyncTask.
Android's AsyncTask er allsidig nok til å håndtere alle typer verdier. Faktisk definerer dokumentasjonen en AsyncTask på denne måten:
android. os. AsyncTask
Definisjonen har tre generiske type plassholdere - Params, Progress og Result. Når du oppretter din egen AsyncTask, fyller du i blankene ved å spesifisere faktiske typer i stedet for Params, Progress og Result.
Posting a new tweet
For å legge til en tweet på vegne av brukeren, tar du et Twitter-objekt (forekomsten du har laget med fabrikken. GetInstance ()), og du kaller forekomstens oppdateringsstatusmetode. Du vil ikke at denne nettverksforespørselen skal avbryte strømmen av hovedaktiviteten din, så du legger forespørselen inne i en AsyncTask. Oppgavens navn er MyAsyncTaskTweet. Oppgavens tre generiske typer er som følger: String, Void og String:
offentlig klasse MyAsyncTaskTweet utvider AsyncTask << String , Gyldig , String >> { Den første typen (String) representerer en tweetegn på 140 tegn. Koden
-
utfør (editTextTweet. GetText (). ToString ())
tar tak i en streng av tegn fra en av aktivitetens tekstfelter og sender denne strengen til MyAsyncTaskTweet. Inne i MyAsyncTaskTweet, kalles doInBackground-metoden som streng tweet [0] og bruker den tweet [0] -strengen for å oppdatere brukerens status.
Parameteren til oppdateringsstatusmetoden er et arrayelement. Det er fordi, i DoInBackground-metodenes overskrift, er tweet en varargs-parameter. Ordet varargs betyr "variabelt antall argumenter. "Du kan passere så mange verdier som du vil. I kroppen av metoden behandler du tweet som om det er et vanlig utvalg. Den første tweetverdien er tweet [0]. Hvis det var en andre tweet-verdi, ville det være tweet [1], og så videre.
Den andre typen (Void) står for en verdi (eller verdier) som markerer bakgrunns trådenes fremgang ved å fullføre arbeidet.
Siden det ikke er noen fremdriftsindikator, er det andre typenavnet ugyldig.
-
I Java er Void-klassen en wrapper-klasse for tomrommet. Sett det i ditt svarte hull av ingenting!
Den tredje typen (String) står for en setning som
Suksess!
-
eller Kunne ikke tweet . DoInBackground-metoden finner strengen assosiert med enten R.-streng. suksess, R. streng. twitter_failure, eller R. streng. general_failure og returnerer denne strengen som resultat. Deretter viser onPostExecute-metoden denne strengen i skjermens editTextTweet-felt. Dette bildet oppsummerer måten generiske typenavn påvirker metodens typer.
Bruken av typer i MyAsyncTaskTweet.
Bildet nedenfor oppsummerer hvordan verdier går fra ett sted til et annet i MyAsyncTaskTweet.
Strømmen av verdier i MyAsyncTaskTweet.Få brukerens tidslinje
Hvis du har sett en AsyncTask, har du sett dem alle! Klassen MyAsyncTaskTimeline er nesten identisk med MyAsyncTaskTweet. De eneste forskjellene er som følger:I MyAsyncTaskTweet blir parameteren som sendes til doInBackground, behandlet som en tweet. Men i MyAsyncTaskTimeline er parameteren som sendes til doInBackground, et brukernavn. Koden passerer dette brukernavnet til getUserTimeline-metoden.
I MyAsyncTaskTweet er verdien returnert fra doInBackground en suksess eller feilmelding. Men i MyAsyncTaskTimeline er verdien returnert fra doInBackground en streng full av tweets (en tidslinje).
-
Koden for å hente en brukers tidslinje ser slik ut:
-
Liste statuser = null; statuses = twitter. getUserTimeline (brukernavn [0]);
En fyr med navnet Yusuke Yamamoto utviklet Twitter4J (eller i det minste Yusuke Yamamoto var Twitter4J prosjektleder), og på et tidspunkt bestemte Mr. Yamamoto at getUserTimeline-metoden returnerer en samling av twitter4J. Statusobjekter. (Hver twitter4J. Status-forekomst inneholder en tweet.) Så, for å hedre kontrakten satt ved å ringe getUserTimeline-metoden, erklærer koden statusene som en samling av twitter4J. Statusobjekter.
Noen linjer senere i koden, en forbedret for setning går gjennom samlingen av statusverdier og legger til hver verdi tekst til en stor resultatstreng. Sløyfen legger til "n" (Java's go-to-the-next-line karakter) etter hvert tweet for godt mål. I onPostExecute-metoden viser koden den store resultatstrengen i skjermens textViewTimeline-felt.
I den andre doInBackground-metoden er det fullt kvalifiserte navnet twitter4j. Status brukes. Dette er gjort for å skille twitter4J. Statusklasse fra Android egen AsyncTask. Statusklasse (en indre klasse i AsyncTask-klassen).
En AsyncTask kan være ganske komplisert. Men når du sammenligner Android's AsyncTask til gjør-det-selv-tråderalternativene, er AsyncTask-ideen ikke dårlig i det hele tatt. Faktisk, når du får litt øvelse og lager noen av dine egne AsyncTask-klasser, blir du vant til å tenke på den måten. Hele virksomheten begynner å føle seg helt naturlig.