แก้ไขข้อ จำกัด ในการทำงานพื้นหลังจาก Android 5.0 เป็น 13

Nov 29 2022
กาลครั้งหนึ่งนานมาแล้ว การทำงานในพื้นหลังเป็นเรื่องง่าย ตอนนี้ Android มีข้อจำกัดมากมาย: ทำงานในพื้นหลัง การเข้าถึงระบบไฟล์ การอนุญาตที่ต้องได้รับการอนุมัติจากผู้ดูแล Google Play และอื่นๆ

กาลครั้งหนึ่งนานมาแล้ว การทำงานในพื้นหลังเป็นเรื่องง่าย ตอนนี้ Android มีข้อจำกัดมากมาย: ทำงานในพื้นหลัง การเข้าถึงระบบไฟล์ การอนุญาตที่ต้องได้รับการอนุมัติจากผู้ดูแล Google Play และอื่นๆ นักพัฒนาต้องทำงานร่วมกับพวกเขาทั้งหมด มาจำจุดเริ่มต้นและการเปลี่ยนแปลงข้อกำหนดใน Android เวอร์ชันใหม่แต่ละเวอร์ชันกัน

มันเริ่มต้นอย่างไร

ก่อน Android 5.0 เรามีชุดเครื่องมือเพื่อเรียกใช้งานในพื้นหลัง:

  • ผู้จัดการปลุก เครื่องมือที่ช่วยให้คุณตั้งปลุกในระบบของคุณและรับการแจ้งเตือน
  • ความ ตั้งใจออกอากาศ จะส่งการแจ้งเตือนเกี่ยวกับเหตุการณ์ที่เกิดขึ้นในระบบ (เช่น ข้อความใหม่)
  • บริการ — พื้นหลัง พื้นหน้า และขอบเขต
  • อแดปเตอร์ซิงค์ สิ่งโบราณพิเศษซึ่งเชื่อมต่อกับการจัดการบัญชีสำหรับการซิงโครไนซ์ข้อมูล ตัวอย่างที่ชัดเจน: เมื่อคุณตั้งค่าบัญชี Google ใน Android คุณสามารถตั้งค่าการซิงโครไนซ์ปฏิทิน รายชื่อติดต่อ และบริการอื่นๆ ภายใต้ประทุนนั้นทำงานผ่าน Sync Adapter เครื่องมือนี้ไม่ได้อยู่ถึงวันของเรา
  • ตัวจัดการ การดาวน์โหลด ยูทิลิตี้ที่ให้คุณดาวน์โหลดไฟล์ มันไม่ฉลาดมาก แต่ง่ายและสะดวก ตัวอย่างเช่น Google Play คือสิ่งที่ดาวน์โหลดไฟล์ด้วย

เมื่อผู้ใช้ทำบางอย่างพัง พวกเขาไม่โทษนักพัฒนาบุคคลที่สาม พวกเขากล่าวว่า “Android ล้าหลัง แต่ทุกอย่างรวดเร็วบน iPhone” ปรากฎว่านักพัฒนาเก่งและ Google แย่

Google ตัดสินใจจัดการกับเรื่องนี้ แต่การทำเช่นนี้ พวกเขาต้องพบกับ "ศัตรู" ที่ส่งผลกระทบต่อคุณภาพของแอปพลิเคชัน พวกเขากลายเป็น:

  • ขนาดแบตเตอรี่เทียบกับขนาดอุปกรณ์ ทุกคนต้องการอุปกรณ์ที่บางและมีน้ำหนักน้อยและจับกระชับมือ ในขณะเดียวกัน ใครๆ ก็ต้องการแบตเตอรี่ขนาดใหญ่และทรงพลัง ยากที่จะต่อสู้กับศัตรูนี้
  • ขนาดหน้าจอและคุณภาพ ทุกคนต้องการความสว่างสูงและการแสดงผลสี แต่หน้าจอเป็นสถานที่หลักในการใช้พลังงานของสมาร์ทโฟน
  • การเพิ่มประสิทธิภาพเฟิร์มแวร์ นั่นคือสิ่งที่ผู้ขายทำ
  • นักพัฒนา บุคคลที่สาม ฉันหมายถึงคุณและฉัน
  • วิธีขายสมาร์ทโฟน สมาร์ทโฟนเจ๋งๆ มีฮาร์ดแวร์ที่ทรงพลัง แถมยังกินไฟมากอีกด้วย คุณไม่สามารถขายสมาร์ทโฟนสุดเจ๋งที่มีโปรเซสเซอร์ราคาประหยัดได้ คุณต้องใส่อันที่ร้อนเหมือนเตาและใช้พลังงานอย่างบ้าคลั่ง แต่มันทำทุกอย่างได้เร็ว
  • การตลาดซึ่งพยายามหลอกความคาดหวังของเรา ด้วยสมาร์ทโฟนเจเนอเรชั่นใหม่ บริษัทต่างๆ กล่าวว่า "เราพัฒนาไปถึง 4 นาโนเมตร 3 นาโนเมตร 2 นาโนเมตร ดังนั้นเราจึงมีพลังมากขึ้น มันเพิ่มขึ้น แต่ทุกอย่างที่เราประหยัดจากการใช้พลังงาน เรามอบให้กับทรานซิสเตอร์ใหม่ และท้ายที่สุด เราก็เพิ่มการใช้พลังงานเท่านั้น

