主頁 > 前端設計 > 深入分析String類

深入分析String類

2020-10-17 17:59:09 前端設計

可以說字串操作是計算機程式設計中最為常見的行為

不可變的String

根據JDK檔案的說法,String類代表字串,Java程式中的所有字串文字(例如"abc")都被實作為此類實體,例如:

		String string = "abc";	
		//相當于:
		char[] data = {'a','b','c'};
		String str = new String(data);

那為什么說String類是不可變的,看一段String類中的部分源代碼
在這里插入圖片描述
哦~,原來是這樣,String類是被final修飾的,所以無法繼承該類,并且,其所有的成員變數都是私有(private)的,而且沒有提供修改私有變數的共有(public)方法,再者,關于對String物件的操作都沒有修改當前物件,而是新建一個物件

例如下面這個substing方法,如果回傳值不等于自身,該方法就會創建一個String物件,該物件為截取后的結果,而不是在原String物件上進行的
在這里插入圖片描述

可能有些人就來疑問了,誰說的不能修改,看我這個,s1都被我改的毀容了在這里插入圖片描述
其實,這只是表面的錯覺而已

起初,3個參考(s1、s2、s3)分別指向各自的物件,如圖

<style>#mermaid-svg-KyAHwVceFMgVHVzC .label{font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family);fill:#333;color:#333}#mermaid-svg-KyAHwVceFMgVHVzC .label text{fill:#333}#mermaid-svg-KyAHwVceFMgVHVzC .node rect,#mermaid-svg-KyAHwVceFMgVHVzC .node circle,#mermaid-svg-KyAHwVceFMgVHVzC .node ellipse,#mermaid-svg-KyAHwVceFMgVHVzC .node polygon,#mermaid-svg-KyAHwVceFMgVHVzC .node path{fill:#ECECFF;stroke:#9370db;stroke-width:1px}#mermaid-svg-KyAHwVceFMgVHVzC .node .label{text-align:center;fill:#333}#mermaid-svg-KyAHwVceFMgVHVzC .node.clickable{cursor:pointer}#mermaid-svg-KyAHwVceFMgVHVzC .arrowheadPath{fill:#333}#mermaid-svg-KyAHwVceFMgVHVzC .edgePath .path{stroke:#333;stroke-width:1.5px}#mermaid-svg-KyAHwVceFMgVHVzC .flowchart-link{stroke:#333;fill:none}#mermaid-svg-KyAHwVceFMgVHVzC .edgeLabel{background-color:#e8e8e8;text-align:center}#mermaid-svg-KyAHwVceFMgVHVzC .edgeLabel rect{opacity:0.9}#mermaid-svg-KyAHwVceFMgVHVzC .edgeLabel span{color:#333}#mermaid-svg-KyAHwVceFMgVHVzC .cluster rect{fill:#ffffde;stroke:#aa3;stroke-width:1px}#mermaid-svg-KyAHwVceFMgVHVzC .cluster text{fill:#333}#mermaid-svg-KyAHwVceFMgVHVzC div.mermaidTooltip{position:absolute;text-align:center;max-width:200px;padding:2px;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family);font-size:12px;background:#ffffde;border:1px solid #aa3;border-radius:2px;pointer-events:none;z-index:100}#mermaid-svg-KyAHwVceFMgVHVzC .actor{stroke:#ccf;fill:#ECECFF}#mermaid-svg-KyAHwVceFMgVHVzC text.actor>tspan{fill:#000;stroke:none}#mermaid-svg-KyAHwVceFMgVHVzC .actor-line{stroke:grey}#mermaid-svg-KyAHwVceFMgVHVzC .messageLine0{stroke-width:1.5;stroke-dasharray:none;stroke:#333}#mermaid-svg-KyAHwVceFMgVHVzC .messageLine1{stroke-width:1.5;stroke-dasharray:2, 2;stroke:#333}#mermaid-svg-KyAHwVceFMgVHVzC #arrowhead path{fill:#333;stroke:#333}#mermaid-svg-KyAHwVceFMgVHVzC .sequenceNumber{fill:#fff}#mermaid-svg-KyAHwVceFMgVHVzC #sequencenumber{fill:#333}#mermaid-svg-KyAHwVceFMgVHVzC #crosshead path{fill:#333;stroke:#333}#mermaid-svg-KyAHwVceFMgVHVzC .messageText{fill:#333;stroke:#333}#mermaid-svg-KyAHwVceFMgVHVzC .labelBox{stroke:#ccf;fill:#ECECFF}#mermaid-svg-KyAHwVceFMgVHVzC .labelText,#mermaid-svg-KyAHwVceFMgVHVzC .labelText>tspan{fill:#000;stroke:none}#mermaid-svg-KyAHwVceFMgVHVzC .loopText,#mermaid-svg-KyAHwVceFMgVHVzC .loopText>tspan{fill:#000;stroke:none}#mermaid-svg-KyAHwVceFMgVHVzC .loopLine{stroke-width:2px;stroke-dasharray:2, 2;stroke:#ccf;fill:#ccf}#mermaid-svg-KyAHwVceFMgVHVzC .note{stroke:#aa3;fill:#fff5ad}#mermaid-svg-KyAHwVceFMgVHVzC .noteText,#mermaid-svg-KyAHwVceFMgVHVzC .noteText>tspan{fill:#000;stroke:none}#mermaid-svg-KyAHwVceFMgVHVzC .activation0{fill:#f4f4f4;stroke:#666}#mermaid-svg-KyAHwVceFMgVHVzC .activation1{fill:#f4f4f4;stroke:#666}#mermaid-svg-KyAHwVceFMgVHVzC .activation2{fill:#f4f4f4;stroke:#666}#mermaid-svg-KyAHwVceFMgVHVzC .mermaid-main-font{font-family:"trebuchet ms", verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-KyAHwVceFMgVHVzC .section{stroke:none;opacity:0.2}#mermaid-svg-KyAHwVceFMgVHVzC .section0{fill:rgba(102,102,255,0.49)}#mermaid-svg-KyAHwVceFMgVHVzC .section2{fill:#fff400}#mermaid-svg-KyAHwVceFMgVHVzC .section1,#mermaid-svg-KyAHwVceFMgVHVzC .section3{fill:#fff;opacity:0.2}#mermaid-svg-KyAHwVceFMgVHVzC .sectionTitle0{fill:#333}#mermaid-svg-KyAHwVceFMgVHVzC .sectionTitle1{fill:#333}#mermaid-svg-KyAHwVceFMgVHVzC .sectionTitle2{fill:#333}#mermaid-svg-KyAHwVceFMgVHVzC .sectionTitle3{fill:#333}#mermaid-svg-KyAHwVceFMgVHVzC .sectionTitle{text-anchor:start;font-size:11px;text-height:14px;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-KyAHwVceFMgVHVzC .grid .tick{stroke:#d3d3d3;opacity:0.8;shape-rendering:crispEdges}#mermaid-svg-KyAHwVceFMgVHVzC .grid .tick text{font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-KyAHwVceFMgVHVzC .grid path{stroke-width:0}#mermaid-svg-KyAHwVceFMgVHVzC .today{fill:none;stroke:red;stroke-width:2px}#mermaid-svg-KyAHwVceFMgVHVzC .task{stroke-width:2}#mermaid-svg-KyAHwVceFMgVHVzC .taskText{text-anchor:middle;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-KyAHwVceFMgVHVzC .taskText:not([font-size]){font-size:11px}#mermaid-svg-KyAHwVceFMgVHVzC .taskTextOutsideRight{fill:#000;text-anchor:start;font-size:11px;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-KyAHwVceFMgVHVzC .taskTextOutsideLeft{fill:#000;text-anchor:end;font-size:11px}#mermaid-svg-KyAHwVceFMgVHVzC .task.clickable{cursor:pointer}#mermaid-svg-KyAHwVceFMgVHVzC .taskText.clickable{cursor:pointer;fill:#003163 !important;font-weight:bold}#mermaid-svg-KyAHwVceFMgVHVzC .taskTextOutsideLeft.clickable{cursor:pointer;fill:#003163 !important;font-weight:bold}#mermaid-svg-KyAHwVceFMgVHVzC .taskTextOutsideRight.clickable{cursor:pointer;fill:#003163 !important;font-weight:bold}#mermaid-svg-KyAHwVceFMgVHVzC .taskText0,#mermaid-svg-KyAHwVceFMgVHVzC .taskText1,#mermaid-svg-KyAHwVceFMgVHVzC .taskText2,#mermaid-svg-KyAHwVceFMgVHVzC .taskText3{fill:#fff}#mermaid-svg-KyAHwVceFMgVHVzC .task0,#mermaid-svg-KyAHwVceFMgVHVzC .task1,#mermaid-svg-KyAHwVceFMgVHVzC .task2,#mermaid-svg-KyAHwVceFMgVHVzC .task3{fill:#8a90dd;stroke:#534fbc}#mermaid-svg-KyAHwVceFMgVHVzC .taskTextOutside0,#mermaid-svg-KyAHwVceFMgVHVzC .taskTextOutside2{fill:#000}#mermaid-svg-KyAHwVceFMgVHVzC .taskTextOutside1,#mermaid-svg-KyAHwVceFMgVHVzC .taskTextOutside3{fill:#000}#mermaid-svg-KyAHwVceFMgVHVzC .active0,#mermaid-svg-KyAHwVceFMgVHVzC .active1,#mermaid-svg-KyAHwVceFMgVHVzC .active2,#mermaid-svg-KyAHwVceFMgVHVzC .active3{fill:#bfc7ff;stroke:#534fbc}#mermaid-svg-KyAHwVceFMgVHVzC .activeText0,#mermaid-svg-KyAHwVceFMgVHVzC .activeText1,#mermaid-svg-KyAHwVceFMgVHVzC .activeText2,#mermaid-svg-KyAHwVceFMgVHVzC .activeText3{fill:#000 !important}#mermaid-svg-KyAHwVceFMgVHVzC .done0,#mermaid-svg-KyAHwVceFMgVHVzC .done1,#mermaid-svg-KyAHwVceFMgVHVzC .done2,#mermaid-svg-KyAHwVceFMgVHVzC .done3{stroke:grey;fill:#d3d3d3;stroke-width:2}#mermaid-svg-KyAHwVceFMgVHVzC .doneText0,#mermaid-svg-KyAHwVceFMgVHVzC .doneText1,#mermaid-svg-KyAHwVceFMgVHVzC .doneText2,#mermaid-svg-KyAHwVceFMgVHVzC .doneText3{fill:#000 !important}#mermaid-svg-KyAHwVceFMgVHVzC .crit0,#mermaid-svg-KyAHwVceFMgVHVzC .crit1,#mermaid-svg-KyAHwVceFMgVHVzC .crit2,#mermaid-svg-KyAHwVceFMgVHVzC .crit3{stroke:#f88;fill:red;stroke-width:2}#mermaid-svg-KyAHwVceFMgVHVzC .activeCrit0,#mermaid-svg-KyAHwVceFMgVHVzC .activeCrit1,#mermaid-svg-KyAHwVceFMgVHVzC .activeCrit2,#mermaid-svg-KyAHwVceFMgVHVzC .activeCrit3{stroke:#f88;fill:#bfc7ff;stroke-width:2}#mermaid-svg-KyAHwVceFMgVHVzC .doneCrit0,#mermaid-svg-KyAHwVceFMgVHVzC .doneCrit1,#mermaid-svg-KyAHwVceFMgVHVzC .doneCrit2,#mermaid-svg-KyAHwVceFMgVHVzC .doneCrit3{stroke:#f88;fill:#d3d3d3;stroke-width:2;cursor:pointer;shape-rendering:crispEdges}#mermaid-svg-KyAHwVceFMgVHVzC .milestone{transform:rotate(45deg) scale(0.8, 0.8)}#mermaid-svg-KyAHwVceFMgVHVzC .milestoneText{font-style:italic}#mermaid-svg-KyAHwVceFMgVHVzC .doneCritText0,#mermaid-svg-KyAHwVceFMgVHVzC .doneCritText1,#mermaid-svg-KyAHwVceFMgVHVzC .doneCritText2,#mermaid-svg-KyAHwVceFMgVHVzC .doneCritText3{fill:#000 !important}#mermaid-svg-KyAHwVceFMgVHVzC .activeCritText0,#mermaid-svg-KyAHwVceFMgVHVzC .activeCritText1,#mermaid-svg-KyAHwVceFMgVHVzC .activeCritText2,#mermaid-svg-KyAHwVceFMgVHVzC .activeCritText3{fill:#000 !important}#mermaid-svg-KyAHwVceFMgVHVzC .titleText{text-anchor:middle;font-size:18px;fill:#000;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-KyAHwVceFMgVHVzC g.classGroup text{fill:#9370db;stroke:none;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family);font-size:10px}#mermaid-svg-KyAHwVceFMgVHVzC g.classGroup text .title{font-weight:bolder}#mermaid-svg-KyAHwVceFMgVHVzC g.clickable{cursor:pointer}#mermaid-svg-KyAHwVceFMgVHVzC g.classGroup rect{fill:#ECECFF;stroke:#9370db}#mermaid-svg-KyAHwVceFMgVHVzC g.classGroup line{stroke:#9370db;stroke-width:1}#mermaid-svg-KyAHwVceFMgVHVzC .classLabel .box{stroke:none;stroke-width:0;fill:#ECECFF;opacity:0.5}#mermaid-svg-KyAHwVceFMgVHVzC .classLabel .label{fill:#9370db;font-size:10px}#mermaid-svg-KyAHwVceFMgVHVzC .relation{stroke:#9370db;stroke-width:1;fill:none}#mermaid-svg-KyAHwVceFMgVHVzC .dashed-line{stroke-dasharray:3}#mermaid-svg-KyAHwVceFMgVHVzC #compositionStart{fill:#9370db;stroke:#9370db;stroke-width:1}#mermaid-svg-KyAHwVceFMgVHVzC #compositionEnd{fill:#9370db;stroke:#9370db;stroke-width:1}#mermaid-svg-KyAHwVceFMgVHVzC #aggregationStart{fill:#ECECFF;stroke:#9370db;stroke-width:1}#mermaid-svg-KyAHwVceFMgVHVzC #aggregationEnd{fill:#ECECFF;stroke:#9370db;stroke-width:1}#mermaid-svg-KyAHwVceFMgVHVzC #dependencyStart{fill:#9370db;stroke:#9370db;stroke-width:1}#mermaid-svg-KyAHwVceFMgVHVzC #dependencyEnd{fill:#9370db;stroke:#9370db;stroke-width:1}#mermaid-svg-KyAHwVceFMgVHVzC #extensionStart{fill:#9370db;stroke:#9370db;stroke-width:1}#mermaid-svg-KyAHwVceFMgVHVzC #extensionEnd{fill:#9370db;stroke:#9370db;stroke-width:1}#mermaid-svg-KyAHwVceFMgVHVzC .commit-id,#mermaid-svg-KyAHwVceFMgVHVzC .commit-msg,#mermaid-svg-KyAHwVceFMgVHVzC .branch-label{fill:lightgrey;color:lightgrey;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-KyAHwVceFMgVHVzC .pieTitleText{text-anchor:middle;font-size:25px;fill:#000;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-KyAHwVceFMgVHVzC .slice{font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-KyAHwVceFMgVHVzC g.stateGroup text{fill:#9370db;stroke:none;font-size:10px;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-KyAHwVceFMgVHVzC g.stateGroup text{fill:#9370db;fill:#333;stroke:none;font-size:10px}#mermaid-svg-KyAHwVceFMgVHVzC g.statediagram-cluster .cluster-label text{fill:#333}#mermaid-svg-KyAHwVceFMgVHVzC g.stateGroup .state-title{font-weight:bolder;fill:#000}#mermaid-svg-KyAHwVceFMgVHVzC g.stateGroup rect{fill:#ECECFF;stroke:#9370db}#mermaid-svg-KyAHwVceFMgVHVzC g.stateGroup line{stroke:#9370db;stroke-width:1}#mermaid-svg-KyAHwVceFMgVHVzC .transition{stroke:#9370db;stroke-width:1;fill:none}#mermaid-svg-KyAHwVceFMgVHVzC .stateGroup .composit{fill:white;border-bottom:1px}#mermaid-svg-KyAHwVceFMgVHVzC .stateGroup .alt-composit{fill:#e0e0e0;border-bottom:1px}#mermaid-svg-KyAHwVceFMgVHVzC .state-note{stroke:#aa3;fill:#fff5ad}#mermaid-svg-KyAHwVceFMgVHVzC .state-note text{fill:black;stroke:none;font-size:10px}#mermaid-svg-KyAHwVceFMgVHVzC .stateLabel .box{stroke:none;stroke-width:0;fill:#ECECFF;opacity:0.7}#mermaid-svg-KyAHwVceFMgVHVzC .edgeLabel text{fill:#333}#mermaid-svg-KyAHwVceFMgVHVzC .stateLabel text{fill:#000;font-size:10px;font-weight:bold;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-KyAHwVceFMgVHVzC .node circle.state-start{fill:black;stroke:black}#mermaid-svg-KyAHwVceFMgVHVzC .node circle.state-end{fill:black;stroke:white;stroke-width:1.5}#mermaid-svg-KyAHwVceFMgVHVzC #statediagram-barbEnd{fill:#9370db}#mermaid-svg-KyAHwVceFMgVHVzC .statediagram-cluster rect{fill:#ECECFF;stroke:#9370db;stroke-width:1px}#mermaid-svg-KyAHwVceFMgVHVzC .statediagram-cluster rect.outer{rx:5px;ry:5px}#mermaid-svg-KyAHwVceFMgVHVzC .statediagram-state .divider{stroke:#9370db}#mermaid-svg-KyAHwVceFMgVHVzC .statediagram-state .title-state{rx:5px;ry:5px}#mermaid-svg-KyAHwVceFMgVHVzC .statediagram-cluster.statediagram-cluster .inner{fill:white}#mermaid-svg-KyAHwVceFMgVHVzC .statediagram-cluster.statediagram-cluster-alt .inner{fill:#e0e0e0}#mermaid-svg-KyAHwVceFMgVHVzC .statediagram-cluster .inner{rx:0;ry:0}#mermaid-svg-KyAHwVceFMgVHVzC .statediagram-state rect.basic{rx:5px;ry:5px}#mermaid-svg-KyAHwVceFMgVHVzC .statediagram-state rect.divider{stroke-dasharray:10,10;fill:#efefef}#mermaid-svg-KyAHwVceFMgVHVzC .note-edge{stroke-dasharray:5}#mermaid-svg-KyAHwVceFMgVHVzC .statediagram-note rect{fill:#fff5ad;stroke:#aa3;stroke-width:1px;rx:0;ry:0}:root{--mermaid-font-family: '"trebuchet ms", verdana, arial';--mermaid-font-family: "Comic Sans MS", "Comic Sans", cursive}#mermaid-svg-KyAHwVceFMgVHVzC .error-icon{fill:#522}#mermaid-svg-KyAHwVceFMgVHVzC .error-text{fill:#522;stroke:#522}#mermaid-svg-KyAHwVceFMgVHVzC .edge-thickness-normal{stroke-width:2px}#mermaid-svg-KyAHwVceFMgVHVzC .edge-thickness-thick{stroke-width:3.5px}#mermaid-svg-KyAHwVceFMgVHVzC .edge-pattern-solid{stroke-dasharray:0}#mermaid-svg-KyAHwVceFMgVHVzC .edge-pattern-dashed{stroke-dasharray:3}#mermaid-svg-KyAHwVceFMgVHVzC .edge-pattern-dotted{stroke-dasharray:2}#mermaid-svg-KyAHwVceFMgVHVzC .marker{fill:#333}#mermaid-svg-KyAHwVceFMgVHVzC .marker.cross{stroke:#333} :root { --mermaid-font-family: "trebuchet ms", verdana, arial;}</style> <style>#mermaid-svg-KyAHwVceFMgVHVzC { color: rgba(0, 0, 0, 0.75); font: ; }</style>
s1
歐文
s2
艾弗森
s3
NB

