Android14之模板类StaticString16解析(二百零一)

2024-03-25 11:04

本文主要是介绍Android14之模板类StaticString16解析(二百零一),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

简介: CSDN博客专家,专注Android/Linux系统,分享多mic语音方案、音视频、编解码等技术,与大家一起成长!

优质专栏:Audio工程师进阶系列原创干货持续更新中……】🚀
优质专栏:多媒体系统工程师系列原创干货持续更新中……】🚀

人生格言: 人生从来没有捷径,只有行动才是治疗恐惧和懒惰的唯一良药.

更多原创,欢迎关注:Android系统攻城狮

欢迎关注Android系统攻城狮

1.前言

本篇目的:Android14之模板类StaticString16解析

2.StaticString16模板类介绍

  • Android 系统是一个基于 Linux 内核的开源操作系统,广泛应用于各种移动设备。在 Android 开发过程中,为了提高开发效率和可维护性,系统提供了一系列模板类,以简化特定类型的编程任务。StaticString16 是 Android 系统中一个用于处理 16 位字符串常量的模板类。
  • StaticString16 模板类的作用类似于 C++ 中的字符串常量,但它仅支持 16 位字符。在 Android 开发中,我们经常需要处理多种语言的字符串,而不同语言的字符集可能不同。StaticString16 正是为了解决这个问题而设计的。使用 StaticString16 可以让开发者编写更加通用和高效的代码,因为它是专门针对 16 位字符设计的。
  • StaticString16 模板类具有以下特点:
  1. 高效性:由于 StaticString16 专门针对 16 位字符设计,因此它的存储和处理效率更高。
  2. 可移植性:StaticString16 模板类可以处理多种语言的字符串,使得开发者编写的代码具有更好的可移植性。
  3. 安全性:StaticString16 模板类是 Android 系统的一部分,因此它的安全性和稳定性得到了保证。
  4. 易用性:StaticString16 模板类提供了简单的接口,使得开发者可以轻松地使用它来处理 16 位字符串常量。
  • 在 Android 开发过程中,使用 StaticString16 模板类可以带来很多好处。例如,在定义字符串常量时,我们可以使用 StaticString16 类型来指定字符串的长度为 16 位,这样可以确保字符串在不同的设备上都能正确显示。此外,使用 StaticString16 还可以避免在字符串常量中出现不必要的空格和换行符等问题。
  • 总之,StaticString16 是 Android 系统中一个非常有用的模板类。它专门用于处理 16 位字符串常量,具有高效、可移植、安全和易用等特点。在 Android 开发过程中,合理地使用 StaticString16 模板类可以提高开发效率,降低软件维护成本。

3.StaticString16模板类分析

<1>.StaticString16模板类实现

template <size_t N>
class StaticString16 : public String16 {
public:constexpr StaticString16(const char16_t (&s)[N]) : String16(mData), mData(makeStaticData(s)) {}constexpr StaticString16(const StaticString16<N>& other): String16(mData), mData(other.mData) {}constexpr StaticString16(const StaticString16<N>&&) = delete;static void* operator new(std::size_t) = delete;private:const StaticData<N> mData;
};

StaticString16模板类继承自String16类。
下面看下String16构造函数。

<2>.String16定义