Google เบื่อกับทุกสิ่งและพวกเขาตัดสินใจว่าพวกเขาไม่สามารถพึ่งพานักพัฒนาบุคคลที่สามได้ เพราะพวกเขาเป็นโจรสลัดที่ใหญ่ที่สุดในระบบนิเวศของ Android และแล้ว Project Volta ก็มาถึง

แนวคิดของโครงการคือการให้เครื่องมือใหม่ในการทำงานและการดำเนินการในคีย์ของประสิทธิภาพการใช้พลังงาน นั่นคือ เพื่อป้องกันไม่ให้นักพัฒนาทำสิ่งที่ไม่จำเป็นมากเกินไป เพื่อไม่ให้พวกเขากินพลังงานมากเกินไป ดังนั้นการเพิ่มประสิทธิภาพครั้งใหญ่จึงเริ่มต้นขึ้น ซึ่งเป็นสิ่งที่เรากำลังจะพูดถึง

JobScheduler API บริการระบบใหม่ จุดเข้าเดียวสำหรับการทำงานเบื้องหลังส่วนใหญ่ นอกจากนี้ บริการใหม่ยังช่วยให้คุณสามารถกำหนดเงื่อนไขที่สะดวกสบายได้ ตัวอย่างเช่น การดำเนินการจะดำเนินการเมื่ออุปกรณ์เชื่อมต่อกับที่ชาร์จ ไม่มีการใช้งานโดยเจ้าของ หรือมีการเข้าถึงเครือข่ายตามข้อกำหนดที่ตั้งไว้

ส่วนที่ดีที่สุด: JobScheduler ไม่ได้ใช้ใน Android 5.0 เพราะมันบั๊กมาก ใช้งานได้เฉพาะใน Android 6.0

ประหยัดแบตเตอรี่คุณสมบัติใหม่ที่สำคัญอันดับสอง ก่อนหน้านั้น ผู้จำหน่ายมีเครื่องมือที่คล้ายคลึงกันเป็นคุณลักษณะของตนเอง ตอนนี้เครื่องมือได้กลายเป็นส่วนมาตรฐานของระบบ นี่คือสิ่งที่นำมา:

  • ลดความถี่ของ CPU
  • การลดอัตราการรีเฟรชการแสดงผล
  • การจำกัดการใช้ข้อมูลในเบื้องหลัง

แอนดรอยด์ 6.0

โหมดเคลิ้ม Android เวอร์ชันนี้เริ่มจริงจัง และทำให้เกิดแนวคิดในการปิดทุกสิ่งที่ไม่ต้องการเมื่อคุณไม่ได้ใช้อุปกรณ์

ระบบรู้ได้อย่างไรว่าต้องเปิด Doze Mode? เริ่มแรกเป็นดังนี้: หากผู้ใช้วางโทรศัพท์ลงและไม่ได้ใช้งาน คุณสามารถปิดการเข้าถึงเครือข่ายและคุณสมบัติอื่นๆ ที่ไม่จำเป็นได้ ตัวอย่างเช่น เปิดโหมดในขณะที่เจ้าของสมาร์ทโฟนหลับ Google อ้างว่า Nexus 5 ในสถานะ Doze Mode กินไฟเพียง 1% ในชั่วข้ามคืน จริง ๆ ฉันไม่เคยเห็นอย่างนั้น

