MySql中varchar类型长度的含义、Java中String长度的含义

14 篇文章 0 订阅
2 篇文章 0 订阅

varchar(5)表示的是字符长度5,不是字节数

𤭢是一个字符占用了四个字节,我们存到数据库中也是最多能存5个𤭢
在这里插入图片描述

String length()方法返回的是代码单元数量代码单元我们

上图是String类中length源码,注意红框部分是代码单元的数量,那我们知道String的value其实是一个char[],那我们就可以推出 char = 代码单元

@Test
public void stringLengthTest() {
  //𤭢 \uD852\uDF62
  String str = "𤭢𤭢𤭢𤭢𤭢";
  // 输出10
  System.out.println(str.length());
  // 输出5
  System.out.println(str.codePointCount(0, str.length()));
}

这个例子就能看出因为1𤭢 = 2char,所以length返回的是10。

String类中还有一个codePointAt()这个返回的是代码点数量,也就是我们看到的字符数量

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值