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 OOM问题定位与解决方案超详细解析

《线上JavaOOM问题定位与解决方案超详细解析》OOM是JVM抛出的错误,表示内存分配失败,:本文主要介绍线上JavaOOM问题定位与解决方案的相关资料,文中通过代码介绍的非常详细,需要的朋... 目录一、OOM问题核心认知1.1 OOM定义与技术定位1.2 OOM常见类型及技术特征二、OOM问题定位工具

深度解析Python中递归下降解析器的原理与实现

《深度解析Python中递归下降解析器的原理与实现》在编译器设计、配置文件处理和数据转换领域,递归下降解析器是最常用且最直观的解析技术,本文将详细介绍递归下降解析器的原理与实现,感兴趣的小伙伴可以跟随... 目录引言:解析器的核心价值一、递归下降解析器基础1.1 核心概念解析1.2 基本架构二、简单算术表达

深度解析Java @Serial 注解及常见错误案例

《深度解析Java@Serial注解及常见错误案例》Java14引入@Serial注解,用于编译时校验序列化成员,替代传统方式解决运行时错误,适用于Serializable类的方法/字段,需注意签... 目录Java @Serial 注解深度解析1. 注解本质2. 核心作用(1) 主要用途(2) 适用位置3

Java MCP 的鉴权深度解析

《JavaMCP的鉴权深度解析》文章介绍JavaMCP鉴权的实现方式,指出客户端可通过queryString、header或env传递鉴权信息,服务器端支持工具单独鉴权、过滤器集中鉴权及启动时鉴权... 目录一、MCP Client 侧(负责传递,比较简单)(1)常见的 mcpServers json 配置

从原理到实战解析Java Stream 的并行流性能优化

《从原理到实战解析JavaStream的并行流性能优化》本文给大家介绍JavaStream的并行流性能优化:从原理到实战的全攻略,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的... 目录一、并行流的核心原理与适用场景二、性能优化的核心策略1. 合理设置并行度:打破默认阈值2. 避免装箱

Maven中生命周期深度解析与实战指南

《Maven中生命周期深度解析与实战指南》这篇文章主要为大家详细介绍了Maven生命周期实战指南,包含核心概念、阶段详解、SpringBoot特化场景及企业级实践建议,希望对大家有一定的帮助... 目录一、Maven 生命周期哲学二、default生命周期核心阶段详解(高频使用)三、clean生命周期核心阶

深入解析C++ 中std::map内存管理

《深入解析C++中std::map内存管理》文章详解C++std::map内存管理,指出clear()仅删除元素可能不释放底层内存,建议用swap()与空map交换以彻底释放,针对指针类型需手动de... 目录1️、基本清空std::map2️、使用 swap 彻底释放内存3️、map 中存储指针类型的对象

Java Scanner类解析与实战教程

《JavaScanner类解析与实战教程》JavaScanner类(java.util包)是文本输入解析工具,支持基本类型和字符串读取,基于Readable接口与正则分隔符实现,适用于控制台、文件输... 目录一、核心设计与工作原理1.底层依赖2.解析机制A.核心逻辑基于分隔符(delimiter)和模式匹

Java+AI驱动实现PDF文件数据提取与解析

《Java+AI驱动实现PDF文件数据提取与解析》本文将和大家分享一套基于AI的体检报告智能评估方案,详细介绍从PDF上传、内容提取到AI分析、数据存储的全流程自动化实现方法,感兴趣的可以了解下... 目录一、核心流程:从上传到评估的完整链路二、第一步:解析 PDF,提取体检报告内容1. 引入依赖2. 封装

深度解析Python yfinance的核心功能和高级用法

《深度解析Pythonyfinance的核心功能和高级用法》yfinance是一个功能强大且易于使用的Python库,用于从YahooFinance获取金融数据,本教程将深入探讨yfinance的核... 目录yfinance 深度解析教程 (python)1. 简介与安装1.1 什么是 yfinance?