執行第12行賦值陳述句后,并不是修改了s1所指的String物件(歐文),而是修改了參考s1,使其指向參考s2所指的String物件(艾弗森),如圖

<style>#mermaid-svg-BGiQXQv4dv07AbDB .label{font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family);fill:#333;color:#333}#mermaid-svg-BGiQXQv4dv07AbDB .label text{fill:#333}#mermaid-svg-BGiQXQv4dv07AbDB .node rect,#mermaid-svg-BGiQXQv4dv07AbDB .node circle,#mermaid-svg-BGiQXQv4dv07AbDB .node ellipse,#mermaid-svg-BGiQXQv4dv07AbDB .node polygon,#mermaid-svg-BGiQXQv4dv07AbDB .node path{fill:#ECECFF;stroke:#9370db;stroke-width:1px}#mermaid-svg-BGiQXQv4dv07AbDB .node .label{text-align:center;fill:#333}#mermaid-svg-BGiQXQv4dv07AbDB .node.clickable{cursor:pointer}#mermaid-svg-BGiQXQv4dv07AbDB .arrowheadPath{fill:#333}#mermaid-svg-BGiQXQv4dv07AbDB .edgePath .path{stroke:#333;stroke-width:1.5px}#mermaid-svg-BGiQXQv4dv07AbDB .flowchart-link{stroke:#333;fill:none}#mermaid-svg-BGiQXQv4dv07AbDB .edgeLabel{background-color:#e8e8e8;text-align:center}#mermaid-svg-BGiQXQv4dv07AbDB .edgeLabel rect{opacity:0.9}#mermaid-svg-BGiQXQv4dv07AbDB .edgeLabel span{color:#333}#mermaid-svg-BGiQXQv4dv07AbDB .cluster rect{fill:#ffffde;stroke:#aa3;stroke-width:1px}#mermaid-svg-BGiQXQv4dv07AbDB .cluster text{fill:#333}#mermaid-svg-BGiQXQv4dv07AbDB div.mermaidTooltip{position:absolute;text-align:center;max-width:200px;padding:2px;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family);font-size:12px;background:#ffffde;border:1px solid #aa3;border-radius:2px;pointer-events:none;z-index:100}#mermaid-svg-BGiQXQv4dv07AbDB .actor{stroke:#ccf;fill:#ECECFF}#mermaid-svg-BGiQXQv4dv07AbDB text.actor>tspan{fill:#000;stroke:none}#mermaid-svg-BGiQXQv4dv07AbDB .actor-line{stroke:grey}#mermaid-svg-BGiQXQv4dv07AbDB .messageLine0{stroke-width:1.5;stroke-dasharray:none;stroke:#333}#mermaid-svg-BGiQXQv4dv07AbDB .messageLine1{stroke-width:1.5;stroke-dasharray:2, 2;stroke:#333}#mermaid-svg-BGiQXQv4dv07AbDB #arrowhead path{fill:#333;stroke:#333}#mermaid-svg-BGiQXQv4dv07AbDB .sequenceNumber{fill:#fff}#mermaid-svg-BGiQXQv4dv07AbDB #sequencenumber{fill:#333}#mermaid-svg-BGiQXQv4dv07AbDB #crosshead path{fill:#333;stroke:#333}#mermaid-svg-BGiQXQv4dv07AbDB .messageText{fill:#333;stroke:#333}#mermaid-svg-BGiQXQv4dv07AbDB .labelBox{stroke:#ccf;fill:#ECECFF}#mermaid-svg-BGiQXQv4dv07AbDB .labelText,#mermaid-svg-BGiQXQv4dv07AbDB .labelText>tspan{fill:#000;stroke:none}#mermaid-svg-BGiQXQv4dv07AbDB .loopText,#mermaid-svg-BGiQXQv4dv07AbDB .loopText>tspan{fill:#000;stroke:none}#mermaid-svg-BGiQXQv4dv07AbDB .loopLine{stroke-width:2px;stroke-dasharray:2, 2;stroke:#ccf;fill:#ccf}#mermaid-svg-BGiQXQv4dv07AbDB .note{stroke:#aa3;fill:#fff5ad}#mermaid-svg-BGiQXQv4dv07AbDB .noteText,#mermaid-svg-BGiQXQv4dv07AbDB .noteText>tspan{fill:#000;stroke:none}#mermaid-svg-BGiQXQv4dv07AbDB .activation0{fill:#f4f4f4;stroke:#666}#mermaid-svg-BGiQXQv4dv07AbDB .activation1{fill:#f4f4f4;stroke:#666}#mermaid-svg-BGiQXQv4dv07AbDB .activation2{fill:#f4f4f4;stroke:#666}#mermaid-svg-BGiQXQv4dv07AbDB .mermaid-main-font{font-family:"trebuchet ms", verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-BGiQXQv4dv07AbDB .section{stroke:none;opacity:0.2}#mermaid-svg-BGiQXQv4dv07AbDB .section0{fill:rgba(102,102,255,0.49)}#mermaid-svg-BGiQXQv4dv07AbDB .section2{fill:#fff400}#mermaid-svg-BGiQXQv4dv07AbDB .section1,#mermaid-svg-BGiQXQv4dv07AbDB .section3{fill:#fff;opacity:0.2}#mermaid-svg-BGiQXQv4dv07AbDB .sectionTitle0{fill:#333}#mermaid-svg-BGiQXQv4dv07AbDB .sectionTitle1{fill:#333}#mermaid-svg-BGiQXQv4dv07AbDB .sectionTitle2{fill:#333}#mermaid-svg-BGiQXQv4dv07AbDB .sectionTitle3{fill:#333}#mermaid-svg-BGiQXQv4dv07AbDB .sectionTitle{text-anchor:start;font-size:11px;text-height:14px;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-BGiQXQv4dv07AbDB .grid .tick{stroke:#d3d3d3;opacity:0.8;shape-rendering:crispEdges}#mermaid-svg-BGiQXQv4dv07AbDB .grid .tick text{font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-BGiQXQv4dv07AbDB .grid path{stroke-width:0}#mermaid-svg-BGiQXQv4dv07AbDB .today{fill:none;stroke:red;stroke-width:2px}#mermaid-svg-BGiQXQv4dv07AbDB .task{stroke-width:2}#mermaid-svg-BGiQXQv4dv07AbDB .taskText{text-anchor:middle;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-BGiQXQv4dv07AbDB .taskText:not([font-size]){font-size:11px}#mermaid-svg-BGiQXQv4dv07AbDB .taskTextOutsideRight{fill:#000;text-anchor:start;font-size:11px;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-BGiQXQv4dv07AbDB .taskTextOutsideLeft{fill:#000;text-anchor:end;font-size:11px}#mermaid-svg-BGiQXQv4dv07AbDB .task.clickable{cursor:pointer}#mermaid-svg-BGiQXQv4dv07AbDB .taskText.clickable{cursor:pointer;fill:#003163 !important;font-weight:bold}#mermaid-svg-BGiQXQv4dv07AbDB .taskTextOutsideLeft.clickable{cursor:pointer;fill:#003163 !important;font-weight:bold}#mermaid-svg-BGiQXQv4dv07AbDB .taskTextOutsideRight.clickable{cursor:pointer;fill:#003163 !important;font-weight:bold}#mermaid-svg-BGiQXQv4dv07AbDB .taskText0,#mermaid-svg-BGiQXQv4dv07AbDB .taskText1,#mermaid-svg-BGiQXQv4dv07AbDB .taskText2,#mermaid-svg-BGiQXQv4dv07AbDB .taskText3{fill:#fff}#mermaid-svg-BGiQXQv4dv07AbDB .task0,#mermaid-svg-BGiQXQv4dv07AbDB .task1,#mermaid-svg-BGiQXQv4dv07AbDB .task2,#mermaid-svg-BGiQXQv4dv07AbDB .task3{fill:#8a90dd;stroke:#534fbc}#mermaid-svg-BGiQXQv4dv07AbDB .taskTextOutside0,#mermaid-svg-BGiQXQv4dv07AbDB .taskTextOutside2{fill:#000}#mermaid-svg-BGiQXQv4dv07AbDB .taskTextOutside1,#mermaid-svg-BGiQXQv4dv07AbDB .taskTextOutside3{fill:#000}#mermaid-svg-BGiQXQv4dv07AbDB .active0,#mermaid-svg-BGiQXQv4dv07AbDB .active1,#mermaid-svg-BGiQXQv4dv07AbDB .active2,#mermaid-svg-BGiQXQv4dv07AbDB .active3{fill:#bfc7ff;stroke:#534fbc}#mermaid-svg-BGiQXQv4dv07AbDB .activeText0,#mermaid-svg-BGiQXQv4dv07AbDB .activeText1,#mermaid-svg-BGiQXQv4dv07AbDB .activeText2,#mermaid-svg-BGiQXQv4dv07AbDB .activeText3{fill:#000 !important}#mermaid-svg-BGiQXQv4dv07AbDB .done0,#mermaid-svg-BGiQXQv4dv07AbDB .done1,#mermaid-svg-BGiQXQv4dv07AbDB .done2,#mermaid-svg-BGiQXQv4dv07AbDB .done3{stroke:grey;fill:#d3d3d3;stroke-width:2}#mermaid-svg-BGiQXQv4dv07AbDB .doneText0,#mermaid-svg-BGiQXQv4dv07AbDB .doneText1,#mermaid-svg-BGiQXQv4dv07AbDB .doneText2,#mermaid-svg-BGiQXQv4dv07AbDB .doneText3{fill:#000 !important}#mermaid-svg-BGiQXQv4dv07AbDB .crit0,#mermaid-svg-BGiQXQv4dv07AbDB .crit1,#mermaid-svg-BGiQXQv4dv07AbDB .crit2,#mermaid-svg-BGiQXQv4dv07AbDB .crit3{stroke:#f88;fill:red;stroke-width:2}#mermaid-svg-BGiQXQv4dv07AbDB .activeCrit0,#mermaid-svg-BGiQXQv4dv07AbDB .activeCrit1,#mermaid-svg-BGiQXQv4dv07AbDB .activeCrit2,#mermaid-svg-BGiQXQv4dv07AbDB .activeCrit3{stroke:#f88;fill:#bfc7ff;stroke-width:2}#mermaid-svg-BGiQXQv4dv07AbDB .doneCrit0,#mermaid-svg-BGiQXQv4dv07AbDB .doneCrit1,#mermaid-svg-BGiQXQv4dv07AbDB .doneCrit2,#mermaid-svg-BGiQXQv4dv07AbDB .doneCrit3{stroke:#f88;fill:#d3d3d3;stroke-width:2;cursor:pointer;shape-rendering:crispEdges}#mermaid-svg-BGiQXQv4dv07AbDB .milestone{transform:rotate(45deg) scale(0.8, 0.8)}#mermaid-svg-BGiQXQv4dv07AbDB .milestoneText{font-style:italic}#mermaid-svg-BGiQXQv4dv07AbDB .doneCritText0,#mermaid-svg-BGiQXQv4dv07AbDB .doneCritText1,#mermaid-svg-BGiQXQv4dv07AbDB .doneCritText2,#mermaid-svg-BGiQXQv4dv07AbDB .doneCritText3{fill:#000 !important}#mermaid-svg-BGiQXQv4dv07AbDB .activeCritText0,#mermaid-svg-BGiQXQv4dv07AbDB .activeCritText1,#mermaid-svg-BGiQXQv4dv07AbDB .activeCritText2,#mermaid-svg-BGiQXQv4dv07AbDB .activeCritText3{fill:#000 !important}#mermaid-svg-BGiQXQv4dv07AbDB .titleText{text-anchor:middle;font-size:18px;fill:#000;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-BGiQXQv4dv07AbDB g.classGroup text{fill:#9370db;stroke:none;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family);font-size:10px}#mermaid-svg-BGiQXQv4dv07AbDB g.classGroup text .title{font-weight:bolder}#mermaid-svg-BGiQXQv4dv07AbDB g.clickable{cursor:pointer}#mermaid-svg-BGiQXQv4dv07AbDB g.classGroup rect{fill:#ECECFF;stroke:#9370db}#mermaid-svg-BGiQXQv4dv07AbDB g.classGroup line{stroke:#9370db;stroke-width:1}#mermaid-svg-BGiQXQv4dv07AbDB .classLabel .box{stroke:none;stroke-width:0;fill:#ECECFF;opacity:0.5}#mermaid-svg-BGiQXQv4dv07AbDB .classLabel .label{fill:#9370db;font-size:10px}#mermaid-svg-BGiQXQv4dv07AbDB .relation{stroke:#9370db;stroke-width:1;fill:none}#mermaid-svg-BGiQXQv4dv07AbDB .dashed-line{stroke-dasharray:3}#mermaid-svg-BGiQXQv4dv07AbDB #compositionStart{fill:#9370db;stroke:#9370db;stroke-width:1}#mermaid-svg-BGiQXQv4dv07AbDB #compositionEnd{fill:#9370db;stroke:#9370db;stroke-width:1}#mermaid-svg-BGiQXQv4dv07AbDB #aggregationStart{fill:#ECECFF;stroke:#9370db;stroke-width:1}#mermaid-svg-BGiQXQv4dv07AbDB #aggregationEnd{fill:#ECECFF;stroke:#9370db;stroke-width:1}#mermaid-svg-BGiQXQv4dv07AbDB #dependencyStart{fill:#9370db;stroke:#9370db;stroke-width:1}#mermaid-svg-BGiQXQv4dv07AbDB #dependencyEnd{fill:#9370db;stroke:#9370db;stroke-width:1}#mermaid-svg-BGiQXQv4dv07AbDB #extensionStart{fill:#9370db;stroke:#9370db;stroke-width:1}#mermaid-svg-BGiQXQv4dv07AbDB #extensionEnd{fill:#9370db;stroke:#9370db;stroke-width:1}#mermaid-svg-BGiQXQv4dv07AbDB .commit-id,#mermaid-svg-BGiQXQv4dv07AbDB .commit-msg,#mermaid-svg-BGiQXQv4dv07AbDB .branch-label{fill:lightgrey;color:lightgrey;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-BGiQXQv4dv07AbDB .pieTitleText{text-anchor:middle;font-size:25px;fill:#000;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-BGiQXQv4dv07AbDB .slice{font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-BGiQXQv4dv07AbDB g.stateGroup text{fill:#9370db;stroke:none;font-size:10px;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-BGiQXQv4dv07AbDB g.stateGroup text{fill:#9370db;fill:#333;stroke:none;font-size:10px}#mermaid-svg-BGiQXQv4dv07AbDB g.statediagram-cluster .cluster-label text{fill:#333}#mermaid-svg-BGiQXQv4dv07AbDB g.stateGroup .state-title{font-weight:bolder;fill:#000}#mermaid-svg-BGiQXQv4dv07AbDB g.stateGroup rect{fill:#ECECFF;stroke:#9370db}#mermaid-svg-BGiQXQv4dv07AbDB g.stateGroup line{stroke:#9370db;stroke-width:1}#mermaid-svg-BGiQXQv4dv07AbDB .transition{stroke:#9370db;stroke-width:1;fill:none}#mermaid-svg-BGiQXQv4dv07AbDB .stateGroup .composit{fill:white;border-bottom:1px}#mermaid-svg-BGiQXQv4dv07AbDB .stateGroup .alt-composit{fill:#e0e0e0;border-bottom:1px}#mermaid-svg-BGiQXQv4dv07AbDB .state-note{stroke:#aa3;fill:#fff5ad}#mermaid-svg-BGiQXQv4dv07AbDB .state-note text{fill:black;stroke:none;font-size:10px}#mermaid-svg-BGiQXQv4dv07AbDB .stateLabel .box{stroke:none;stroke-width:0;fill:#ECECFF;opacity:0.7}#mermaid-svg-BGiQXQv4dv07AbDB .edgeLabel text{fill:#333}#mermaid-svg-BGiQXQv4dv07AbDB .stateLabel text{fill:#000;font-size:10px;font-weight:bold;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-BGiQXQv4dv07AbDB .node circle.state-start{fill:black;stroke:black}#mermaid-svg-BGiQXQv4dv07AbDB .node circle.state-end{fill:black;stroke:white;stroke-width:1.5}#mermaid-svg-BGiQXQv4dv07AbDB #statediagram-barbEnd{fill:#9370db}#mermaid-svg-BGiQXQv4dv07AbDB .statediagram-cluster rect{fill:#ECECFF;stroke:#9370db;stroke-width:1px}#mermaid-svg-BGiQXQv4dv07AbDB .statediagram-cluster rect.outer{rx:5px;ry:5px}#mermaid-svg-BGiQXQv4dv07AbDB .statediagram-state .divider{stroke:#9370db}#mermaid-svg-BGiQXQv4dv07AbDB .statediagram-state .title-state{rx:5px;ry:5px}#mermaid-svg-BGiQXQv4dv07AbDB .statediagram-cluster.statediagram-cluster .inner{fill:white}#mermaid-svg-BGiQXQv4dv07AbDB .statediagram-cluster.statediagram-cluster-alt .inner{fill:#e0e0e0}#mermaid-svg-BGiQXQv4dv07AbDB .statediagram-cluster .inner{rx:0;ry:0}#mermaid-svg-BGiQXQv4dv07AbDB .statediagram-state rect.basic{rx:5px;ry:5px}#mermaid-svg-BGiQXQv4dv07AbDB .statediagram-state rect.divider{stroke-dasharray:10,10;fill:#efefef}#mermaid-svg-BGiQXQv4dv07AbDB .note-edge{stroke-dasharray:5}#mermaid-svg-BGiQXQv4dv07AbDB .statediagram-note rect{fill:#fff5ad;stroke:#aa3;stroke-width:1px;rx:0;ry:0}:root{--mermaid-font-family: '"trebuchet ms", verdana, arial';--mermaid-font-family: "Comic Sans MS", "Comic Sans", cursive}#mermaid-svg-BGiQXQv4dv07AbDB .error-icon{fill:#522}#mermaid-svg-BGiQXQv4dv07AbDB .error-text{fill:#522;stroke:#522}#mermaid-svg-BGiQXQv4dv07AbDB .edge-thickness-normal{stroke-width:2px}#mermaid-svg-BGiQXQv4dv07AbDB .edge-thickness-thick{stroke-width:3.5px}#mermaid-svg-BGiQXQv4dv07AbDB .edge-pattern-solid{stroke-dasharray:0}#mermaid-svg-BGiQXQv4dv07AbDB .edge-pattern-dashed{stroke-dasharray:3}#mermaid-svg-BGiQXQv4dv07AbDB .edge-pattern-dotted{stroke-dasharray:2}#mermaid-svg-BGiQXQv4dv07AbDB .marker{fill:#333}#mermaid-svg-BGiQXQv4dv07AbDB .marker.cross{stroke:#333} :root { --mermaid-font-family: "trebuchet ms", verdana, arial;}</style> <style>#mermaid-svg-BGiQXQv4dv07AbDB { color: rgba(0, 0, 0, 0.75); font: ; }</style>
s1
歐文
s2
艾弗森
s3
NB

