Сборник тестов: 1500 вопросов и ответов на знание Android Машнин Тимур
Создание Helper объекта занимает больше времени.
Мы не можем предсказать, иногда создание Helper объекта занимает много времени и иногда получение объекта базы данных может занять некоторое время. Мы не можем угадать, что является асинхронным.
Создание Helper объекта является синхронным и возвращает немедленно, тогда как getWritableDatabase может занять некоторое время, когда вы создаете базу данных впервые. Так что это может занять больше времени (асинхронное создание) впервые или когда мы обновляем базу данных.
Создание и получение sqlitedatabase объекта является асинхронным иногда, но мы не можем угадать, когда это будет асинхронно.
Вопрос 5
Запустить сервис из активности и закрыть активность, при этом, что произойдет с этим сервисом, будет ли он жив или мертв?
Сервис также будет убит.
Сервис будет жив в течение некоторого времени и будет убит Android сборщиком мусора.
Сервис будет работать вечно, никто не сможет остановить его сейчас, и будет утечка памяти.
Сервис будет продолжать работать в фоновом режиме, но это он может остановить себя сам, когда выполнит работу. Или другие компоненты также могут убить его, используя stopService (), или Android может также убить сервис в случае нехватки памяти.
Вопрос 6
Какая функция реализуется в классе bound service?
onCreate ()
onBind () и onUnbind ()
ServiceConnectionListener на клиентской стороне.
Все перечисленное.
Вопрос 7
Как обновить пользовательский интерфейс из сервиса, который имеет потоки?
Создать поток в классе сервиса и иметь непосредственный доступ к компонентам пользовательского интерфейса вашей активности.
Так как обновление интерфейса из другого потока непосредственно не представляется возможным, создать коммуникацию с главным UI потоком для обновления пользовательского интерфейса.
Использование Intent Service.
Все перечисленное.
Вопрос 8
Как запустить сервис с приоритетом переднего плана?
Сервис всегда работает в фоновом режиме, так как он не имеет пользовательского интерфейса, так что это не возможно.
startService (intent, boolean foreground); передать второй параметр true, чтобы сделать этот сервис с приоритетом переднего плана.
Установить приоритет сервиса в <service> теге в файле манифеста. если приоритет отличается от 0, тогда сервис будет на переднем плане.
startForeground (int id, Notification notification), используйте эту функцию в оnCreate () вашего сервиса.
Вопрос 9
Мое приложение имеет только сервис, и мой сервис выполняет тяжелую функциональность подключения к Интернету и получения данных, должен ли я создать поток или нет? Если это так, почему?
Да потому что сервис по умолчанию, без каких-либо потоков, использует основной поток.
Да потому что, если сервис и активность работают в одном потоке, это может привести к ANR ошибке.
Нет, вам не нужно создавать поток, потому что сервис создаст фоновый поток, когда кто-то запускает сервис.
Нет необходимости создавать новый поток в сервисе, это не требуется в этом случае. Потому что сервис работает в главном потоке. Так как наше приложение не имеет какой-либо активности, все будет ОК, если запустить сервис в главном потоке.
Вопрос 10
Как передать данные от активности сервису?
Передать данные в putextras намерения и использовать setResult ().
Передать данные в putextras намерения и использовать startService () с этим намерением.
Сохранить данные в общую базу данных и обеспечить доступ к ним как из активности, так и из сервиса.
Все перечисленное.
Вопрос 11
Как получить доступ к прогресс бару из сервиса?
Отправить ProgressBar идентификатор с помощью intent extras и получить доступ к нему в сервисе.
Сделать индикатор как статическую переменную в активности и получить доступ к переменной в сервисе.
Если вы хотите обновить интерфейс в сервисе, вызовите динамически зарегистрированный приемник в активности из сервиса. И обновите пользовательский интерфейс из этого динамического приемника этой активности.
Поместить все элементы управления пользовательского интерфейса в общем классе и получить к нему доступ из всех компонентов.
Вопрос 12
Какие значения возвращает метод onStartCommand () и когда они используются?
START_STICKY – в случае, если Android останавливает наш сервис силой, а затем перезапускает сервис, посылая нулевое намерение.
START_NOT_STICKY – в случае, если Android останавливает наш сервис силой, не перезапуская сервис, пока пользователь сам не перезапустит его.
START_REDELIVER_INTENT – в случае, если Android останавливает наш сервис силой, а затем перезапускает сервис, посылая повторно намерение.
Все перечисленное.
Вопрос 13
Как контролировать состояние подключения bound service?
Используя метод isServiceConnected (), который возвращает истину, если сервис подключен.
Используя метод onServiceDisConnected (), эта функция будет вызываться, если соединение нарушается.
Клиент может опрашивать сервис, доступен он или нет.
Используя класс ServiceConnection.
Вопрос 14
Предположим, мой сервис поддерживает и starting service и binding service, и в настоящее время два клиента запустили мой сервис и один клиент связался с моим сервисом. Через 5 минут клиент, который был связан с моим сервисом, отвязывается, а другой клиент останавливает мой сервис. В настоящее время мой сервис работает в памяти или выведен из памяти?
Сервис умер, но до сих пор в памяти.
Сервис мертв и выведен из памяти.
Сервис по-прежнему жив и в памяти.
Сервис все еще жив, но выведен из памяти.
Вопрос 15
Как реализовать IPC (inter process communication), используя Binder?
1. Создать сервис, реализовать оnCreate (), onBind (), onUnbind (), оnDestroy ()
2. Создать файл. aidl с интерфейсными функциями.
3. Реализовать автоматический генерируемый Binder класс заглушки в сервисе.
4. Возвратить объект этого класса заглушки из onBind ().
1. Создать сервис, реализовать оnCreate (), onBind (), onStartCommand (), onUnbind (), оnDestroy ().
2. Создать файл. aidl с интерфейсными функциями.
3. Реализовать автоматически генерируемый Binder класс заглушки в сервисе.
4. Возвратить объект этого класса заглушки из onStartCommand ().
1. Создать сервис, реализовать оnCreate (), onBind (), onStartCommand (), onUnbind (), оnDestroy ().
2. Создать внутренний класс в классе сервиса, который расширяет класс Binder.
3. Реализовать функции этого внутреннего класса.
4. Возвратить объект этого внутреннего класса из onStartCommand ().
1. Создать сервис, реализовать оnCreate (), onBind (), onUnbind (), оnDestroy ().
2. Создать внутренний класс в классе сервиса, который расширяет класс Binder.
3. Реализовать функции этого внутреннего класса.
4. Возвратить объект этого внутреннего класса из onBind ().
Вопрос 16
Для реализации фоновой функциональности активности, что лучше, запустить сервис или поток?
Вы можете использовать оба, потому что оба будут делать то же самое.
Если фоновая функциональность связана с активностью, использовать поток. Если нет, запустить сервис с потоком в нем.
Имеет ли фоновая функциональность связь с активностью или нет, всегда лучше воспользоваться сервисом с потоком, а не активностью с потоком.
Если вы хотите некоторую фоновую функциональность в активности, используйте поток, нет необходимости в сервисе.
Вопрос 17
Можно ли создать сервис без какого-либо потока?
Да, вы можете иметь сервис, запущенный в главном потоке.
Нет, сервис должен иметь поток, он не может работать в главном потоке.
Да, вы можете иметь сервис, запущенный в главном потоке, только если вы не имеете какой-либо активности в главном потоке.
Поток и сервис не связаны.
Вопрос 18
Что произойдет, если вы запустите сервис без потока, как будет работать тяжелая функциональность?
Ничего не случится, сервис будет работать хорошо.
Может привести к ANR (приложение не отвечает) ошибке.
Может привести к ANR (приложение не отвечает) ошибке, если ваше приложение имеет, по меньшей мере, одну активность, поскольку эта активность будет работать в потоке пользовательского интерфейса.
Может привести к ANR (приложение не отвечает) ошибке, независимо от того, есть ли у вас, по крайней мере, одна активность или нет в вашем приложении.
Вопрос 19
В случае нехватки памяти, если Android закрывает сервис насильно, тогда сервис перезагрузится автоматически или пользователь должен запустить этот сервис?
Сервис не будет перезапущен системой Android.
Пользователь должен перезапустить его снова.
Сервис не будет перезапущен системой Android, если метод onStartCommand () вернет START_NOT_STICKY.
Сервис не будет перезапущен системой Android, если метод onStartCommand () вернет START_STICKY или START_NOT_STICKY.
Вопрос 20
JSON это язык?
Да
Нет
Мы не можем назвать его языком. Это легковесный текстовый формат, который используется для обмена данными между двумя системами, подключенными к сети. Он является альтернативой XML способом передачи данных между системами.
Ничего из перечисленного.
Вопрос 21
Какие из следующих являются элементами JSON?
Number, String, Boolean, null, Array, Object.
Number, String, Boolean, Array, Object.
String, Array, Object.
Number, String, null, Array, Object.
Вопрос 22
Как передать данные интернет-серверу из Android приложения?
Если данные небольшие – использовать пространства имен NameValuePairs, если данные большие, использовать XML. XML быстрее, чем JSON, поэтому разбор и загрузка будут быстрее.
Если данные небольшие – использовать пространства имен NameValuePairs, если данные большие, использовать JSON. JSON быстрее, чем XML, поэтому разбор и загрузка будут быстрее.
Если данные небольшие – использовать пространства имен NameValuePairs, если данные большие, использовать XML. XML быстрее, чем JSON, поэтому разбор и загрузка будут быстрее. Многие веб-сайты и сервисы имеют большую поддержку XML по сравнению с JSON.
Если данные небольшие – использовать пространства имен NameValuePairs, если данные большие, использовать JSON. JSON быстрее, чем XML, поэтому разбор и загрузка будут быстрее. Многие веб-сайты и сервисы, включая Twitter, facebook, Google, LinkedIn использует JSON, а не XML.
Вопрос 23
Что из следующего верно о коде состояния HTTP ответа, приходящего от сервера к Android приложению?
Код состояния доступен в строке состояния, которая содержит статус результата ответа сервера.
Если код состояния> 400, то это означает успешное выполнение на стороне сервера.
Если код состояния <= 400, то это означает успешное выполнение на стороне сервера.
Вопрос 24
Что произойдет, если код HTTP-соединения будет написан в главном потоке активности?
Это может привести к ANR.
Это не даст никакой ошибки, но может привести к ANR до 2.3 версии. но начиная с 3,0 это является обязательным, чтобы все сетевые соединения производились в отдельном потоке. Иначе во время выполнения будет исключение NetworkOnMainThreadException.
Код будет отлично работать. Ошибки не будет.
Если мы не будем использовать отдельный фоновый поток, начиная с версии 3.0, система будет бросать исключение времени выполнения.
Вопрос 25
Для подключения к сети Android приложения, какой из следующих вариантов я должен использовать?
DefaultHTTPClient
DefaultHTTPClient или AndroidHttpClient
HttpURLConnection. Это более легковесный вариант, так что используйте его всегда.
До Froyo (2.2) лучше использовать вариант DefaultHTTPClient или AndroidHttpClient, но после него лучше использовать HttpURLConnection.
Вопрос 26
Как войти в Gmail аккаунт из Android приложения с помощью HTTP запроса?
DefaultHttpClient client = new DefaultHttpClient ();
HttpPost post = new HttpPost (»http://mail.google.com/");
List <NameValuePair> params = new ArrayList <NameValuePair> (3);
params. add (new BasicNameValuePair («Email», "username@gmail.com»));
params. add (new BasicNameValuePair («Passwd», «password here»));
params. add (new BasicNameValuePair («signIn», «Sign in»));
post. setEntity (new UrlEncodedFormEntity (params));
HttpResponse res = client. execute (post);
if (res. getStatusLine (). getStatusCode () <400)
//success
else
//fail
//////////////////////////////////////////////////////////////////////////////////////////////
DefaultHttpClient client = new DefaultHttpClient ();
HttpPost post = new HttpPost (»http://mail.google.com/");
List <NameValuePair> params = new ArrayList <NameValuePair> (3);
params. add (new BasicNameValuePair («Email», "username@gmail.com»));
params. add (new BasicNameValuePair («Passwd», «password here»));
post. setEntity (new UrlEncodedFormEntity (params));
HttpResponse res = client. execute (post);
if (res. getStatusLine (). getStatusCode () <400)
//success
else
//fail
/////////////////////////////////////////////////////////////////////////////////////////
DefaultHttpClient client = new DefaultHttpClient ();
HttpPost post = new HttpPost (»http://mail.google.com/");
List <NameValuePair> params = new ArrayList <NameValuePair> (3);
params. add (new BasicNameValuePair («Email», "username@gmail.com»));
params. add (new BasicNameValuePair («Passwd», «password here»));
post. setEntity (new UrlEncodedFormEntity (params));
HttpResponse res = client. execute (post);
if (res. getStatusLine (). getStatusCode ()> = 400)
//success
else
//fail
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
DefaultHttpClient client = new DefaultHttpClient ();
HttpPost post = new HttpPost (»http://mail.google.com/");
List <NameValuePair> params = new ArrayList <NameValuePair> (3);
params. add (new BasicNameValuePair («Email», "username@gmail.com»));
params. add (new BasicNameValuePair («Passwd», «password here»));
params. add (new BasicNameValuePair («signIn», «Sign in»));
post. setEntity (new UrlEncodedFormEntity (params));
HttpResponse res = client. execute (post);
if (res. getStatusLine (). getStatusCode ()> = 400)
//success
else
//fail
Вопрос 27
Какие технологии лучше всего подходят, чтобы отправлять данные по сети к серверу из Android приложения?
SOAP быстрее, чем REST для передачи данных.
JSON быстрее, чем XML, XML быстрее, чем SOAP.
JSON быстрее, чем XML, XML быстрее, чем SOAP. Но если мы хотим использовать SOAP в мобильных приложениях, мы можем использовать KSOAP, который разработан для встраиваемых устройств и который быстрее.
Ничего из перечисленного.
Вопрос 28
Какие исключения могут быть брошены во время разбора JSON ответа от сервера в Android приложении?
