TikTok ลดขนาดโค้ดลง 58% และปรับปรุงประสิทธิภาพของแอปสำหรับฟีเจอร์ใหม่ด้วย Jetpack Compose
ใช้เวลาอ่าน 2 นาที
TikTok เป็นแพลตฟอร์มวิดีโอสั้นระดับโลกที่ขึ้นชื่อเรื่องฐานผู้ใช้จำนวนมากและฟีเจอร์ที่เป็นนวัตกรรม ทีมงานเผยแพร่การอัปเดต การทดลอง และฟีเจอร์ใหม่ๆ ให้ผู้ใช้อย่างต่อเนื่อง ทีม Android ของ TikTok จึงหันมาใช้ Jetpack Compose เพื่อรับมือกับความท้าทายในการรักษาความเร็วไปพร้อมๆ กับการจัดการหนี้ทางเทคนิค
ทีมงานต้องการให้การทำซ้ำข้อกำหนดของผลิตภัณฑ์ทำได้เร็วขึ้นและมีคุณภาพสูงขึ้น การใช้ประโยชน์จาก Compose ช่วยให้ทีมงานสามารถปรับปรุงประสิทธิภาพด้านวิศวกรรมด้วยการเขียนโค้ดน้อยลงและลดภาระทางความคิด ขณะเดียวกันก็ยังได้ประสิทธิภาพและความเสถียรที่ดีขึ้นด้วย
การปรับปรุง UI ที่ซับซ้อนเพื่อเพิ่มประสิทธิภาพการทำงานของนักพัฒนาแอป
หน้าต่างๆ ของ TikTok มักจะซับซ้อนกว่าที่เห็น โดยมีข้อกำหนดแบบมีเงื่อนไขซ้อนกันอยู่มากมาย ความซับซ้อนนี้มักจะทำให้ลำดับชั้นของ View มีโครงสร้างที่ไม่เหมาะสมและดูแลรักษายาก รวมถึงมีการซ้อน View มากเกินไป ซึ่งทำให้ประสิทธิภาพลดลงเนื่องจากมีการวัดผลหลายครั้ง
Compose มีโซลูชันโดยตรงสำหรับปัญหาโครงสร้างนี้
นอกจากนี้ _กลยุทธ์การวัดผล_ของ Compose ยังช่วยลด __การเก็บภาษีซ้ำซ้อน__ ทำให้การเพิ่มประสิทธิภาพการวัดผลทำได้ง่ายขึ้น
ทีมระบบการออกแบบส่วนกลางของ TikTok ได้จัดเตรียมคลังคอมโพเนนต์สำหรับทีมที่ทำงานกับฟีเจอร์ต่างๆ ของแอปเพื่อปรับปรุงประสิทธิภาพการทำงานของนักพัฒนาแอป ทีมงานสังเกตว่าการพัฒนาใน Compose นั้นง่าย โดยการใช้ประโยชน์จากคอมโพเนนต์ขนาดเล็กมีประสิทธิภาพสูง ขณะที่การรวมบล็อก UI ขนาดใหญ่เข้ากับตรรกะแบบมีเงื่อนไขนั้นทำได้ง่ายและมีค่าใช้จ่ายน้อย
การสร้างเส้นทางไปข้างหน้าผ่านการย้ายข้อมูลเชิงกลยุทธ์
การนำ Jetpack Compose มาใช้ในเชิงกลยุทธ์ช่วยให้ TikTok สามารถจัดการหนี้ทางเทคนิคได้ ขณะเดียวกันก็ยังคงมุ่งเน้นที่การสร้างประสบการณ์ที่ยอดเยี่ยมให้แก่ผู้ใช้ ความสามารถของ Compose ในการจัดการตรรกะแบบมีเงื่อนไขได้อย่างชัดเจนและการปรับปรุงการจัดองค์ประกอบช่วยให้ทีมงานลดเวลาในการโหลดหน้าได้สูงสุด 78% ในหน้าใหม่หรือหน้าที่เขียนใหม่ทั้งหมด การปรับปรุงนี้อยู่ที่ 20-30% ในกรณีที่เล็กกว่า และ 70-80% สำหรับการเขียนใหม่ทั้งหมดและฟีเจอร์ใหม่ นอกจากนี้ยังลดขนาดโค้ดลงได้ 58%, เมื่อเทียบกับฟีเจอร์เดียวกันที่สร้างใน View ทีมงานยังได้แชร์สิ่งที่ได้เรียนรู้เพิ่มเติม 2-3 ข้อ ดังนี้
กลยุทธ์โดยรวมของทีม TikTok คือการย้ายข้อมูลเส้นทางของผู้ใช้ที่เฉพาะเจาะจงทีละขั้นตอน ซึ่งทำให้ทีมงานมีโอกาสย้ายข้อมูล ยืนยันผลประโยชน์ที่วัดผลได้ แล้วขยายไปยังหน้าจออื่นๆ ทีมงานเริ่มต้นด้วยการใช้ Compose เพื่อลดความซับซ้อนของโครงสร้างโดยรวมในฟีเจอร์คิวอาร์โค้ดและเห็นการปรับปรุง ต่อมาทีมงานได้ขยายการย้ายข้อมูลไปยังประสบการณ์การเข้าสู่ระบบและการลงชื่อสมัครใช้
ทีมงานได้แชร์สิ่งที่ได้เรียนรู้เพิ่มเติม ดังนี้
ขณะตรวจสอบประสิทธิภาพระหว่างการย้ายข้อมูล ทีม TikTok พบว่าการใช้ ComposeView ขนาดเล็กจำนวนมากเพื่อแทนที่องค์ประกอบภายใน ViewHolder เดียวทำให้เกิดค่าใช้จ่ายในการจัดองค์ประกอบ ทีมงานได้ผลลัพธ์ที่ดีขึ้นด้วยการขยายการย้ายข้อมูลเพื่อใช้ ComposeView เดียวสำหรับ ViewHolder ทั้งหมด
เมื่อย้ายข้อมูล Fragment ภายใน ViewPager ซึ่งมีตรรกะความสูงที่กำหนดเองและตรรกะแบบมีเงื่อนไขเพื่อซ่อนและแสดง UI ตามการทดลอง ประสิทธิภาพจะไม่ได้รับผลกระทบ ในกรณีนี้ การย้ายข้อมูล ViewPager ไปยัง Composable ทำงานได้ดีกว่าการย้ายข้อมูล Fragment
Jun Shen ชอบที่ Compose "ลดจำนวนโค้ดที่จำเป็นสำหรับการพัฒนาฟีเจอร์ ปรับปรุงความสามารถในการทดสอบ และเร่งการเผยแพร่" ทีมงานวางแผนที่จะเพิ่มการนำ Compose มาใช้อย่างต่อเนื่อง เพื่อให้เป็นเฟรมเวิร์กที่ต้องการในระยะยาว Jetpack Compose พิสูจน์ให้เห็นแล้วว่าเป็นโซลูชันที่มีประสิทธิภาพสำหรับการปรับปรุงทั้งประสบการณ์ของนักพัฒนาแอปและเมตริกการผลิตในวงกว้าง
เริ่มต้นใช้งาน Jetpack Compose
ดูข้อมูลเพิ่มเติมเกี่ยวกับวิธีที่ Jetpack Compose ช่วยทีมของคุณได้
-
กรณีศึกษาการถดถอยของประสิทธิภาพเป็นสิ่งที่จำลองได้ยากมาก ซึ่งทำให้การถดถอยเป็นปัญหาคอขวดขนาดใหญ่สำหรับนักพัฒนาแอปบนอุปกรณ์เคลื่อนที่
Alice Yuan, Arti Arutiunov, Nikita Ogorodnikov • ใช้เวลาอ่าน 4 นาที -
กรณีศึกษาเมื่อไม่นานมานี้ FotMob มีการเพิ่มขึ้นมากที่สุดในวันเดียวใน Wear OS ในกลุ่มผู้ชมที่ติดตั้งแอปในช่วง 5 ปีที่ผ่านมา โดยเพิ่มขึ้น 2-3 เท่าของค่าเฉลี่ยรายวัน เคล็ดลับคืออะไร ขั้นตอนการติดตั้งข้ามอุปกรณ์ที่เรียบง่ายซึ่งช่วยให้ผู้ใช้ค้นพบแอป Wear OS ได้โดยตรงจากโทรศัพท์
Garan Jenkin • ใช้เวลาอ่าน 3 นาที -
กรณีศึกษาแอป Gratitude ซึ่งเป็นแอปฝึกสติช่วยกระตุ้นให้เกิดความสม่ำเสมอผ่านการจดบันทึกประจำวันขนาดเล็ก ข้อความเสริมสร้างกำลังใจ และบอร์ดวิสัยทัศน์ แอปนี้มีการดาวน์โหลดมากกว่า 6 ล้านครั้ง ได้รับคะแนน 5 ดาว 150,000 ครั้ง และมีการบันทึกรายการบันทึกมากกว่า 100 ล้านรายการ
Amrit Sanjeev, Ash Nohe • ใช้เวลาอ่าน 3 นาที
รับข้อมูลเชิงลึกด้านการพัฒนา Android ล่าสุดส่งตรงถึงกล่องจดหมายของคุณ ทุกสัปดาห์