ทั้งหมดนี้ได้ชำระแล้ว นอกเหนือจากข้อเท็จจริงที่ว่า Doze Mode ปิดการทำงานสูงสุดแล้ว ยังมีหน้าต่างการบำรุงรักษาอีกด้วย นั่นคือเวลาที่อุปกรณ์ออกจากโหมด Doze และอนุญาตให้นักพัฒนาทำหรือตรวจสอบบางอย่างได้ และนี่เป็นอีกครั้งที่ JobScheduler เริ่มมีบทบาทสำคัญ เพราะทุกอย่างถูกควบคุมผ่านมัน

แอพสแตนด์บาย มีโหมดประหยัดพลังงานโหมดที่สอง — ระงับกิจกรรมของแอพพลิเคชั่นที่ผู้ใช้ไม่ได้ใช้งาน หากเราย่อขนาดแอปและไม่ใช้ จะมีข้อจำกัดที่กำหนดไว้ พวกมันไม่รุนแรงเท่าในโหมด Doze แต่รบกวนการออนไลน์และลดความถี่ของทริกเกอร์ Google ไม่ได้ระบุในข้อ จำกัด เช่นเคยเพราะผู้ขายสามารถทำอะไรก็ได้

FCM High Priorityคือประเภทของการกดที่สามารถปลุกอุปกรณ์ในโหมด Doze และ App Standby และมันเป็นสิ่งสำคัญ แต่คุณต้องจำไว้ว่าถ้าคุณทำทุกวิถีทางที่มีลำดับความสำคัญสูง พวกเขาไม่จำเป็นต้องไปถึงจุดนั้น บางคนจะเริ่มถูกละเลยไม่ช้าก็เร็ว ดังนั้นคุณควรใช้มันสำหรับเหตุการณ์ที่สำคัญจริงๆ เท่านั้น ตัวอย่างเช่น เมื่อผู้ใช้ได้รับข้อความแชทซึ่งเขาได้เปิดใช้งานการแจ้งเตือน

แอนดรอยด์ 7.0

Doze on the Go เวอร์ชันที่สองของโหมด Doze หากก่อนหน้านี้อุปกรณ์เข้าสู่โหมด Doze เฉพาะเมื่อยังคงอยู่เป็นระยะเวลาหนึ่ง ตอนนี้ก็เพียงพอแล้วที่จะปิดหน้าจอและใส่สมาร์ทโฟนลงในกระเป๋าของคุณ

ใน Android 7.0 เราได้รับประสบการณ์ที่แตกต่างออกไปเล็กน้อยกับหน้าต่างการบำรุงรักษา หน้าต่างเริ่มปรากฏบ่อยขึ้น ข้อจำกัดเริ่มเบาบางลง แต่แอปพลิเคชันยังคงไม่สามารถทำงานได้อย่างถูกต้องในพื้นหลัง

ภาพประกอบวิธีที่ Doze ใช้การจำกัดกิจกรรมของระบบระดับแรกเพื่อปรับปรุงอายุแบตเตอรี่

โครงการ Svelte โครงการที่สองเพื่อลดการใช้หน่วยความจำและเพิ่มประสิทธิภาพวิธีการทำงานของแอปพลิเคชันในพื้นหลัง

ไม่มีการออกอากาศ สิ่งแรกที่เราทำในโครงการนี้คือการลบการออกอากาศทั้งหมด เราเริ่มต้นด้วย CONNECTIVITY_ACTION นี่เป็นครั้งแรกและสำคัญที่สุดเนื่องจากการออกอากาศนี้จะถูกส่งออกไปเมื่อมีการเปลี่ยนแปลงเครือข่าย ตัวอย่างเช่น เมื่อผู้ใช้เปลี่ยนจากเครือข่ายมือถือเป็น Wi-Fi Android มีคุณสมบัติพิเศษ: แม้ว่าแอปจะถูกฆ่าไปแล้ว แต่เครื่องรับพยากรณ์ได้สมัครรับการพยากรณ์บางอย่าง ระบบจะรับแอปเพื่อส่งมอบ

ลองนึกภาพเรามีแอพดังกล่าว การดึงกระบวนการขึ้นมาไม่ใช่การดำเนินการที่ถูก แต่โดยทั่วไปก็ไม่น่ากลัว แต่ถ้าเรามี 20 แอปพลิเคชันดังกล่าวล่ะ การเปลี่ยนแปลงแต่ละครั้งจะทำให้กระบวนการถูกดึงขึ้นมาและถูกฆ่า 20 ครั้ง แต่นี่ไม่ใช่เรื่องที่น่าทึ่ง สิ่งที่เลวร้ายที่สุดคือ CONNECTIVITY_ACTION ไม่เพียงถูกเรียกเมื่อออกจากเครือข่ายไปยัง Wi-Fi แต่ยังเรียกจาก 3G เป็น 4G และประเภทของการเชื่อมต่อจะกระโดดตลอดเวลาเมื่อเดินไปรอบ ๆ เมือง ลองนึกดูว่ามีเหตุการณ์ใดบ้างที่ถูกส่งไปยังระบบ นั่นเป็นสาเหตุที่ปิดการใช้งานก่อน

