-
Notifications
You must be signed in to change notification settings - Fork 3.1k
Description
Dear developers,
I am analyzing owncloud using a static code checker. I found some potential slow operations in owncloud's UI thread.
Android documentation says this:
http://developer.android.com/training/articles/perf-anr.html
"Any method that runs in the UI thread should do as little work as possible on that thread. In particular, activities should do as little as possible in key life-cycle methods such as onCreate(). Potentially long running operations such as network or database operations, or computationally expensive calculations such as resizing bitmaps should be done in a worker thread (e.g., via AsyncTask)."
I've identified the following operations running on the UI thread that may cause performance issues:
- File system I/O:
ReceiveExternalFilesActivity.onCreate()synchronously invokesprepareStreamsToUpload(), which performs blocking file system operations (e.g., callingFile.getCanonicalPath()). - Database I/O:
FolderPickerActivity.onCreate()synchronously invokesinitAndShowListOfFilesFragment(), which triggers disk I/O by querying the local SQLite database viaFileDataStorageManager.getFileByPath().
Do you think these slow operations will affect owncloud's performance (e.g., make GUI not smooth enough)? If yes, perhaps moving them to a separate thread can help make owncloud super smooth in user interaction. Looking forward to your reply and hope I can help improve owncloud.