執行第15行陳述句時,臨時的StringBuilder物件會連接s2與s3所指的物件,并呼叫toString方法創建一個String物件賦值給參考s1,即參考s1會指向這個新創建的String物件,如圖

<style>#mermaid-svg-MTK7iV9RfLMJkSGp .label{font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family);fill:#333;color:#333}#mermaid-svg-MTK7iV9RfLMJkSGp .label text{fill:#333}#mermaid-svg-MTK7iV9RfLMJkSGp .node rect,#mermaid-svg-MTK7iV9RfLMJkSGp .node circle,#mermaid-svg-MTK7iV9RfLMJkSGp .node ellipse,#mermaid-svg-MTK7iV9RfLMJkSGp .node polygon,#mermaid-svg-MTK7iV9RfLMJkSGp .node path{fill:#ECECFF;stroke:#9370db;stroke-width:1px}#mermaid-svg-MTK7iV9RfLMJkSGp .node .label{text-align:center;fill:#333}#mermaid-svg-MTK7iV9RfLMJkSGp .node.clickable{cursor:pointer}#mermaid-svg-MTK7iV9RfLMJkSGp .arrowheadPath{fill:#333}#mermaid-svg-MTK7iV9RfLMJkSGp .edgePath .path{stroke:#333;stroke-width:1.5px}#mermaid-svg-MTK7iV9RfLMJkSGp .flowchart-link{stroke:#333;fill:none}#mermaid-svg-MTK7iV9RfLMJkSGp .edgeLabel{background-color:#e8e8e8;text-align:center}#mermaid-svg-MTK7iV9RfLMJkSGp .edgeLabel rect{opacity:0.9}#mermaid-svg-MTK7iV9RfLMJkSGp .edgeLabel span{color:#333}#mermaid-svg-MTK7iV9RfLMJkSGp .cluster rect{fill:#ffffde;stroke:#aa3;stroke-width:1px}#mermaid-svg-MTK7iV9RfLMJkSGp .cluster text{fill:#333}#mermaid-svg-MTK7iV9RfLMJkSGp div.mermaidTooltip{position:absolute;text-align:center;max-width:200px;padding:2px;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family);font-size:12px;background:#ffffde;border:1px solid #aa3;border-radius:2px;pointer-events:none;z-index:100}#mermaid-svg-MTK7iV9RfLMJkSGp .actor{stroke:#ccf;fill:#ECECFF}#mermaid-svg-MTK7iV9RfLMJkSGp text.actor>tspan{fill:#000;stroke:none}#mermaid-svg-MTK7iV9RfLMJkSGp .actor-line{stroke:grey}#mermaid-svg-MTK7iV9RfLMJkSGp .messageLine0{stroke-width:1.5;stroke-dasharray:none;stroke:#333}#mermaid-svg-MTK7iV9RfLMJkSGp .messageLine1{stroke-width:1.5;stroke-dasharray:2, 2;stroke:#333}#mermaid-svg-MTK7iV9RfLMJkSGp #arrowhead path{fill:#333;stroke:#333}#mermaid-svg-MTK7iV9RfLMJkSGp .sequenceNumber{fill:#fff}#mermaid-svg-MTK7iV9RfLMJkSGp #sequencenumber{fill:#333}#mermaid-svg-MTK7iV9RfLMJkSGp #crosshead path{fill:#333;stroke:#333}#mermaid-svg-MTK7iV9RfLMJkSGp .messageText{fill:#333;stroke:#333}#mermaid-svg-MTK7iV9RfLMJkSGp .labelBox{stroke:#ccf;fill:#ECECFF}#mermaid-svg-MTK7iV9RfLMJkSGp .labelText,#mermaid-svg-MTK7iV9RfLMJkSGp .labelText>tspan{fill:#000;stroke:none}#mermaid-svg-MTK7iV9RfLMJkSGp .loopText,#mermaid-svg-MTK7iV9RfLMJkSGp .loopText>tspan{fill:#000;stroke:none}#mermaid-svg-MTK7iV9RfLMJkSGp .loopLine{stroke-width:2px;stroke-dasharray:2, 2;stroke:#ccf;fill:#ccf}#mermaid-svg-MTK7iV9RfLMJkSGp .note{stroke:#aa3;fill:#fff5ad}#mermaid-svg-MTK7iV9RfLMJkSGp .noteText,#mermaid-svg-MTK7iV9RfLMJkSGp .noteText>tspan{fill:#000;stroke:none}#mermaid-svg-MTK7iV9RfLMJkSGp .activation0{fill:#f4f4f4;stroke:#666}#mermaid-svg-MTK7iV9RfLMJkSGp .activation1{fill:#f4f4f4;stroke:#666}#mermaid-svg-MTK7iV9RfLMJkSGp .activation2{fill:#f4f4f4;stroke:#666}#mermaid-svg-MTK7iV9RfLMJkSGp .mermaid-main-font{font-family:"trebuchet ms", verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-MTK7iV9RfLMJkSGp .section{stroke:none;opacity:0.2}#mermaid-svg-MTK7iV9RfLMJkSGp .section0{fill:rgba(102,102,255,0.49)}#mermaid-svg-MTK7iV9RfLMJkSGp .section2{fill:#fff400}#mermaid-svg-MTK7iV9RfLMJkSGp .section1,#mermaid-svg-MTK7iV9RfLMJkSGp .section3{fill:#fff;opacity:0.2}#mermaid-svg-MTK7iV9RfLMJkSGp .sectionTitle0{fill:#333}#mermaid-svg-MTK7iV9RfLMJkSGp .sectionTitle1{fill:#333}#mermaid-svg-MTK7iV9RfLMJkSGp .sectionTitle2{fill:#333}#mermaid-svg-MTK7iV9RfLMJkSGp .sectionTitle3{fill:#333}#mermaid-svg-MTK7iV9RfLMJkSGp .sectionTitle{text-anchor:start;font-size:11px;text-height:14px;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-MTK7iV9RfLMJkSGp .grid .tick{stroke:#d3d3d3;opacity:0.8;shape-rendering:crispEdges}#mermaid-svg-MTK7iV9RfLMJkSGp .grid .tick text{font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-MTK7iV9RfLMJkSGp .grid path{stroke-width:0}#mermaid-svg-MTK7iV9RfLMJkSGp .today{fill:none;stroke:red;stroke-width:2px}#mermaid-svg-MTK7iV9RfLMJkSGp .task{stroke-width:2}#mermaid-svg-MTK7iV9RfLMJkSGp .taskText{text-anchor:middle;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-MTK7iV9RfLMJkSGp .taskText:not([font-size]){font-size:11px}#mermaid-svg-MTK7iV9RfLMJkSGp .taskTextOutsideRight{fill:#000;text-anchor:start;font-size:11px;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-MTK7iV9RfLMJkSGp .taskTextOutsideLeft{fill:#000;text-anchor:end;font-size:11px}#mermaid-svg-MTK7iV9RfLMJkSGp .task.clickable{cursor:pointer}#mermaid-svg-MTK7iV9RfLMJkSGp .taskText.clickable{cursor:pointer;fill:#003163 !important;font-weight:bold}#mermaid-svg-MTK7iV9RfLMJkSGp .taskTextOutsideLeft.clickable{cursor:pointer;fill:#003163 !important;font-weight:bold}#mermaid-svg-MTK7iV9RfLMJkSGp .taskTextOutsideRight.clickable{cursor:pointer;fill:#003163 !important;font-weight:bold}#mermaid-svg-MTK7iV9RfLMJkSGp .taskText0,#mermaid-svg-MTK7iV9RfLMJkSGp .taskText1,#mermaid-svg-MTK7iV9RfLMJkSGp .taskText2,#mermaid-svg-MTK7iV9RfLMJkSGp .taskText3{fill:#fff}#mermaid-svg-MTK7iV9RfLMJkSGp .task0,#mermaid-svg-MTK7iV9RfLMJkSGp .task1,#mermaid-svg-MTK7iV9RfLMJkSGp .task2,#mermaid-svg-MTK7iV9RfLMJkSGp .task3{fill:#8a90dd;stroke:#534fbc}#mermaid-svg-MTK7iV9RfLMJkSGp .taskTextOutside0,#mermaid-svg-MTK7iV9RfLMJkSGp .taskTextOutside2{fill:#000}#mermaid-svg-MTK7iV9RfLMJkSGp .taskTextOutside1,#mermaid-svg-MTK7iV9RfLMJkSGp .taskTextOutside3{fill:#000}#mermaid-svg-MTK7iV9RfLMJkSGp .active0,#mermaid-svg-MTK7iV9RfLMJkSGp .active1,#mermaid-svg-MTK7iV9RfLMJkSGp .active2,#mermaid-svg-MTK7iV9RfLMJkSGp .active3{fill:#bfc7ff;stroke:#534fbc}#mermaid-svg-MTK7iV9RfLMJkSGp .activeText0,#mermaid-svg-MTK7iV9RfLMJkSGp .activeText1,#mermaid-svg-MTK7iV9RfLMJkSGp .activeText2,#mermaid-svg-MTK7iV9RfLMJkSGp .activeText3{fill:#000 !important}#mermaid-svg-MTK7iV9RfLMJkSGp .done0,#mermaid-svg-MTK7iV9RfLMJkSGp .done1,#mermaid-svg-MTK7iV9RfLMJkSGp .done2,#mermaid-svg-MTK7iV9RfLMJkSGp .done3{stroke:grey;fill:#d3d3d3;stroke-width:2}#mermaid-svg-MTK7iV9RfLMJkSGp .doneText0,#mermaid-svg-MTK7iV9RfLMJkSGp .doneText1,#mermaid-svg-MTK7iV9RfLMJkSGp .doneText2,#mermaid-svg-MTK7iV9RfLMJkSGp .doneText3{fill:#000 !important}#mermaid-svg-MTK7iV9RfLMJkSGp .crit0,#mermaid-svg-MTK7iV9RfLMJkSGp .crit1,#mermaid-svg-MTK7iV9RfLMJkSGp .crit2,#mermaid-svg-MTK7iV9RfLMJkSGp .crit3{stroke:#f88;fill:red;stroke-width:2}#mermaid-svg-MTK7iV9RfLMJkSGp .activeCrit0,#mermaid-svg-MTK7iV9RfLMJkSGp .activeCrit1,#mermaid-svg-MTK7iV9RfLMJkSGp .activeCrit2,#mermaid-svg-MTK7iV9RfLMJkSGp .activeCrit3{stroke:#f88;fill:#bfc7ff;stroke-width:2}#mermaid-svg-MTK7iV9RfLMJkSGp .doneCrit0,#mermaid-svg-MTK7iV9RfLMJkSGp .doneCrit1,#mermaid-svg-MTK7iV9RfLMJkSGp .doneCrit2,#mermaid-svg-MTK7iV9RfLMJkSGp .doneCrit3{stroke:#f88;fill:#d3d3d3;stroke-width:2;cursor:pointer;shape-rendering:crispEdges}#mermaid-svg-MTK7iV9RfLMJkSGp .milestone{transform:rotate(45deg) scale(0.8, 0.8)}#mermaid-svg-MTK7iV9RfLMJkSGp .milestoneText{font-style:italic}#mermaid-svg-MTK7iV9RfLMJkSGp .doneCritText0,#mermaid-svg-MTK7iV9RfLMJkSGp .doneCritText1,#mermaid-svg-MTK7iV9RfLMJkSGp .doneCritText2,#mermaid-svg-MTK7iV9RfLMJkSGp .doneCritText3{fill:#000 !important}#mermaid-svg-MTK7iV9RfLMJkSGp .activeCritText0,#mermaid-svg-MTK7iV9RfLMJkSGp .activeCritText1,#mermaid-svg-MTK7iV9RfLMJkSGp .activeCritText2,#mermaid-svg-MTK7iV9RfLMJkSGp .activeCritText3{fill:#000 !important}#mermaid-svg-MTK7iV9RfLMJkSGp .titleText{text-anchor:middle;font-size:18px;fill:#000;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-MTK7iV9RfLMJkSGp g.classGroup text{fill:#9370db;stroke:none;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family);font-size:10px}#mermaid-svg-MTK7iV9RfLMJkSGp g.classGroup text .title{font-weight:bolder}#mermaid-svg-MTK7iV9RfLMJkSGp g.clickable{cursor:pointer}#mermaid-svg-MTK7iV9RfLMJkSGp g.classGroup rect{fill:#ECECFF;stroke:#9370db}#mermaid-svg-MTK7iV9RfLMJkSGp g.classGroup line{stroke:#9370db;stroke-width:1}#mermaid-svg-MTK7iV9RfLMJkSGp .classLabel .box{stroke:none;stroke-width:0;fill:#ECECFF;opacity:0.5}#mermaid-svg-MTK7iV9RfLMJkSGp .classLabel .label{fill:#9370db;font-size:10px}#mermaid-svg-MTK7iV9RfLMJkSGp .relation{stroke:#9370db;stroke-width:1;fill:none}#mermaid-svg-MTK7iV9RfLMJkSGp .dashed-line{stroke-dasharray:3}#mermaid-svg-MTK7iV9RfLMJkSGp #compositionStart{fill:#9370db;stroke:#9370db;stroke-width:1}#mermaid-svg-MTK7iV9RfLMJkSGp #compositionEnd{fill:#9370db;stroke:#9370db;stroke-width:1}#mermaid-svg-MTK7iV9RfLMJkSGp #aggregationStart{fill:#ECECFF;stroke:#9370db;stroke-width:1}#mermaid-svg-MTK7iV9RfLMJkSGp #aggregationEnd{fill:#ECECFF;stroke:#9370db;stroke-width:1}#mermaid-svg-MTK7iV9RfLMJkSGp #dependencyStart{fill:#9370db;stroke:#9370db;stroke-width:1}#mermaid-svg-MTK7iV9RfLMJkSGp #dependencyEnd{fill:#9370db;stroke:#9370db;stroke-width:1}#mermaid-svg-MTK7iV9RfLMJkSGp #extensionStart{fill:#9370db;stroke:#9370db;stroke-width:1}#mermaid-svg-MTK7iV9RfLMJkSGp #extensionEnd{fill:#9370db;stroke:#9370db;stroke-width:1}#mermaid-svg-MTK7iV9RfLMJkSGp .commit-id,#mermaid-svg-MTK7iV9RfLMJkSGp .commit-msg,#mermaid-svg-MTK7iV9RfLMJkSGp .branch-label{fill:lightgrey;color:lightgrey;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-MTK7iV9RfLMJkSGp .pieTitleText{text-anchor:middle;font-size:25px;fill:#000;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-MTK7iV9RfLMJkSGp .slice{font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-MTK7iV9RfLMJkSGp g.stateGroup text{fill:#9370db;stroke:none;font-size:10px;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-MTK7iV9RfLMJkSGp g.stateGroup text{fill:#9370db;fill:#333;stroke:none;font-size:10px}#mermaid-svg-MTK7iV9RfLMJkSGp g.statediagram-cluster .cluster-label text{fill:#333}#mermaid-svg-MTK7iV9RfLMJkSGp g.stateGroup .state-title{font-weight:bolder;fill:#000}#mermaid-svg-MTK7iV9RfLMJkSGp g.stateGroup rect{fill:#ECECFF;stroke:#9370db}#mermaid-svg-MTK7iV9RfLMJkSGp g.stateGroup line{stroke:#9370db;stroke-width:1}#mermaid-svg-MTK7iV9RfLMJkSGp .transition{stroke:#9370db;stroke-width:1;fill:none}#mermaid-svg-MTK7iV9RfLMJkSGp .stateGroup .composit{fill:white;border-bottom:1px}#mermaid-svg-MTK7iV9RfLMJkSGp .stateGroup .alt-composit{fill:#e0e0e0;border-bottom:1px}#mermaid-svg-MTK7iV9RfLMJkSGp .state-note{stroke:#aa3;fill:#fff5ad}#mermaid-svg-MTK7iV9RfLMJkSGp .state-note text{fill:black;stroke:none;font-size:10px}#mermaid-svg-MTK7iV9RfLMJkSGp .stateLabel .box{stroke:none;stroke-width:0;fill:#ECECFF;opacity:0.7}#mermaid-svg-MTK7iV9RfLMJkSGp .edgeLabel text{fill:#333}#mermaid-svg-MTK7iV9RfLMJkSGp .stateLabel text{fill:#000;font-size:10px;font-weight:bold;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-MTK7iV9RfLMJkSGp .node circle.state-start{fill:black;stroke:black}#mermaid-svg-MTK7iV9RfLMJkSGp .node circle.state-end{fill:black;stroke:white;stroke-width:1.5}#mermaid-svg-MTK7iV9RfLMJkSGp #statediagram-barbEnd{fill:#9370db}#mermaid-svg-MTK7iV9RfLMJkSGp .statediagram-cluster rect{fill:#ECECFF;stroke:#9370db;stroke-width:1px}#mermaid-svg-MTK7iV9RfLMJkSGp .statediagram-cluster rect.outer{rx:5px;ry:5px}#mermaid-svg-MTK7iV9RfLMJkSGp .statediagram-state .divider{stroke:#9370db}#mermaid-svg-MTK7iV9RfLMJkSGp .statediagram-state .title-state{rx:5px;ry:5px}#mermaid-svg-MTK7iV9RfLMJkSGp .statediagram-cluster.statediagram-cluster .inner{fill:white}#mermaid-svg-MTK7iV9RfLMJkSGp .statediagram-cluster.statediagram-cluster-alt .inner{fill:#e0e0e0}#mermaid-svg-MTK7iV9RfLMJkSGp .statediagram-cluster .inner{rx:0;ry:0}#mermaid-svg-MTK7iV9RfLMJkSGp .statediagram-state rect.basic{rx:5px;ry:5px}#mermaid-svg-MTK7iV9RfLMJkSGp .statediagram-state rect.divider{stroke-dasharray:10,10;fill:#efefef}#mermaid-svg-MTK7iV9RfLMJkSGp .note-edge{stroke-dasharray:5}#mermaid-svg-MTK7iV9RfLMJkSGp .statediagram-note rect{fill:#fff5ad;stroke:#aa3;stroke-width:1px;rx:0;ry:0}:root{--mermaid-font-family: '"trebuchet ms", verdana, arial';--mermaid-font-family: "Comic Sans MS", "Comic Sans", cursive}#mermaid-svg-MTK7iV9RfLMJkSGp .error-icon{fill:#522}#mermaid-svg-MTK7iV9RfLMJkSGp .error-text{fill:#522;stroke:#522}#mermaid-svg-MTK7iV9RfLMJkSGp .edge-thickness-normal{stroke-width:2px}#mermaid-svg-MTK7iV9RfLMJkSGp .edge-thickness-thick{stroke-width:3.5px}#mermaid-svg-MTK7iV9RfLMJkSGp .edge-pattern-solid{stroke-dasharray:0}#mermaid-svg-MTK7iV9RfLMJkSGp .edge-pattern-dashed{stroke-dasharray:3}#mermaid-svg-MTK7iV9RfLMJkSGp .edge-pattern-dotted{stroke-dasharray:2}#mermaid-svg-MTK7iV9RfLMJkSGp .marker{fill:#333}#mermaid-svg-MTK7iV9RfLMJkSGp .marker.cross{stroke:#333} :root { --mermaid-font-family: "trebuchet ms", verdana, arial;}</style> <style>#mermaid-svg-MTK7iV9RfLMJkSGp { color: rgba(0, 0, 0, 0.75); font: ; }</style>
s1
艾弗森NB
歐文
艾弗森
s2
s3
NB