ACTION_NEW_PICTURE จากนั้นเราก็ปิด action_new_picture และ action_new_video ไม่ใช่เรื่องสำคัญ เพราะสามารถทำได้ด้วยวิธีอื่น เช่น ผ่าน JobScheduler ความสามารถในการตอบสนองต่อการเปลี่ยนแปลงในผู้ให้บริการเนื้อหาปรากฏขึ้น คุณสามารถส่ง Uri ด้วย ContentProvider และเมื่อการแจ้งเตือนการเปลี่ยนแปลงเกิดขึ้น ให้เรียกงาน

แอนดรอยด์ 8. 0

NoBroadcasts+ ห้ามออกอากาศทุกระบบ นักพัฒนาไม่จำเป็นต้องใช้ หรือสามารถสมัครรับข้อมูลได้เมื่อแอปกำลังทำงาน สิ่งนี้ไม่สามารถทำได้โดยปริยาย ผ่าน JobScheduler เท่านั้น มีข้อยกเว้นเหลืออยู่ แต่มีน้อยมาก:

  • ACTION_BOOT_COMPLETED;
  • ACTION_LOCAL_CHANGED;
  • ACTION_PACKAGE_DATA_CLEARED
  • ACTION_PACKAGE_ FULLY_REMOVED;
  • ACTION_NEW_OUTGOING_CALL;
  • ACTION_MEDIA_***;
  • SMS_RECEIVED_ACTION และ WAP_PUSH_RECIEVED_ACTION

ไม่มีบริการพื้นหลัง ไม่อนุญาตให้เรียกใช้บริการในเบื้องหลัง หากนักพัฒนาเริ่มบริการนี้และออกจากแอปพลิเคชัน บริการนั้นจะอยู่ได้ไม่นานนักและจะถูกบังคับฆ่า หากคุณพยายามเริ่มบริการปกติเมื่อแอปพลิเคชันอยู่ในพื้นหลัง แอปพลิเคชันก็จะหยุดทำงานเช่นกัน

อัพเดทJobScheduler ประการแรก มีหน่วยความจำว่างไม่เพียงพอ (นั่นคือลักษณะของเงื่อนไข) Google ไม่ได้บอกว่าหน่วยความจำเพียงพอ ไม่ใช่แบตเตอรี่ต่ำ — สิ่งนี้หมายความว่าอย่างไร อธิบายอีกครั้งไม่ได้ เห็นได้ชัดว่าเป็นเปอร์เซ็นต์วิกฤตเมื่อแบตเตอรี่เปลี่ยนเป็นสีแดง

เครือ ข่ายมิเตอร์ สิ่งใหม่ที่ยอดเยี่ยมซึ่งเชื่อมโยงกับต้นทุน เมื่อเราเชื่อมต่อกับเครือข่ายในการตั้งค่า เครือข่ายเซลลูลาร์จะมีค่าใช้จ่ายตามค่าเริ่มต้น ซึ่งหมายความว่าเราต้องจ่ายสำหรับการรับส่งข้อมูล Wi-Fi ตามค่าเริ่มต้นจะถือว่าไม่มีภาษี แต่คุณสามารถเปลี่ยนแปลงได้ในการตั้งค่า

บริการเบื้องหน้า . ขณะนี้จำเป็นต้องเรียกใช้บริการพื้นหลังอย่างชัดเจน ก่อนหน้านี้คุณต้องเรียกใช้บริการดังกล่าวแล้วบอกว่าเป็นเบื้องหน้า ตอนนี้ เนื่องจากบริการพื้นหลังถูกฆ่า คุณต้องพูดอย่างชัดเจนว่า: ฉันจะเรียกใช้บริการเบื้องหน้า และโค้ดจะกลายเป็นแบบนี้

// Old way
context.startService(Intent(context, MediaService::class))

// New way in Android 8.0
context.startForegroundService(Intent(context, MediaService::class))

class MediaService : Service() {

