String的坑

    想必大家在熟悉不过了,不错今天就遇到了这个万年坑,哪怕喜欢翻源码的人,也不屑一顾翻它的源码,良言相劝最好翻下源码。

   1. String为啥被定义为final ?

   2. String是线程安全的么 ?

   3. String的设计思想是什么 ?

   4. 偏移量是什么 ?

   在不看下面解释的时候自己想想,是不是真的了解,每天都能遇见的String这个对象 ???

   先说String是线程安全的么?

   答:是线程安全的,都定义final(不可变)了,这都不安全什么才算安全,必须要看到 synchronized ?

   再说String为啥被定义为final?

      答:因为这样有助于共享,提高性能,可以将字符串对象保存在字符串常量池中以供与字面值相同字符串对象共享。如果String对象是可变的,那就不能这样共享,因为一旦对某一个String类型变量引用的对象值改变,将同时改变一起共享字符串对象的其他 String类型变量所引用的对象的值。String本质是个char数组. final修饰的字段创建以后就不可改变,String设成final禁止继承,避免被其它类继承后破坏。

    /** The value is used for character storage. */
     private final char value[];

    String的设计思想是什么?

    答:java程序语言的许多特性依赖于不可变的String对象,若String允许被继承, 由于它的高度被使用率, 可能会降低程序的性能

    偏移量是什么?

    答:就是在数组中(int[] ary={1,2,3})。变量名(ary)保存的是数组的首地址,数组实际的内存是一块连续的内存区域。所以ary[i]就是相对数组首地址的便宜量,即就是根据首地址和偏移量([i])就可以知道偏移后的地址,这也是为什么在java中你可以用ary[i]访问元素的根本原因。

    

   

原文地址:https://www.cnblogs.com/Snail-1174158844/p/10159462.html

时间: 2024-10-20 04:12:36

String的坑的相关文章

[Swift]String的坑

在String中获取某个位置的Character,各Swift版本的差异 Swift 3.0 let text = "abc" let index2 = text.index(text.startIndex, offsetBy: 2) //will call succ 2 times let lastChar: Character = text[index2] //now we can index! let characterIndex2 = text.characters.index

参数签名ascii码排序的坑

参数签名中通常是按键值对中键名称的ASCII按从小到大的顺序排序后进行hash为签名字符串.不要直接使用 SortedDictionary<string, string> 有坑的,他是按数字.小写字母.大写字母的顺序排的,实际规则应该是数字.大写字母.小写字母的顺序来排才对.一直使用他在支付宝和微信的接口中都没问题,因为支付宝和微信的单词是用下划线分隔的,今天接入的一家支付公司用的驼峰命名法坑就出现了.正确的打开姿势如下: /// <summary> /// ASCII值排序 //

C# 参数签名字符串按 ASCII码排序,注意其中的坑

参数签名中通常是按键值对中键名称的ASCII按从小到大的顺序排序后进行hash为签名字符串.不要直接使用 SortedDictionary<string, string> 有坑的,他是按数字.小写字母.大写字母的顺序排的,实际规则应该是数字.大写字母.小写字母的顺序来排才对.一直使用他在支付宝和微信的接口中都没问题,因为支付宝和微信的单词是用下划线分隔的,今天接入的一家支付公司用的驼峰命名法坑就出现了.正确的打开姿势如下: /// <summary> /// ASCII值排序 //

汉字-拼音转换类

汉字转拼音 ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84

2017年6月15日 由一个freemarker出错引发的感想

今天想要实现一个功能,想要实现遍历多个checkbox的功能.想出一个解决方法用了30秒钟,将包含的键值put进map中,前台根据map[key]??判断是否具有该值,乍一看这个方法很好,可是实际上问题很大..我在不请求freemarker api的情况下乱用它的功能..很有可能出现不可预知的错误...果然,.出错了....再百度一看..直接用 seq_contains 就可以了..可这么一些还是不对.....冥思苦(ˇ?ˇ) 想-,,原来 我后台 array 是string 类型的..而seq

【HackerRank】 Sherlock and The Beast

Sherlock and The Beast Sherlock Holmes is getting paranoid about Professor Moriarty, his archenemy. All his efforts to subdue Moriarty have been in vain. These days Sherlock is working on a problem with Dr. Watson. Watson mentioned that the CIA has b

BUCT20180814邀请赛

A:SUM 水. 1 #include<bits/stdc++.h> 2 3 using namespace std; 4 5 #define N 100010 6 typedef long long ll; 7 8 int n; 9 ll arr[N]; 10 ll sum[N]; 11 12 int main() 13 { 14 while(~scanf("%d",&n)) 15 { 16 memset(sum, 0, sizeof sum); 17 for(i

CPython对象模型:string(留坑待填)

在python3中,移除了2中的byte string,string变的和2中的unicode类似.所以在python3中烦人的编码问题会少不少. 在准备动手写这一篇的时候,查了不少资料,结果不小心发现了PEP-393 这个是unicode部分的原作者亲自写的,内容详细解释的很清楚,只要对python对象有个基础的认识绝对看得懂啊! 于是为了先赶赶进度,我决定先给string留个坑,等以后再填……

Torch-RNN运行过程中的坑 [2](Lua的string sub函数,读取中文失败,乱码?)

0.踩坑背景 仍然是torch-rnn/LanguageModel.lua文件中的一些问题,仍然是这个狗血的LM:encode_string函数: function LM:encode_string(s) local encoded = torch.LongTensor(#s) for i = 1, #s do local token = s:sub(i, i) local idx = self.token_to_idx[token] assert(idx ~= nil, 'Got invali