從執行的程序可以看出,String物件“歐文”、“艾弗森”、“NB”在全程程序中都沒有改變,改變的只是參考s1所指向的內容,也就是s1的值,

下面的程式給予說明,String物件的不可變性,
在這里插入圖片描述
可以看出,盡管對s1依次呼叫了3個方法(toUpperCase、concat和substring),但是s1指向的String內容始終沒有改變,而s2、s3與s4確實輸出了期望的結果,這是因為,String類提供的一系列操作字串內容的方法都不是在自身物件上進行的,而是新創建一個String物件,例如,當呼叫toUpperCase時,并不是修改s1自身指向的String物件,而是新創建了一個String物件,其內容就是s1內容的大寫形式,因此,這樣既可以滿足對String物件的各種操作要求,又保證了String物件的資料成員不會被外界修改,

那為什么要把String設計為不可變呢
其最大的好處就是可以實作資源共享,在對執行緒操作的時候,可以將其認為不可變的,而不用擔心其他執行緒會對其進行修改

要點總結

  • String類是不可變類,其物件一旦創建,就不可修改,
  • String類那些看似修改字符序列的方法實際上都是新創建的String物件,而不是修改自身物件
  • 由于String物件是不可變的,因此其具有執行緒安全性,可以自由地實作共享

轉載請註明出處,本文鏈接:https://www.uj5u.com/qianduan/176396.html

