we did it with Java in following way:
1) function that reliably getting pageSource (just few retries in loop. very very random it can fail to get source and this is helpful)
2) function that gets Nodelist with xPath evaluate. Two different evaluations for Android and iOS clients due to structure difference
3) different functions that do whatever needed with found Nodelist e.g. getting some attribute text or number of elements in nodeList
Were does it help:
1) iOS client first.
1.1) iOS clients can have very large source tree (e.g. list of items) as far as in source also visible items outside screen. In such case each request takes time (no matter getPagerSrouce or check that element visible with driver.findElements(MobileBy....)). Thus check that e.g. 5 elements exist on screen taking large amount of time. With implemented method above we taking screenshot of Pagesource one time and do check all needed elements inside -> speedup in times such checks.
1.2) iOS clients to check if given elements 100% visible and on displaying on screen. With Appium we can't get 100% display on screen sometimes (due to visibility attribute setting wrong in client with some elements by some reason).
2) iOS and Android client when we need quickly to check that some elements not exists on screen. Timeout waiting and managing is boring and sometimes does not help to speedup element absence waiting.
With Android client not any benefit against Appium requests in terms of speed.