    override fun onCreate() {
        super.onCreate()
        // Must be called up to 5 seconds after startForegroundService
        startForeground(NOTIFICATION_ID, newOngoingNotification())
    }

    fun newOngoingNotification() : Notification

    companion object {
        const val NOTIFICATION_ID
    }
}

สิ่งสำคัญอย่างหนึ่งที่ต้องจำไว้คือในแอปพลิเคชันใดๆ เมื่อบริการ การเปิดใช้งาน หรือสิ่งอื่นใดเริ่มทำงาน แอปพลิเคชันจะเริ่มโหลดก่อน คุณสร้าง nits ที่แตกต่างกันกี่รายการในแอปพลิเคชัน เรามักจะใส่ห้องสมุดทั้งหมดไว้ในนั้น และประเด็นก็คือต้องลดระดับเสียงให้เหลือน้อยที่สุด

พูดอย่างคร่าว ๆ หากคุณมีการเริ่มต้นที่จำเป็นสำหรับ UI คุณไม่จำเป็นต้องทำในแอปพลิเคชันเพราะเป็นทางเลือกและสามารถเรียกใช้บริการบางอย่างได้ คุณต้องทำทุกอย่างเป็นพื้นหลังหรือทำสิ่งที่ขี้เกียจซึ่งเป็นแนวทางใหม่

อาจดูเหมือนห้าวินาทีมาก แต่เชื่อฉันเถอะ สำหรับอุปกรณ์ Android 8.0 ราคาประหยัด มันคือชั่วนิรันดร์ รหัสอาจไม่ทำงานและจะมีปัญหา โดยเฉพาะอย่างยิ่งหากมีการทำงานของเครือข่ายในแอป ดังนั้นคุณไม่ควรลืมที่จะเพิ่มประสิทธิภาพ

ข้อ จำกัด การเข้าถึงตำแหน่ง ข้อจำกัดอื่นที่เกี่ยวข้องกับความปลอดภัยและการประหยัดแบตเตอรี่ หากแอปพลิเคชันอยู่ในพื้นหลัง แอปพลิเคชันจะได้รับการอัปเดตไม่เกินสองสามครั้งต่อชั่วโมง เราไม่รู้ว่ากี่ครั้งกันแน่

การลบ WakeLock โดยระบบ เมื่อแอพเข้าสู่สถานะแคช (ไม่มีส่วนประกอบ Android ที่ใช้งานอยู่) WakeLocks ทั้งหมดที่ระบบจับไว้จะถูกปล่อย WakeLock เป็น API พิเศษที่ช่วยให้ระบบสามารถบล็อกสิ่งที่ไม่จำเป็นได้ ตัวอย่างเช่น หากระบบเห็นว่าไม่มีสิ่งใดถูกใช้งานในขณะนี้ และอุปกรณ์เข้าสู่โหมดสลีป คุณสามารถปิด CPU ได้ เหมือนกับว่า WakeLock กำลังบอกระบบว่าอย่าปิดโปรเซสเซอร์ ฉันจะใช้มัน ดังนั้นจึงมีการโหลดฮาร์ดแวร์ และหากแอปพลิเคชันเข้าสู่สถานะแคช แสดงว่าไม่มีบริการและกิจกรรมที่ใช้งานอยู่ ไม่มีใครโทรหาผู้ให้บริการเนื้อหาหรือผู้รับออกอากาศ WakeLock ทั้งหมดจะถูกลบออกโดยอัตโนมัติ

แอนดรอยด์ 9.0

ที่ฝากข้อมูลสแตนด์บายของแอป บัคเก็ตที่เรียกว่าเป็นวิธีการใหม่ในการหยุดแอพและวิธี หากแอปเคยเข้าสู่พื้นหลัง ระบบจะถือว่าแอปนั้นต้องหยุดทำงาน ขณะนี้ระบบจะวิเคราะห์วิธีการใช้งานแอปพลิเคชันและจัดหมวดหมู่แอปพลิเคชัน:

  • ใช้งานอยู่ — แอปพลิเคชันกำลังทำงานโดยผู้ใช้หรือแอปพลิเคชันอื่นในสถานะใช้งานอยู่
  • ชุดการทำงาน — มีการใช้งานแอปพลิเคชันบ่อยครั้ง แต่ผู้ใช้ไม่ได้ใช้งานอยู่ในขณะนี้
  • บ่อย — มีการใช้งานแอปเป็นประจำ แต่ไม่จำเป็นต้องทุกวัน
  • หายาก — แอปพลิเคชั่นนี้ไม่ค่อยได้ใช้
  • ไม่เคย — ติดตั้งแอปพลิเคชันแล้ว แต่ผู้ใช้ไม่เคยเรียกใช้ ปิดการใช้งานทั้งหมด
  • แต่ละที่เก็บข้อมูลสอดคล้องกับชุดข้อจำกัดเฉพาะ
  • ระบบทำให้แอพเข้าสู่โหมดสแตนด์บายแอพมากขึ้น
  • ข้อจำกัดมีผลกับทุกแอพ โดยไม่คำนึงถึง targetSdk
  • การเข้าถึงแอพอาจหายไปเมื่อปิดหน้าจอ
  • แอปพื้นหลังไม่สามารถเข้าถึงเครือข่ายได้
  • รายการเพิ่มเติม — ผู้ขายสามารถเพิ่มหรือเปลี่ยนแปลงบางสิ่งได้