標籤:其他

上一篇:【SSM - SpringMVC篇】日期格式轉換 把英文日期轉化為數字日期

下一篇:js中復選框的取值以及賦值

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • vue移動端上拉加載

    可能做得過于簡單或者比較low,請各位大佬留情,一起探討技術 ......

    uj5u.com 2020-09-10 04:38:07 more
  • 優美網站首頁,頂部多層導航

    一個個人用的瀏覽器首頁,可以把一下常用的網站放在這里,平常打開會比較方便。 第一步,HTML代碼 <script src=https://www.cnblogs.com/szharf/p/"js/jquery-3.4.1.min.js"></script> <div id="navigate"> <ul> <li class="labels labels_1"> ......

    uj5u.com 2020-09-10 04:38:47 more
  • 頁面為要加<!DOCTYPE html>

    最近因為寫一個js函式,需要用到$(window).height(); 由于手寫demo的時候,過于自信,其實對前端方面的認識也不夠體系,用文本檔案直接敲出來的html代碼,第一行沒有加上<!DOCTYPE html> 導致了$(window).height();的結果直接是整個document的高 ......

    uj5u.com 2020-09-10 04:38:52 more
  • WordPress網站程式手動升級要做好資料備份

    WordPress博客網站程式在進行升級前,必須要做好網站資料的備份,這個問題良家佐言是遇見過的;在剛開始接觸WordPress博客程式的時候,因為升級問題和博客網站的修改的一些嘗試,良家佐言是吃盡了苦頭。因為購買的是西部數碼的空間和域名,每當佐言把自己的WordPress博客網站搞到一塌糊涂的時候 ......

    uj5u.com 2020-09-10 04:39:30 more
  • WordPress程式不能升級為5.4.2版本的原因

    WordPress是一款個人博客系統,受到英文博客愛好者和中文博客愛好者的追捧,并逐步演化成一款內容管理系統軟體;它是使用PHP語言和MySQL資料庫開發的,用戶可以在支持PHP和MySQL資料庫的服務器上使用自己的博客。每一次WordPress程式的更新,就會牽動無數WordPress愛好者的心, ......

    uj5u.com 2020-09-10 04:39:49 more
  • 使用CSS3的偽元素進行首字母下沉和首行改變樣式

    網頁中常見的一種效果,首字改變樣式或者首行改變樣式,效果如下圖。 代碼: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, ......

    uj5u.com 2020-09-10 04:40:09 more
  • 關于a標簽的講解

    什么是a標簽? <a> 標簽定義超鏈接,用于從一個頁面鏈接到另一個頁面。 <a> 元素最重要的屬性是 href 屬性,它指定鏈接的目標。 a標簽的語法格式:<a href=https://www.cnblogs.com/summerxbc/p/"指定要跳轉的目標界面的鏈接">需要展示給用戶看見的內容</a> a標簽 在所有瀏覽器中,鏈接的默認外觀如下: 未被訪問的鏈接帶 ......

    uj5u.com 2020-09-10 04:40:11 more
  • 前端輪播圖

    在需要輪播的頁面是引入swiper.min.js和swiper.min.css swiper.min.js地址: 鏈接:https://pan.baidu.com/s/15Uh516YHa4CV3X-RyjEIWw 提取碼:4aks swiper.min.css地址 鏈接:https://pan.b ......

    uj5u.com 2020-09-10 04:40:13 more
  • 如何設定html中的背景圖片(全屏顯示,且不拉伸)

    1 <style>2 body{background-image:url(https://uploadbeta.com/api/pictures/random/?key=BingEverydayWallpaperPicture); 3 background-size:cover;background ......

    uj5u.com 2020-09-10 04:40:16 more
  • Java學習——HTML詳解(上)

    HTML詳解 初識HTML Hyper Text Markup Language(超文本標記語言) 1 <!--DOCTYPE:告訴瀏覽器我們要使用什么規范--> 2 <!DOCTYPE html> 3 <html lang="en"> 4 <head> 5 <!--meta 描述性的標簽,描述一些 ......

    uj5u.com 2020-09-10 04:40:33 more
最新发布
  • 我的第一個NPM包:panghu-planebattle-esm(胖虎飛機大戰)使用說明

    好家伙,我的包終于開發完啦 歡迎使用胖虎的飛機大戰包!! 為你的主頁添加色彩 這是一個有趣的網頁小游戲包,使用canvas和js開發 使用ES6模塊化開發 效果圖如下: (覺得圖片太sb的可以自己改) 代碼已開源!! Git: https://gitee.com/tang-and-han-dynas ......

    uj5u.com 2023-04-20 07:59:23 more
  • 生產事故-走近科學之消失的JWT

    入職多年,面對生產環境,盡管都是小心翼翼,慎之又慎,還是難免捅出簍子。輕則滿頭大汗,面紅耳赤。重則系統停擺,損失資金。每一個生產事故的背后,都是寶貴的經驗和教訓,都是專案成員的血淚史。為了更好地防范和遏制今后的各類事故,特開此專題,長期更新和記錄大大小小的各類事故。有些是親身經歷,有些是經人耳傳口授 ......

    uj5u.com 2023-04-18 07:55:04 more
  • 記錄--Canvas實作打飛字游戲

    這里給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 打開游戲界面,看到一個畫面簡潔、卻又富有挑戰性的游戲。螢屏上,有一個白色的矩形框,里面不斷下落著各種單詞,而我需要迅速地輸入這些單詞。如果我輸入的單詞與螢屏上的單詞匹配,那么我就可以獲得得分;如果我輸入的單詞錯誤或者時間過長,那么我就會輸 ......

    uj5u.com 2023-04-04 08:35:30 more
  • 了解 HTTP 看這一篇就夠

    在學習網路之前,了解它的歷史能夠幫助我們明白為何它會發展為如今這個樣子,引發探究網路的興趣。下面的這張圖片就展示了“互聯網”誕生至今的發展歷程。 ......

    uj5u.com 2023-03-16 11:00:15 more
  • 藍牙-低功耗中心設備

    //11.開啟藍牙配接器 openBluetoothAdapter //21.開始搜索藍牙設備 startBluetoothDevicesDiscovery //31.開啟監聽搜索藍牙設備 onBluetoothDeviceFound //30.停止監聽搜索藍牙設備 offBluetoothDevi ......

    uj5u.com 2023-03-15 09:06:45 more
  • canvas畫板(滑鼠和觸摸)

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>canves</title> <style> #canvas { cursor:url(../images/pen.png),crosshair; } #canvasdiv{ bo ......

    uj5u.com 2023-02-15 08:56:31 more
  • 手機端H5 實作自定義拍照界面

    手機端 H5 實作自定義拍照界面也可以使用 MediaDevices API 和 <video> 標簽來實作,和在桌面端做法基本一致。 首先,使用 MediaDevices.getUserMedia() 方法獲取攝像頭媒體流,并將其傳遞給 <video> 標簽進行渲染。 接著,使用 HTML 的 < ......

    uj5u.com 2023-01-12 07:58:22 more
  • 記錄--短視頻滑動播放在 H5 下的實作

    這里給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 短視頻已經無數不在了,但是主體還是使用 app 來承載的。本文講述 H5 如何實作 app 的視頻滑動體驗。 無聲勝有聲,一圖頂百辯,且看下圖: 網址鏈接(需在微信或者手Q中瀏覽) 從上圖可以看到,我們主要實作的功能也是本文要講解的有: ......

    uj5u.com 2023-01-04 07:29:05 more
  • 一文讀懂 HTTP/1 HTTP/2 HTTP/3

    從 1989 年萬維網(www)誕生,HTTP(HyperText Transfer Protocol)經歷了眾多版本迭代,WebSocket 也在期間萌芽。1991 年 HTTP0.9 被發明。1996 年出現了 HTTP1.0。2015 年 HTTP2 正式發布。2020 年 HTTP3 或能正... ......

    uj5u.com 2022-12-24 06:56:02 more
  • 【HTML基礎篇002】HTML之form表單超詳解

    ??一、form表單是什么

    ??二、form表單的屬性

    ??三、input中的各種Type屬性值

    ??四、標簽 ......

    uj5u.com 2022-12-18 07:17:06 more