首页
学习
活动
专区
圈层
工具
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

在Java中字符串是通过引用传递的?

这是一个经典的java问题。在stackoverflow上,许多类似的问题已经被问过了,但是许多回答是错误的或不完整的。 如果你不想深入思考的话,这个问题很简单。...经常让人捉摸不透的问题 x 存储了堆中"ab"字符串的引用。...因此,当x作为参数传递到change()方法的时候,它仍然堆中的"ab",如下所示: ? 因为java是按值传递的,x的值是"ab"的引用。...变量x包含了一个指向字符串对象的引用,x并不是字符串对象本身。它是一个储存了字符串对象'ab'引用的变量。 java是按值传递的。...即使String被StringBuilder替换,结果仍然是一样的。关键点是变量存储的是对象引用,而不是对象本身!

6.2K50

为什么String在Java中是不可变的

String 在 Java 中是不可变的。 不可变类只是一个无法修改其实例的类。 创建实例时,将初始化实例中的所有信息,并且无法修改信息。 不可变类有许多优点。...本文总结了为什么 String 设计为不可变的。 这篇文章从内存,同步和数据结构的角度说明了不变性概念。 1. 字符串池 字符串池(String intern pool)是方法区域中的特殊存储区域。...创建字符串并且池中已存在该字符串时,将返回现有字符串的引用,而不是创建新对象。 以下代码将在堆中仅创建一个字符串对象。...String string1 = "abcd"; String string2 = "abcd"; 如下图所示: ? 如果字符串是可变的,则使用一个引用更改字符串将导致其他引用的错误。 2....缓存的哈希码 字符串的哈希码经常在 Java 中使用。 例如,在 HashMap 或 HashSet 中。 不可变保证哈希码总是相同的,这样它就可以缓存起来而不用担心变化。