ข้อจำกัดในการ เข้าถึงเซนเซอร์ แอปพลิเคชันในพื้นหลังไม่สามารถเข้าถึงไมโครโฟนและกล้องได้ เซ็นเซอร์จะไม่ส่งข้อมูลใดๆ เลยหรือส่งข้อมูลด้วยความถี่ที่ช้า เราไม่รู้ว่ามันช้าแค่ไหน

อัพเดท JobScheduler ตอนนี้ให้ข้อมูลเกี่ยวกับขนาดของไฟล์ที่ดาวน์โหลด จากข้อมูลนี้ ระบบอาจเข้าใจ: หากคุณโหลดไฟล์ขนาดเล็ก คุณสามารถข้ามได้อย่างรวดเร็ว และหากไฟล์มีขนาดใหญ่ ควรรอเครือข่ายที่ไม่ตรงเป้าหมายและระดับการชาร์จที่สูงจะดีกว่า

นอกจากนี้ยังมีสิ่งสำคัญสำหรับการโหลดเนื้อหาล่วงหน้า หากแอปจำเป็นต้องโหลดข้อมูลล่วงหน้าเพื่อแสดง เช่น หน้าจอหลัก คุณสามารถทำเครื่องหมายงานด้วยแฟล็กใหม่นี้ และ JobScheduler จะเพิ่มลำดับความสำคัญของงานนั้น

แอนดรอยด์ 10

บริการเบื้องหน้า . คุณลักษณะใหม่ที่ช่วยให้ระบบเข้าใจว่าเหตุใดจึงจำเป็นต้องมีบริการเบื้องหน้าและจัดลำดับความสำคัญก่อนหลัง มีทั้งหมดแปดประเภทไม่ควรมีประเภทอื่น:

  • กล้อง — ใช้กล้องถ่ายรูป ถ่ายภาพ และบันทึกวิดีโอ
  • ConnectedDevice — ทำงานร่วมกับอุปกรณ์บลูทูธ รถยนต์ และสิ่งอื่นๆ
  • DataSync — ส่งข้อมูลผ่านเครือข่าย สำรอง/กู้คืน ดาวน์โหลดไฟล์
  • ตำแหน่ง — GPS แผนที่ หรือการนำทาง
  • MediaPlayback — เล่นเสียงและวิดีโอ;
  • MediaProjection — ควบคุมการฉายสื่อ เช่น การบันทึกวิดีโอจากหน้าจอ การจับภาพหน้าจอ และอื่นๆ
  • ไมโครโฟน — ใช้ไมโครโฟนหรือบันทึกเสียง
  • PhoneCall — การดำเนินการเกี่ยวกับการโทรศัพท์และการสนทนาทางวิดีโอ และการสื่อสารที่คล้ายคลึงกัน

class MediaService : Service() {

    override fun onCreate() {
        super.onCreate() 
        startForeground(NOTIF_ID, newNotification(), ServiceInfo.FOREGROUND_SERVICE_TYPE_MEDIA_PLAYBACK)

        startForeground(NOTIF_ID, newNotification(), ServiceInfo.FOREGROUND_SERVICE_TYPE_MANIFEST)

        startForeground(NOTIF_ID, newNotification(), ServiceInfo.FOREGROUND_SERVICE_TYPE_NONE)
    }
}

การเข้าถึงตำแหน่งจากพื้นหลัง มีการอนุญาตครั้งที่สามสำหรับท้องที่ และตอนนี้เราต้องแจ้งว่าเรากำลังจะทำงานอยู่เบื้องหลังเช่นกัน นอกจากนี้ เราจำเป็นต้องได้รับอนุญาตแยกต่างหากเพื่อทำงานในพื้นหลังจากผู้ใช้