class String16
{
public:String16();String16(const String16& o);String16(String16&& o) noexcept;String16(const String16& o,size_t len,size_t begin=0);explicit                    String16(const char16_t* o);explicit                    String16(const char16_t* o, size_t len);explicit                    String16(const String8& o);explicit                    String16(const char* o);explicit                    String16(const char* o, size_t len);~String16();inline  const char16_t*     string() const;private:static inline std::string   std_string(const String16& str);
public:size_t              size() const;void                setTo(const String16& other);status_t            setTo(const char16_t* other);status_t            setTo(const char16_t* other, size_t len);status_t            setTo(const String16& other,size_t len,size_t begin=0);status_t            append(const String16& other);status_t            append(const char16_t* other, size_t len);inline  String16&           operator=(const String16& other);String16&           operator=(String16&& other) noexcept;inline  String16&           operator+=(const String16& other);inline  String16            operator+(const String16& other) const;status_t            insert(size_t pos, const char16_t* chrs);status_t            insert(size_t pos,const char16_t* chrs, size_t len);ssize_t             findFirst(char16_t c) const;ssize_t             findLast(char16_t c) const;bool                startsWith(const String16& prefix) const;bool                startsWith(const char16_t* prefix) const;bool                contains(const char16_t* chrs) const;status_t            replaceAll(char16_t replaceThis,char16_t withThis);inline  int                 compare(const String16& other) const;inline  bool                operator<(const String16& other) const;inline  bool                operator<=(const String16& other) const;inline  bool                operator==(const String16& other) const;inline  bool                operator!=(const String16& other) const;inline  bool                operator>=(const String16& other) const;inline  bool                operator>(const String16& other) const;inline  bool                operator<(const char16_t* other) const;inline  bool                operator<=(const char16_t* other) const;inline  bool                operator==(const char16_t* other) const;inline  bool                operator!=(const char16_t* other) const;inline  bool                operator>=(const char16_t* other) const;inline  bool                operator>(const char16_t* other) const;inline                      operator const char16_t*() const;bool                isStaticString() const;private:static constexpr uint32_t kIsSharedBufferAllocated = 0x80000000;/** alloc() returns void* so that SharedBuffer class is not exposed.*/static void* alloc(size_t size);static char16_t* allocFromUTF8(const char* u8str, size_t u8len);static char16_t* allocFromUTF16(const char16_t* u16str, size_t u16len);void* edit();void* editResize(size_t new_size);void acquire();void release();size_t staticStringSize() const;const char16_t* mString;protected:template <size_t N>struct StaticData {// The high bit of 'size' is used as a flag.static_assert(N - 1 < kIsSharedBufferAllocated, "StaticString16 too long!");constexpr StaticData() : size(N - 1), data{0} {}const uint32_t size;char16_t data[N];constexpr StaticData(const StaticData<N>&) = default;};/** Helper function for constructing a StaticData object.*/template <size_t N>static constexpr const StaticData<N> makeStaticData(const char16_t (&s)[N]) {StaticData<N> r;for (size_t i = 0; i < N - 1; ++i) r.data[i] = s[i];return r;}template <size_t N>explicit constexpr String16(const StaticData<N>& s) : mString(s.data) {}
};

重点关注下: String16(const String16& o);构造函数实现

<3>.String16构造函数

system/core/libutils/String16.cpp

String16::String16(const String16& o) : mString(o.mString)
{acquire();
}

将传入的String16对象变量o,将o.mString赋值给mString类成员变量,mString的定义如下所示。

const char16_t* mString;

char16_t类型占2个byte。

这篇关于Android14之模板类StaticString16解析(二百零一)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/844786

相关文章

Java中Redisson 的原理深度解析

《Java中Redisson的原理深度解析》Redisson是一个高性能的Redis客户端,它通过将Redis数据结构映射为Java对象和分布式对象,实现了在Java应用中方便地使用Redis,本文... 目录前言一、核心设计理念二、核心架构与通信层1. 基于 Netty 的异步非阻塞通信2. 编解码器三、

Java HashMap的底层实现原理深度解析

《JavaHashMap的底层实现原理深度解析》HashMap基于数组+链表+红黑树结构,通过哈希算法和扩容机制优化性能,负载因子与树化阈值平衡效率,是Java开发必备的高效数据结构,本文给大家介绍... 目录一、概述:HashMap的宏观结构二、核心数据结构解析1. 数组(桶数组)2. 链表节点(Node

Java 虚拟线程的创建与使用深度解析

《Java虚拟线程的创建与使用深度解析》虚拟线程是Java19中以预览特性形式引入,Java21起正式发布的轻量级线程,本文给大家介绍Java虚拟线程的创建与使用,感兴趣的朋友一起看看吧... 目录一、虚拟线程简介1.1 什么是虚拟线程?1.2 为什么需要虚拟线程?二、虚拟线程与平台线程对比代码对比示例:三

一文解析C#中的StringSplitOptions枚举

《一文解析C#中的StringSplitOptions枚举》StringSplitOptions是C#中的一个枚举类型,用于控制string.Split()方法分割字符串时的行为,核心作用是处理分割后... 目录C#的StringSplitOptions枚举1.StringSplitOptions枚举的常用

Python函数作用域与闭包举例深度解析

《Python函数作用域与闭包举例深度解析》Python函数的作用域规则和闭包是编程中的关键概念,它们决定了变量的访问和生命周期,:本文主要介绍Python函数作用域与闭包的相关资料,文中通过代码... 目录1. 基础作用域访问示例1:访问全局变量示例2:访问外层函数变量2. 闭包基础示例3:简单闭包示例4

MyBatis延迟加载与多级缓存全解析

《MyBatis延迟加载与多级缓存全解析》文章介绍MyBatis的延迟加载与多级缓存机制,延迟加载按需加载关联数据提升性能,一级缓存会话级默认开启,二级缓存工厂级支持跨会话共享,增删改操作会清空对应缓... 目录MyBATis延迟加载策略一对多示例一对多示例MyBatis框架的缓存一级缓存二级缓存MyBat

前端缓存策略的自解方案全解析

《前端缓存策略的自解方案全解析》缓存从来都是前端的一个痛点,很多前端搞不清楚缓存到底是何物,:本文主要介绍前端缓存的自解方案,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录一、为什么“清缓存”成了技术圈的梗二、先给缓存“把个脉”:浏览器到底缓存了谁?三、设计思路:把“发版”做成“自愈”四、代码

Java集合之Iterator迭代器实现代码解析

《Java集合之Iterator迭代器实现代码解析》迭代器Iterator是Java集合框架中的一个核心接口,位于java.util包下,它定义了一种标准的元素访问机制,为各种集合类型提供了一种统一的... 目录一、什么是Iterator二、Iterator的核心方法三、基本使用示例四、Iterator的工

使用Java填充Word模板的操作指南

《使用Java填充Word模板的操作指南》本文介绍了Java填充Word模板的实现方法,包括文本、列表和复选框的填充,首先通过Word域功能设置模板变量,然后使用poi-tl、aspose-words... 目录前言一、设置word模板普通字段列表字段复选框二、代码1. 引入POM2. 模板放入项目3.代码

Java JDK Validation 注解解析与使用方法验证

《JavaJDKValidation注解解析与使用方法验证》JakartaValidation提供了一种声明式、标准化的方式来验证Java对象,与框架无关,可以方便地集成到各种Java应用中,... 目录核心概念1. 主要注解基本约束注解其他常用注解2. 核心接口使用方法1. 基本使用添加依赖 (Maven