1.3K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    java 为什么 String 在 java 中是不可变的?

    为什么 String 在 java 中是不可变的?String 在 java 中是不可变的,一个不可变类意味着它的实例在创建之后就不可修改,实例的所有属性在创建时初始化,之后无法对这些属性进行修改。...1 字符串池的需要字符串池是存在于 Java方法区 的一个特殊内存区域,当需要创建的目标字符串在字符串池中已经存在,那么字符串池中的字符串引用就会返回并赋值给目标字符串,而不是创建一个新的对象。...如下的代码只会在堆中创建一个对象: 代码解读复制代码String string1 = "abc";String string2 = "abc";图形表示: 如果 String 是可变的,一个引用改变字符串的值将会导致另一个引用在获取值时得到错误的值...(译者:另一个引用并未对字符串做修改,当他再次取值时字符串的值却与上次取的不同!)。2 用作缓存时的 hashcode字符串的哈希值在 java 中是被频繁使用到的。...总结,String 被设计为 final 的原因是 效率 和 安全,通常情况下这也是为什么不可变对象在许多设计中会成为首选的原因。

    8710

    jdk源码分析之HashMap--为什么初始容量是2的n次幂

    熟悉HashMap的人都知道,其底层是数组+链表结构实现,也就是说我们常用的get和put操作中,key要和底层的结构关联对应起来,先看一下HashMap的机构模型: ?...key在Entry数组中的位置索引,然后for循环做的事情就是遍历该位置的链表,如果有和key相等的节点,直接返回节点(由调用方返回节点中的value)。...那么我们关注的是indexFor方法中如何找到key在数组中的位置呢?...其实就是两个数字的二进制数据对应的位对比,1&1=1,1&0=0,0&0=0,比如: 1011=11 1000=8 按位与之后 1000=8 回到我们的主题中,为什么初始容量(也就是Entry...回到上述的indexFor方法中,也就是说对于数组长度非2的n次幂的情况,永远会有一些数组位置辐射不到,再换一个角度来说,这些场景中,我们永远无法将Entry数组利用率提高到100%。

    37610

    HashMap中数组的长度为什么要设计成2次幂?

    HashMap中数组的长度为什么要设计成2次幂?  了解本文的前提需要你对数据结构有一定的了解,明白各种数据结构的优劣。当然如果你已经知道了HashMap底层的数据结构是数组+链表+红黑树那就更好了。...如果你还知道hashMap默认初始化的数组长度是16,且每次扩容都扩容为原长度的两倍,那么我只能说“你已经是一个合格的大佬了”。  ...下面是jdk1.8中HashMap的部分源码 ?...可以看出当数组的长度为16时,计算出了16个槽位并且均匀分布在数组的每一个位置,当数组长度为15时,只计算出了8个槽位,每个槽位放了一个两个节点的链表,导致了有8个槽位是空闲状态。...我们从map中取数据时,本来可以直接通过key计算出的槽位取出对应元素就可以了,现在因为这个槽位存放的是一个链表,那么想要取数据还得遍历这个链表,在非常极端的情况下(所有元素的hashcode都是相同的

    95020

    为什么在深度神经网络中,网络权重的初始化很重要?

    在深度神经网络中,网络权重的初始化非常关键,因为它对网络的训练速度、收敛能力以及最终的性能都有重大影响。...而一个好的初始化策略可以使权重开始时就更接近最优解,从而加快训练过程。 影响模型性能:不恰当的初始化可能导致模型陷入局部最小值或鞍点,尤其是在复杂的非凸优化问题中。...正交初始化:权重矩阵的行或列是正交的。通常用于 RNN。 稀疏初始化:保持大部分权重为零,只有少数非零初始值。...总之,合理选择和调整深度学习模型中的权重初始化方法是确保模型良好训练行为和高性能表现的关键步骤之一。...值得注意的是,PyTorch 的 torch.nn.init 模块中的所有函数都旨在用于初始化神经网络参数,因此它们都在 torch.no_grad() 模式下运行,不会被自动求导考虑在内。

    41100

    为什么在深度学习中,AlphaGo Zero是一个巨大的飞跃?

    AlphaGo Zero是DeepMind的自动操作系统的最新化身。有人可能会认为,在围棋中击败人类世界冠军是很难的。...2.学习从头开始执行这项任务,而不需要学习以前的人类知识(例如:记录的博弈计划)。 3.只需3天的训练时间,就能达到世界冠军水平。 4.用较少的神经网络(4 TPUs vs 48 TPUs)。...Lockhart和其他一些人提到,它几乎同时在各种各样的斗争中战斗,采用了一种对人类玩家来说有点疯狂的方法,它们可能会花更多的精力在棋盘上的更小的区域上。 第三点是,训练时间也比之前的版本少得多。...该网络通过将自身与外部训练数据进行比较,而不是从先前版本的神经网络中获得的合成数据来学习。 第四点是,在之前的系统中,它只需要4个Google TPUs,而之前需要48个TPUs。...它可以有效地做到这一点,因为所有其他的不确定因素都是已知的。也就是说,在一系列行为的结果中没有不确定性,行为效果是可以预测的。简而言之,博弈的行为是可以预测的。

    96380

    PHP AES加密

    #CCM (counter with CBC-MAC)定义在分组长度为128位的加密算法中,如,AES 的分组长度为128。...组成AES-CCM算法的关键组成是CTR工作模式以及CMAC认证算法。 #GCM基于并行化设计,因此可以提供高效的吞吐率和低成本、低时延。...本质是消息在变形的CTR模式下加密,密文结果与密钥以及消息长度在GF(2^128)域上相乘。其输入输出和CCM基本一致。 #GCM中的G就是指GMAC,C就是指CTR。...在实际应用场景中,有些信息是我们不需要保密,但信息的接收者需要确认它的真实性的,例如源IP,源端口,目的IP,IV,等等。因此,我们可以将这一部分作为附加消息加入到MAC值的计算当中。...最后,密文接收者会收到密文、IV(计数器CTR的初始值)、MAC值。

    1.5K30

    IoC容器初始化过程(下)1 BeanDefinition的载入和解析2 BeanDefinition在IoC容器中的注册

    的基类)中,详细地描述了整个 ApplicationContext 的初始化过程,比如 BeanFactory 的更新, MessageSource 和 PostProcessor 的注册...看起来像是对...图1.2 对IoC容器执行refresh的过程 2 BeanDefinition在IoC容器中的注册 BeanDefinition 在IoC容器中完成了载入和解析后,用户定义的 BeanDefinition...,在 DefaultListableBeanFactory 中,是通过一个 ConcurrentHashMap 来持有载入的 BeanDefinition 的. ?...beanDefinitionMap 注册的过程是在载入 BeanDefinition 完成后进行的,注册的调用过程如图 ?...这些信息是容器建立依赖反转的基础,有了这些基础数据,我们下面学习一下在IoC容器中,依赖注入是怎样完成的.

    87680

    PHP 垃圾回收机制详解

    p5和php7的垃圾回收机制都是利用引用计数 二、php5和php7不同点 1、PHP5标量数据类型会计数,PHP7标量数据类型不再计数,不需要单独分配内存 2、PHP7的zval 需要的内存不再是单独从堆上分配...3、PHP7的复杂数据类型(比如数组和对象)的引用计数由其自身来存储。 三、变量在zval的变量容器中结构 ?...zval中,除了存储变量的类型和值之外,还有is_ref字段和refcount字段 1、is_ref:是个bool值,用来区分变量是否属于引用集合。...八、循环引用问题   1、PHP7.1效果 在5.2及更早版本的PHP中,没有专门的垃圾回收器GC(Garbage Collection),引擎在判断一个变量空间是否能够被释放的时候是依据这个变量的zval的refcount的值,    如果

    47520

    PHP 垃圾回收机制详解

    不同点 1、PHP5标量数据类型会计数,PHP7标量数据类型不再计数,不需要单独分配内存 2、PHP7的zval 需要的内存不再是单独从堆上分配,不再自己存储引用计数。...3、PHP7的复杂数据类型(比如数组和对象)的引用计数由其自身来存储。...三、变量在zval的变量容器中结构 zval中,除了存储变量的类型和值之外,还有is_ref字段和refcount字段 1、is_ref:是个bool值,用来区分变量是否属于引用集合。...a的refcount=2,后经测试发现数组的refcount都是从2开始的 八、循环引用问题   1、PHP7.1效果 2、再看看5.3的效果 说明:在5.2及更早版本的PHP中,没有专门的垃圾回收器GC(Garbage Collection),引擎在判断一个变量空间是否能够被释放的时候是依据这个变量的zval的

    40220

    PHP中那些隐蔽的坑

    城边编程 phplog 读完需要 5 分钟 速读仅需2分钟 各大论坛中只要是关于PHP的话题最后都会变成引战贴,争来争去就那么几个点在重复的说,最开始我也会去知乎上回答,每次回答完都会遇到杠精来骂你,...false; } strcmp($a,$b) 函数的返回类型也是mixed,正常情况下会返回int,如果传入的是数组,则返回`false`,PHP中 `false` == 0是成立的,所以可以绕过。...json函数之坑 在PHP7.1之后,json_encode($arr) 函数会默认给float类型的数据添加精度。...之前的分析文章请看这里-我是如何拿到巨额漏洞奖金的 数组结构类型太少之坑 PHP虽然有数组的概念,但全是基于HashTable实现。你想创建一个int型的数组,但是PHP不支持。...你想创建一个sting类型的数组,PHP也不支持。虽然在语法上看起来像是int,string类型的数组,但底层还是HashTable。

    84950

    Objective-C中的内存管理

    OC中使用引用计数和垃圾回收来管理内存,在OC中为每个对象分配一个引用计数器,当对象刚刚被创建时其初始值为1,当有某段代码需要访问一个对象是时,会将该对象的引用计数器加1(通过retain来实现);当访问一个对象结束时...在NSObject类有一个retainCount方法,调用该方法可获取当前对象的引用计数值。         ...在XCode4以后的版本采取自动引用计数(Automatic Reference Counting)简称ARC, 默认的是ARC模式,在ARC下是不能直接调用retain,release, releaseCount...(1).先创建一个可变数组对象,在创建一个可变字符串对象;     ​    ​    ​(2).然后往可变数组里添加可变的字符串,观察可变字符串的retainCount的变化。     ​    ​    ​...(3).在可变数组中移除一个str,观察retainCount的变化     ​    ​    ​(4)我们为什么要用可变的字符串呢?稍后会提到为什么。

    81290

    PHP中那些你不知道的坑,PHP的坑,PHP漏洞

    但是PHP不一样,PHP中很多函数返回的数据类型并不固定。 例如json_decode($a)函数,正常情况下这个函数能将字符串转换成数组然后返回,但是少数情况下它会放飞自我。...json函数之坑 在PHP7.1之后,json_encode($array) 函数会默认给float类型的数据添加精度。...我遇到时也是一脸懵,好在这个问题可以通过修改配置文件修复,在PHP7.2之后默认关闭了json_encode函数保留更多精度的开关。只有PHP7.1版本有这个问题。...虽然在语法上看起来像是int,或者string类型的数组,但底层都是HashTable。这导致PHP在算法优化上的空间非常少,更没有办法基于数组扩展更多高级的数据结构,比如双向链表,红黑树等。...至于在知乎上大家说的那些问题,我觉得都不是什么大问题。例如语法不美,速度不快,函数命名不规范……为什么大家都喜欢喷这几点?

    99840

    定义一个方法,功能是找出一个数组中第一个只重复出现2次的元素,没有则返回null。例如:数组元素为 ,重复两次的元素为4和2,但是元素4排在2的前面,则结果返回

    在本篇博客中,我们将探讨如何实现一个方法,该方法能够在给定的整数数组中,找出第一个仅重复出现两次的元素。如果数组中不存在这样的元素,则方法将返回null。...问题背景 考虑以下情景:我们有一个整数数组,其中某些元素可能会重复出现,但我们只关注那些仅出现两次的元素。我们的目标是找到这些仅重复出现两次的元素中,排在前面的那个元素。 1....定义一个方法,功能是找出一个数组中第一个只重复出现2次的元素,没有则返回null。...例如:数组元素为 [1,3,4,2,6,3,4,2,3],重复两次的元素为4和2,但是元素4排在2的前面,则结果返回4。...如果已存在,我们将该元素的计数加1;否则,我们将该元素添加到m中,并将计数设置为1。 循环完成后,我们得到一个映射表m,其中包含了每个元素及其在数组中出现的次数。

    22010

    PHP的引用计数是什么意思?

    PHP的引用计数是什么意思? 什么是引用计数 在PHP的数据结构中,引用计数就是指每一个变量,除了保存了它们的类型和值之外,还额外保存了两个内容,一个是当前这个变量是否被引用,另一个是引用的次数。...(注意,PHP中的变量对应的是内存的符号表,并不是真正的内存地址) 对象的引用计数 和普通类型的变量一样,对象变量也是使用同样的计数规则。...当数组中的某一个元素被 & 引用赋值给其他变量之后,这个元素的 refcount 会增加,不会影响整个数组的 refcount 。 二是数组默认上来的 refcount 是2。...其实这是 PHP7 之后的一种新的特性,当数组定义并初始化后,会将这个数组转变成一个不可变数组(immutable array)。为了和普通数组区分开,这种数组的 refcount 是从2开始起步的。...关于内存泄露需要注意的地方 其实 PHP 在底层已经帮我们做好了 GC 机制就不需要太关心变量的销毁释放问题,但是,千万要注意的是对象或数组中的元素是可以赋值为自身的,也就是说,给某个元素赋值一个自身的引用就变成了循环引用

    2.2K20
    领券