แอนดรอยด์ 11

สิ่งที่น่าสนใจที่สุดและน่าผิดหวังที่สุดสำหรับฉันคือ Android 11 ไม่ได้จำกัดอะไรเลย ดังนั้นเราไปต่อที่…

แอนดรอยด์ 12

ที่เก็บข้อมูลการสแตนด์ บายของแอปที่ถูกจำกัด บัคเก็ตที่ยากที่สุด: หากแอปใช้ทรัพยากรระบบจำนวนมากหรือทำงานในลักษณะที่ไม่พึงปรารถนา ระบบจะนำมันไปไว้ที่นั่น ถ้อยคำไม่ชัดเจน แต่ส่วนใหญ่น่าจะเกี่ยวกับมัลแวร์

ข้อจำกัดในการเรียกใช้บริการเบื้องหน้า แอปพลิเคชันในพื้นหลังไม่สามารถเรียกใช้บริการเบื้องหน้าได้เว้นแต่จะมีข้อยกเว้นบางประการ รายการข้อยกเว้นสั้นมาก

สิทธิ์ในการปลุกที่แน่นอน ก่อนหน้านี้คุณสามารถทำสิ่งนี้ได้ตามต้องการ แต่ตอนนี้มีการอนุญาตแล้ว และไม่ใช่การอนุญาตรันไทม์ แต่เป็นสิ่งที่น่าสนใจ เช่น Picture-in-Picture ดังนั้นเราต้องบอกผู้ใช้: ไปที่การตั้งค่าระบบและอนุญาตให้แอปพลิเคชันของฉันทำสิ่งนี้ ในแง่หนึ่งมันไม่สะดวก แต่อีกแง่หนึ่งก็มีประโยชน์ นักพัฒนาหลายคนต้องรับมือกับข้อเท็จจริงที่ว่า Exact Alarms ทำงานอย่างคาดเดาไม่ได้หรือไม่ทำงานเลย และการเรียงสับเปลี่ยนคือการกำหนดมาตรฐานและสัญญาณที่ชัดเจนของระบบ สิ่งสำคัญคือต้องจำไว้ว่าการเตือนที่แน่นอนนั้นไม่จำเป็นต้องถูกกระตุ้นในเวลาที่เหมาะสม อาจเกิดขึ้นภายในไม่กี่นาทีหรือมากกว่านั้นในภายหลัง

งานด่วน . ประเภทงานใหม่สำหรับงานสำคัญที่ต้องทำให้เสร็จทันที คุณไม่สามารถละเมิดได้ นี่คือสัญญาณของงานดังกล่าว:

  • เสร็จเร็วที่สุด;
  • มีข้อ จำกัด น้อยลงในโหมด Doze และโหมดประหยัดแบตเตอรี่
  • ไม่ได้รับผลกระทบจากการจำกัดการเข้าถึงเครือข่ายที่กำหนดโดยโหมด Doze, App Standby และโหมดประหยัดแบตเตอรี่
  • มีโอกาสถูกฆ่าน้อยกว่างานปกติ
  • การจำกัดการเข้าถึงตำแหน่งในพื้นหลังยังคงมีอยู่
  • ต้องการความพร้อมใช้งานของเครือข่าย จำนวนพื้นที่ว่าง และการบันทึกงานระหว่างการรีบูตอุปกรณ์เท่านั้นจึงจะทำงานได้
  • ระบบจะจัดสรรโควต้าสำหรับจำนวนงานเร่งด่วนที่รันพร้อมกันสำหรับแอปพลิเคชัน
  • โควต้าไม่ได้ใช้กับแอปพลิเคชันที่ใช้งานอยู่
  • อาจไม่เริ่มทำงานทันทีหากอุปกรณ์ไม่ว่างเกินไป หรือหากงานที่ระบุสำหรับการดำเนินการไม่สามารถดำเนินการได้
  • มีเวลาดำเนินการจำกัดอย่างน้อยหนึ่งนาที
  • หากแอปพลิเคชันมีโควต้าเหลืออยู่ Expedited Job อาจทำงานได้นานขึ้น

