Download Associate Android Developer.Associate-Android-Developer.VCEplus.2021-06-21.107q.vcex

Vendor: Google
Exam Code: Associate-Android-Developer
Exam Name: Associate Android Developer
Date: Jun 21, 2021
File Size: 2 MB
Downloads: 2

How to open VCEX files?

Files with VCEX extension can be opened by ProfExam Simulator.

Demo Questions

Question 1
What is a correct part of an Implicit Intent for sharing data implementation?
  1. val sendIntent = Intent(this, 
    UploadService::class.java).apply {     
    putExtra(Intent.EXTRA_TEXT, textMessage) ...
  2. val sendIntent = Intent().apply {      type = 
    Intent.ACTION_SEND; ...
  3. val sendIntent = Intent(this, 
    UploadService::class.java).apply {      data = 
    Uri.parse(fileUrl) ...
  4. val sendIntent = Intent().apply {     action = 
    Intent.ACTION_SEND ...
Correct answer: D
Explanation:
Create the text message with a string  val sendIntent = Intent().apply {     action  = Intent.ACTION_SEND      putExtra(Intent.EXTRA_TEXT, textMessage)      type = "text/plain" }   Reference: https://developer.android.com/guide/components/fundamentals
Create the text message with a string  
val sendIntent = Intent().apply {     action  
= Intent.ACTION_SEND      
putExtra(Intent.EXTRA_TEXT, textMessage)      
type = "text/plain" }  
 
Reference: https://developer.android.com/guide/components/fundamentals
Question 2
By default, the notification's text content is truncated to fit one line. If you want your notification to be longer, for example, to create a larger text area, you can do it in this way:
  1. var builder = NotificationCompat.Builder(this, CHANNEL_ID) 
            .setContentText("Much longer text that cannot fit one line...")  
            .setStyle(NotificationCompat.BigTextStyle()  
                    .bigText("Much longer text that cannot fit one line..."))  
            ...
  2. var builder = NotificationCompat.Builder(this, CHANNEL_ID) 
          .setContentText("Much longer text that cannot fit one line...")         
    .setLongText("Much longer text that cannot fit one line..."))  
            ...
  3. var builder = NotificationCompat.Builder(this, CHANNEL_ID) 
            .setContentText("Much longer text that cannot fit one  
    line...")         .setTheme(android.R.style.Theme_LongText);          
    ...
Correct answer: A
Explanation:
Reference: https://developer.android.com/training/notify-user/build-notification
Reference: 
https://developer.android.com/training/notify-user/build-notification
Question 3
Select correct demonstration of WorkRequest cancellation.  
  1. workManager.enqueue(OneTimeWorkRequest.Builder(FooWorker::class.java).build())
  2. val request: WorkRequest = OneTimeWorkRequest.Builder(FooWorker::class.java).build() 
    workManager.enqueue(request)  
    val status = workManager.getWorkInfoByIdLiveData(request.id)  
    status.observe(...)
  3. val request: WorkRequest = OneTimeWorkRequest.Builder(FooWorker::class.java).build() 
    workManager.enqueue(request) workManager.cancelWorkById(request.id)
  4. val request1: WorkRequest = OneTimeWorkRequest.Builder(FooWorker::class.java).build() 
    val request2: WorkRequest = OneTimeWorkRequest.Builder(BarWorker::class.java).build() 
    val request3: WorkRequest = OneTimeWorkRequest.Builder(BazWorker::class.java).build() 
    workManager.beginWith(request1, request2).then(request3).enqueue()
  5. val request: WorkRequest = OneTimeWorkRequest.Builder(FooWorker::class.java).build() 
    workManager.enqueue(request) workManager.cancelWork(request)
Correct answer: C
Explanation:
Videos: Working with WorkManager, from the 2018 Android Dev Summit  WorkManager: Beyond the basics, from the 2019 Android Dev Summit Reference: https://developer.android.com/reference/androidx/work/WorkManager?hl=en
Videos: 
  • Working with WorkManager, from the 2018 Android Dev Summit  
  • WorkManager: Beyond the basics, from the 2019 Android Dev Summit 
Reference: 
https://developer.android.com/reference/androidx/work/WorkManager?hl=en
Question 4
In general, you should send an AccessibilityEvent whenever the content of your custom view changes. For example, if you are implementing a custom slider bar that allows a user to select a numeric value by pressing the left or right arrows, your custom view should emit an event of type TYPE_VIEW_TEXT_CHANGED whenever the slider value changes. Which one of the following sample codes demonstrates the use of the sendAccessibilityEvent() method to report this event.
  1. override fun dispatchPopulateAccessibilityEvent(event: 
    AccessibilityEvent): Boolean {     return 
    super.dispatchPopulateAccessibilityEvent(event).let { completed ->          
    if (text?.isNotEmpty() == true) {             event.text.add(text)              
    true         } else {             completed  
            }  
        }  
    }
  2. override fun onKeyUp(keyCode: Int, event: KeyEvent): Boolean { 
    return when(keyCode) {  
            KeyEvent.KEYCODE_DPAD_LEFT -> {              
    currentValue--  
                sendAccessibilityEvent(AccessibilityEvent.TYPE_VIEW_TEXT_CHANGED)              
    true  
            }  
            ...  
        }  
    }
  3. override fun onKeyUp(keyCode: Int, event: KeyEvent): Boolean { 
    return when(keyCode) {  
            KeyEvent.KEYCODE_ENTER -> {              
    currentValue--  
                sendAccessibilityEvent(AccessibilityEvent.TYPE_VIEW_CONTEXT_CLICKED)              
    true  
            }  
            ...  
        }  
    }
Correct answer: B
Explanation:
Reference: https://developer.android.com/guide/topics/ui/accessibility/custom-views
Reference: https://developer.android.com/guide/topics/ui/accessibility/custom-views
Question 5
The easiest way of adding menu items  (to specify the options menu for an activity) is inflating an XML file into the Menu via MenuInflater. With menu_main.xml we can do it in this way:
  1. override fun onCreateOptionsMenu(menu: Menu): Boolean 
    {    menuInflater.inflate(R.menu.menu_main, menu)     
    return true  
    }
  2. override fun onOptionsItemSelected(item: MenuItem): 
    Boolean { menuInflater.inflate(R.menu.menu_main, menu)  
       return super.onOptionsItemSelected(item)  
    }
  3. override fun onCreate(savedInstanceState: Bundle?) { 
    super.onCreate(savedInstanceState)     
    setContentView(R.menu.menu_main) }
Correct answer: A
Explanation:
Reference: https://developer.android.com/guide/topics/ui/accessibility/custom-views
Reference: https://developer.android.com/guide/topics/ui/accessibility/custom-views
Question 6
Android Tests. You can use the childSelector() method to nest multiple UiSelector instances. For example, the following code example shows how your test might specify a search to find the first ListView in the currently displayed UI, then search within that ListView to find a UI element with the text property Apps. What is the correct sample?
  1. val appItem: UiObject = device.findObject( 
            UiSelector().className(ListView.class)  
                    .instance(1)  
                    .childSelector(  
                            UiSelector().text("Apps")  
                    )  
    )
  2. val appItem: UiObject = device.findObject( 
            UiSelector().className("android.widget.ListView")  
                    .instance(0)  
                    .childSelector(  
                            UiSelector().text("Apps")  
                    )  
    )
  3. val appItem: UiObject = device.findObject( 
            UiSelector().className("android.widget.ListView")  
                    .instance(  
                            UiSelector().text("Apps")  
                    )  
    )
Correct answer: B
Question 7
The following code snippet shows an example of an Espresso test:
  1. @Rule fun 
    greeterSaysHello() {  
        onView(withId(R.id.name_field)).do(typeText("Steve"))      
    onView(withId(R.id.greet_button)).do(click())  
        onView(withText("Hello Steve!")).check(matches(isDisplayed()))  
    }
  2. @Test fun 
    greeterSaysHello() {  
        onView(withId(R.id.name_field)).perform(typeText("Steve"))      
    onView(withId(R.id.greet_button)).perform(click())  
        onView(withText("Hello Steve!")).check(matches(isDisplayed()))  
    }
  3. @Test fun 
    greeterSaysHello() {  
        onView(withId(R.id.name_field)).do(typeText("Steve"))      
    onView(withId(R.id.greet_button)).do(click())  
        onView(withText("Hello Steve!")).compare(matches(isDisplayed()))  
    }
Correct answer: B
Question 8
As an example. In an Activity we have our TimerViewModel object (extended ViewModel), named mTimerViewModel. mTimerViewModel.timer method returns a LiveData<Long> value. What can be a correct way to set an observer to change UI in case if data was changed?
  1. mTimerViewModel!!.timer.value.toString().observe 
    (Observer { aLong -> callAnyChangeUIMethodHere(aLong!!) })
  2. mTimerViewModel!!.timer.observe 
    (this, Observer { aLong -> callAnyChangeUIMethodHere(aLong!!) })
  3. mTimerViewModel.observe 
    (Observer { aLong -> callAnyChangeUIMethodHere(aLong!!) })
Correct answer: B
Question 9
LiveData.postValue() and LiveData.setValue() methods have some differences. So if you have a following code executed in the main thread: 
liveData.postValue("a");  
liveData.setValue("b");  
What will be the correct statement?
  1. The value "b" would be set at first and later the main thread would override it with the value "a".
  2. The value "a" would be set at first and later the main thread would override it with the value "b".
  3. The value "b" would be set at first and would not be overridden with the value "a".
  4. The value "a" would be set at first and would not be overridden with the value "b".
Correct answer: B
Question 10
In our TeaViewModel class, that extends ViewModel, we have such prorerty: 
val tea: LiveData<Tea> 
An observer in our Activity (type of mViewModel variable in example is TeaViewModel) is set in this way: 
mViewModel!!.tea.observe(this, Observer { tea: Tea? -> displayTea(tea) }) 
What will be a correct displayTea method definition?
  1. private fun displayTea()
  2. private fun displayTea(tea: Tea?)
  3. private fun displayTea(tea: LiveData?<Tea>) 
  4. private fun displayTea(tea: LiveData?<T>)
Correct answer: B
HOW TO OPEN VCE FILES

Use VCE Exam Simulator to open VCE files
Avanaset

HOW TO OPEN VCEX AND EXAM FILES

Use ProfExam Simulator to open VCEX and EXAM files
ProfExam Screen

ProfExam
ProfExam at a 20% markdown

You have the opportunity to purchase ProfExam at a 20% reduced price

Get Now!