Tinder is the world's most popular app for meeting new people. Known for changing how people meet and date, it empowers users to swipe right to connect and chat with others. Tinder sparks over 26 million matches a day, with more than 20 billion matches made since their launch in 2012.
The company needed to scale up the
quickly, based on user demand, but their database implementation was left over
from their early days, making it increasingly more complicated to expand upon.
They also had a view-heavy architecture to reduce lifecycle complexities, but
needed to know which lifecycle events were specific to an activity. They lacked
a consistent framework for handling tasks such as marshalling
Cursor objects into domain objects, making
database migrations, or consistently performing queries.
What they did
Tinder turned to Android Architecture
Components for solutions for upgrading their
code. They used
View observe its host activity's
lifecycle, and they used
to facilitate a decentralized plugin architecture and to prevent bloat in
objects. The Room persistence library
provided a turnkey method for defining, managing, and querying their local
The Tinder development team was able to implement the
plugin architecture in only two weeks, while seamlessly implementing Room for
their internal Ads SDK took just two days.
"We no longer had to invest significant time managing the Activity Lifecycle inside of plugins or views," says Andy Lawton, Head of Android at Tinder. "Room's design is well- thought-out and makes our persistence layer easy to implement. Using Room for the internal Ads SDK probably saved a week of time in upfront development."
Tinder was so pleased with their results with their Ads SDK that they're migrating their entire database layer to Room. Testing was easy, and Room's protection against forgetting to unregister something reduced memory leaks. Android Architecture Components is also helping to produce smaller memory footprints.
"Android Architecture Components has provided a prescription for solving many of the pain points that developers face at all different scales," Lawton says. "Through the use of lifecycle-aware components, Tinder has managed to improve developer productivity, testability, and modularity, while being conducive to a view-first architecture. Room eliminates the need for other solutions for managing SQLite, and turns database management and querying into an exercise in configuration."
500+ lines of code removed from
Android Architecture Components is open to all developers as part of Android Jetpack. Get started with Android Architecture Components.