ตัวจัดการงานบริการเบื้องหน้า ขณะนี้ผู้ใช้สามารถดูในหน้าต่างพิเศษในแถบการแจ้งเตือนว่าแอปพลิเคชันใดกำลังทำบางอย่างในเบื้องหน้า นั่นคือพวกเขาถูกย่อให้เล็กสุด แต่กำลังพยายามทำบางสิ่ง ผู้ใช้สามารถหยุดได้ด้วยตนเอง

ปุ่มพิเศษหยุดแอปพลิเคชันอย่างแรง ไม่เหมือนบังคับหยุดในการตั้งค่า แต่ก็ยังหยุดได้อย่างสมบูรณ์ แม้จะถูกลดทอนลงเพียงใดก็ตาม

การตั้งค่าการใช้งานแบตเตอรี่สำหรับแต่ละแอพพลิเคชั่น ตามค่าเริ่มต้น แอปพลิเคชันทั้งหมดจะได้รับการปรับให้เหมาะสม นั่นคือการรักษาสมดุลระหว่างรันไทม์ในพื้นหลังและการใช้แบตเตอรี่ ผู้ใช้สามารถเลือกหนึ่งในสองการตั้งค่า:

  • ไม่จำกัด — “ทำอะไรก็ได้ ฉันไม่สน”
  • จำกัด — เมื่อแอปพลิเคชันไม่สามารถทำอะไรได้เลยในพื้นหลัง
  • ไม่สามารถเรียกใช้บริการเบื้องหน้า;
  • บริการเบื้องหน้าที่กำลังทำงานอยู่จะถูกลบออกจากเบื้องหน้า
  • จะไม่มีการเตือนใด ๆ เกิดขึ้น
  • งานจะไม่เริ่ม

การแจ้งเตือนบริการเบื้องหน้ายาวเกินไป ระบบจะตรวจสอบว่าแอพทำงานในโหมดนี้นานเกินไปหรือไม่ และแนะนำให้คุณหยุด ด้วยเหตุผลบางประการ Google จึงคิดว่าระยะเวลานานคือ 20 ชั่วโมงในกรอบเวลา 24 ชั่วโมง มันแปลก; ฉันมีช่วงเวลาที่ยากลำบากในการจินตนาการถึงแอปที่ทำงานแบบนั้น คุณสมบัติของการทำงานในโหมดนี้:

  • สามารถแสดงการแจ้งเตือนได้ไม่เกินหนึ่งครั้งทุกๆ 30 วัน
  • การแจ้งเตือนจะไม่แสดงหากมองเห็นการแจ้งเตือนที่เกี่ยวข้องกับบริการเบื้องหน้า
  • การยกเว้นคือบริการประเภท MediaPlayback และ Location;
  • แอปพลิเคชันระบบ แอปพลิเคชันเฉพาะเป้าหมาย และอุปกรณ์ในโหมดสาธิตก็เป็นข้อยกเว้นเช่นกัน

นอกเหนือจากนั้น เราได้เพิ่มลำดับความสำคัญของงาน นี่คือค่าคงที่พิเศษที่ช่วยในการจัดเรียงงานทั้งหมดภายในแอปพลิเคชันเดียวกันและจัดลำดับความสำคัญของการดำเนินการ

ในช่วงแปดปีที่ผ่านมา Google พยายามจำกัดนักพัฒนาซอฟต์แวร์และบังคับให้ใช้ API พิเศษ เนื่องจากเสรีภาพในการเลือกเครื่องมือทำให้เกิดความสับสนวุ่นวายบนอุปกรณ์ต่างๆ

การป้องกันขั้นที่สองคือ Google Play ซึ่งไม่อนุญาตให้เผยแพร่แอปด้วยสิทธิ์ส่วนบุคคลโดยไม่มีการตรวจสอบพิเศษจากร้านค้า จากนี้ไปมีแต่จะรุนแรงขึ้น เนื่องจาก API เริ่มต้นใหม่ทั้งหมดมุ่งเน้นไปที่ข้อจำกัด การประหยัดแบตเตอรี่ และการควบคุมแอปที่ชัดเจนโดยระบบ

นี่เป็นเหตุผล เพราะในตอนเริ่มต้น Google ได้สืบทอดซอร์สโค้ดมา จำเป็นต้องดึงดูดนักพัฒนาและผู้ขายให้มาเติม Android ภายในปี 2014 บริษัทได้แก้ปัญหานี้และเปลี่ยนเวกเตอร์เพื่อให้มั่นใจถึงความน่าเชื่อถือ ความปลอดภัย และประสบการณ์ผู้ใช้ที่น่าพึงพอใจกับอุปกรณ์ Android