JDK源码学习--AbstractStringBuilder reverse()

本文介绍了一个字符串反转方法,并特别关注了Unicode字符中的代理对处理。通过具体代码实现了解释如何正确反转包含高代理和低代理字符的字符串。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

public AbstractStringBuilder reverse() {
	//是否含代理字符
	//高代理highSurrogate和低代理lowSurrogate概念请另查询char与Unicode字符
	boolean hasSurrogate = false;
	//定义一个变量表示长度-1
	int n = count - 1;
	//j初始化,长度-2再算术右移一位 j = (count-2)/2
	//偶数长度,遍历一半次数,对调替换
	//奇数长度,遍历一半-1次数,对调替换,中间值不用替换
	for (int j = (n-1) >> 1; j >= 0; --j) {
		char temp = value[j];
		char temp2 = value[n - j];
		//如果无代理
		if (!hasSurrogate) {
			hasSurrogate = (temp >= Character.MIN_SURROGATE && temp <= Character.MAX_SURROGATE)
				|| (temp2 >= Character.MIN_SURROGATE && temp2 <= Character.MAX_SURROGATE);
		}
		value[j] = temp2;
		value[n - j] = temp;
	}
	if (hasSurrogate) {
		// Reverse back all valid surrogate pairs
		//反转回所有有效代理对
		//高代理+低代理组合表示一个字符
		for (int i = 0; i < count - 1; i++) {
			char c2 = value[i];
			if (Character.isLowSurrogate(c2)) {
				char c1 = value[i + 1];
				if (Character.isHighSurrogate(c1)) {
					value[i++] = c1;
					value[i] = c2;
				}
			}
		}
	}
	return this;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值