Java入門6(String和封裝類)

来源:https://www.cnblogs.com/te9uila/archive/2023/04/18/17330421.html
-Advertisement-
Play Games

使用第三方jar包,完成get/set操作 Lombok,結合特殊的註解,實現setter和getter的自動生成 導入jar包 使用插件Lombok 在類里import 即可使用 import lombok.AllArgsConstructor; import lombok.Data; impor ...


使用第三方jar包,完成get/set操作

Lombok,結合特殊的註解,實現setter和getter的自動生成

  1. 導入jar包
  2. 使用插件Lombok
  3. 在類里import 即可使用
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;

// 使用註解@Data,在類編譯的時候,自動給class文件生成getter,setter,toString 以及其他方法
@Data
// 自動生成無參構造
@NoArgsConstructor
// 自動生成有參構造
@AllArgsConstructor
public class Person {
    private String name;
    private String sex;
    private int age;
}

系統常用類 String

// String類
public final class String
    implements java.io.Serializable, Comparable<String>, CharSequence {
    /** The value is used for character storage. */
    private final char value[];
    ...

​ String 底層是使用char數組進行存儲的,由於在String類中,char數組是用final修飾的,因此String類型的數據不可以被改變!!!

String str = "test01";
char[] cs = str.toCharArray();
// .toCharArray(),使用System.arraycopy方法,將String底層數組複製並輸出給cs

構造方法

String()無參構造
// String無參構造 -- 空字元串
String tmp = new String();
// 創建出來的空字元串預設沒有任何字元存儲
String(byte[] bytes)位元組數組(每一個字元所對應的字元集編碼)作為參數
// 將位元組數組,轉化為字元數組,再將字元數組拼接存儲到字元串中
byte[] bs = {65,66,67,68};
String tmp = new String(bs);
String(char[] value)char數組作為參數
// 將字元數組拼接存儲到字元串中
char[] cs = {'a','q','c'};
String tmp = new String(cs);
String (String original)String字元串作作為參數 ---- 字元數組的引用傳遞
// 將目標字元串底層存儲所使用的char數組的記憶體地址,傳遞給當前字元串對象所對應的字元數組引用
String tmp = new String("test");
// 等同於
// 使用等號賦值的字元串,預設會使用字元串常量池,來進行字元串對象的復用
String tmp = "test";

image-20230417150409215

等號和new定義字元串的區別

// 通過等號賦值直接定義的字元串是存放在運行時常量池中的,記憶體地址相同
String tmp = "test";
String tmp1 = "test";
System.out.println(tmp.equals(tmp1)); // true
System.out.println(tmp == tmp1); // true

// 而用new定義的字元串,實在堆中創建,記憶體地址不同
String tmp = new String("test");
String tmp1 = new String("test1");
System.out.println(tmp.equals(tmp1)); // true
System.out.println(tmp == tmp1); // false

equals方法源碼分析

​ 記憶體地址判斷 -> 長度判斷 -> 逐位比較

// 源碼
public boolean equals(Object anObject) {
    if (this == anObject) { // 判斷兩個對象記憶體地址是否相同
        return true;
    }
    if (anObject instanceof String) { // 判斷傳入的參數是不是String對象
        String anotherString = (String)anObject; // 向下轉型,方便後續訪問String特有的方法和屬性
        int n = value.length; // 當前調用equals方法的字元串所對應的char數組的長度
        if (n == anotherString.value.length) { // 判斷兩個字元串的長度是不是一致
            char v1[] = value; // v1代表當前字元串所對應的char數組
            char v2[] = anotherString.value; // v2代表參數字元串所對應的char數組
            int i = 0;
            while (n-- != 0) { // 逐位比較
                if (v1[i] != v2[i])
                    return false;
                i++;
            }
            return true;
        }
    }
    return false;
}

API方法

str.charAt()通過下表獲取索引處的值
String tmp = "test";
System.out.println(tmp.charAt(3)); // t
str.concat("...")返回拼接結果,不改變str本身
String tmp = "test";
System.out.println(tmp.concat(" plus")); // test plus
str.contains("...")判斷是否包含子字元串
String tmp = "test";
System.out.println(tmp.contains("es")); // true
str.endsWith("...")判斷是不是以...結尾
String tmp = "test";
System.out.println(tmp.endsWith("st")); // true
str.equalsIgnoreCase(String tmp)比較時忽略大小寫
String tmp = "test";
String tmp1 = "test01";
System.out.println(tmp.equalsIgnoreCase(tmp1)); // false
str.indexof("...")返回指定字元第一次出現時的索引值
String tmp = "test";
System.out.println(tmp.indexOf("t")); // 0
str.indexof("...",index)返回從index開始往後指定字元第一次出現時的索引值
String tmp = "test";
System.out.println(tmp.indexOf("t",2)); // 3
str.isEmpty當且僅當length()為0時返回true
String tmp = "test";
System.out.println(tmp.isEmpty()); // false
str.toCharArray()將字元串還原成char數組
String tmp = "test";
System.out.println(tmp.toCharArray()); // test
str.split("...")將字元串根據...拆分
String tmp = "This is a test";
String[] res = tmp.split(" ");
for (String i : res) {
    System.out.print(i + " \\ "); // This \ is \ a \ test \ 
}
str.startsWith(...)判斷是否以指定字元串開頭
String tmp = "This is a test";
System.out.println(tmp.startsWith("This")); // true
str.substring()字元串截取
String tmp = "This is a test";
// 一個參數確定開始位置
System.out.println(tmp.substring(3)); // s is a test
// 兩個參數確定起止位置(左閉右開)
System.out.println(tmp.substring(3,8)); // s is 
str.toLowerCase() / str.toUpperCase()將字元強制大小寫
String tmp = "This is a test";
System.out.println(tmp.toLowerCase()); // this is a test
System.out.println(tmp.toUpperCase()); // THIS IS A TEST
str.trim()去除前面和後面的空格
String tmp = "    This is a test    ";
System.out.println(tmp.trim()); // This is a test

系統常用類 StringBuffer / StringBuilder

區別

StringBuffer:支持線程安全,性能相對較差

StringBuilder: 不支持線程安全,性能相對較好

使用方式(StringBuilder為例)

// StringBuilder的底層數組比較String的數組,少了一個final修飾符,因此說明StingBuilder時可變的
// 構造方法:
// 無參構造
StringBuilder tmp = new StringBuilder();
// StringBuilder底層使用的是一個叫做value的字元數組(預設16個字元)
System.out.println(tmp.capacity()); // 16
// 如果不斷的使用append方法進行字元串拼接,StringBuilder就會自動擴容
tmp.append("Hei bro, this is a test !");
System.out.println(tmp.capacity()); // 34

// 有參構造
// 如果出現有參構造,StringBuilder的容量會在初始化字元串的基礎上加上16
StringBuilder tmp = new StringBuilder("This is a test");
System.out.println(tmp.capacity()); // 30

StringBuilder擴容機制

​ 新數組容量 =(原數組的容量+1)*2 :這種擴容機制會使擴容的次數越來越少,增加性能

// 如果StringBuilder需要擴容,就會定義一個新的char數組
// 新數組容量是(原數組的容量+1)*2
// 並且會將指向原數組的指針指向新數組,原數組會被GC進行回收
private int newCapacity(int minCapacity) {
    // overflow-conscious code
    int newCapacity = (value.length << 1) + 2;
    if (newCapacity - minCapacity < 0) {
        newCapacity = minCapacity;
    }
    return (newCapacity <= 0 || MAX_ARRAY_SIZE - newCapacity < 0)
        ? hugeCapacity(minCapacity)
        : newCapacity;
}

API方法(StringBuilder特殊的)

str.capacity()返回StringBuilder容量
str.delete(a,b)刪除此序列的子字元串中的字元
// 刪除子字元串之後,並不影響StringBuilder容量
StringBuilder tmp = new StringBuilder("This is a test");
System.out.println(tmp.delete(3,8)); // Thia test
str.deleteCharAt(a)刪除指定下標的元素
str.replace(a,b,...) 用指定字元串替換指定區間
StringBuilder tmp = new StringBuilder("This is a test");
System.out.println(tmp.replace(4,8," have fun! ")); // This have fun! a test
str.setCharAt()設定指定位置的字元
StringBuilder tmp = new StringBuilder("This is a test");
tmp.setCharAt(4,'G');
System.out.println(tmp); // ThisGis a test
str.toString()創建一個新的String對象,去除尾部多餘的空格
@Override
public String toString() {
    // Create a copy, don't share the array
    return new String(value, 0, count);
}
System.out.println(System.currentTimeMillis());

封裝類

​ 針對八種基本數據類型進行定義以及使用的,封裝類有八個

基本數據類型 對應的封裝類
byte Byte
short Short
int Integer
long Long
float Float
double Double
char Character

賦值的兩種使用方式

// 四種整型的封裝類支持使用常量池技術(-128 ~ 127)
// 通過 = 號賦值的整數,會被存儲在常量池中

// 等號直接賦值(常量池)
Integer tmp1 = 1;
// 使用構造方法(堆)
Integer tmp2 = new Integer(1);

Scanner鍵盤獲取

// 導入包
import java.util.Scanner;
// 使用Scanner類創建一個對象
Scanner s = new Scanner(System.in);
// 獲取系統輸入
// 獲取String類型數據
String input = s.nextline();
// 獲取整型數據
int input = Integer.parseInt(s.nextLine());
// 獲取浮點型數據
float input = Float.parseFloat(s.nextLine());

裝箱和拆箱

裝箱:將基本類型轉換為封裝類類型的過程

拆箱:將封裝類類型轉換為基本類型的過程

int a = 1;
Integer b = 1;
// 自動裝箱
Integer tmp = a;
// 手動裝箱
Integer tmp = new Interger(a);
// 自動拆箱
int tmp = b;
// 手動拆箱
int tmp = b.intValue();

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 本文是從開源項目 RuoYi 的提交記錄文字描述中根據關鍵字漏洞|安全|阻止篩選而來。旨在為大家介紹日常項目開發中需要註意的一些安全問題以及如何解決。 項目安全是每個開發人員都需要重點關註的問題。如果項目漏洞太多,很容易遭受黑客攻擊與用戶信息泄露的風險。本文將結合3個典型案例,解釋常見的安全漏洞及修 ...
  • 項目介紹&功能實現 1.項目介紹&環境搭建 一個以社交平臺為核心的輕電商項目,功能如下: 簡訊登錄、商戶查詢緩存、優惠券秒殺、達人探店、好友關註、附近的商戶、用戶簽到、UV統計 1.1項目架構 1.2項目環境搭建 1.2.1後端項目搭建 mysql的版本採用5.7及以上版本 (1)首先創建資料庫,需 ...
  • 本文首發於公眾號:Hunter後端 原文鏈接:Django筆記二十四之資料庫函數之比較和轉換函數 這一篇筆記開始介紹幾種資料庫函數,以下是幾種函數及其作用 Cast 轉換類型 Coalesce 優先取值 Greatest 返回較大值 Nullif 值相同返回 None 1、model 準備 這一篇筆 ...
  • 網路分層結構 電腦網路體系大致分為三種,OSI七層模型、TCP/IP四層模型和五層模型。一般面試的時候考察比較多的是五層模型。最全面的Java面試網站 五層模型:應用層、傳輸層、網路層、數據鏈路層、物理層。 應用層:為應用程式提供交互服務。在互聯網中的應用層協議很多,如功能變數名稱系統DNS、HTTP協議 ...
  • 一、哆啦A夢 由於代碼過長,這裡僅顯示部分代碼: from turtle import * import turtle as t from random import * #五軌跡跳躍 def my_goto(x,y): penup() goto(x,y) pendown() def eyes(): ...
  • Go語言流媒體開源項目 LAL 今天發佈了v0.35.4版本。 LAL 項目地址:https://github.com/q191201771/lal 老規矩,簡單介紹一下: ▦ 一. OBS支持RTMP H265推流 新出的標準,一般被稱為enhanced RTMP,OBS新版(29.1+版本,點我 ...
  • 什麼是冒泡排序 冒泡排序(Bubble Sort)也是一種簡單直觀的排序演算法。它重覆地走訪過要排序的數列,一次比較兩個元素,如果他們的順序錯誤就把他們交換過來。走訪數列的工作是重覆地進行直到沒有再需要交換,也就是說該數列已經排序完成。這個演算法的名字由來是因為越小的元素會經由交換慢慢"浮"到數列的頂端 ...
  • 平時開發時的工作的話之主要負責寫代碼就行了,什麼發佈項目啊,好吧不是我們乾的事。在我們的瞭解中打包發佈項目應該不是一個困難的問題。 對,最簡單的方法就行使用直接使用maven插件打包,甚至我們都不需要知道他是怎麼實現的,插件能幫我們將項目打包為一個jar包,然後使用java -jar xx.jar就 ...
一周排行
    -Advertisement-
    Play Games
  • 前言 本文介紹一款使用 C# 與 WPF 開發的音頻播放器,其界面簡潔大方,操作體驗流暢。該播放器支持多種音頻格式(如 MP4、WMA、OGG、FLAC 等),並具備標記、實時歌詞顯示等功能。 另外,還支持換膚及多語言(中英文)切換。核心音頻處理採用 FFmpeg 組件,獲得了廣泛認可,目前 Git ...
  • OAuth2.0授權驗證-gitee授權碼模式 本文主要介紹如何筆者自己是如何使用gitee提供的OAuth2.0協議完成授權驗證並登錄到自己的系統,完整模式如圖 1、創建應用 打開gitee個人中心->第三方應用->創建應用 創建應用後在我的應用界面,查看已創建應用的Client ID和Clien ...
  • 解決了這個問題:《winForm下,fastReport.net 從.net framework 升級到.net5遇到的錯誤“Operation is not supported on this platform.”》 本文內容轉載自:https://www.fcnsoft.com/Home/Sho ...
  • 國內文章 WPF 從裸 Win 32 的 WM_Pointer 消息獲取觸摸點繪製筆跡 https://www.cnblogs.com/lindexi/p/18390983 本文將告訴大家如何在 WPF 裡面,接收裸 Win 32 的 WM_Pointer 消息,從消息裡面獲取觸摸點信息,使用觸摸點 ...
  • 前言 給大家推薦一個專為新零售快消行業打造了一套高效的進銷存管理系統。 系統不僅具備強大的庫存管理功能,還集成了高性能的輕量級 POS 解決方案,確保頁面載入速度極快,提供良好的用戶體驗。 項目介紹 Dorisoy.POS 是一款基於 .NET 7 和 Angular 4 開發的新零售快消進銷存管理 ...
  • ABP CLI常用的代碼分享 一、確保環境配置正確 安裝.NET CLI: ABP CLI是基於.NET Core或.NET 5/6/7等更高版本構建的,因此首先需要在你的開發環境中安裝.NET CLI。這可以通過訪問Microsoft官網下載並安裝相應版本的.NET SDK來實現。 安裝ABP ...
  • 問題 問題是這樣的:第三方的webapi,需要先調用登陸介面獲取Cookie,訪問其它介面時攜帶Cookie信息。 但使用HttpClient類調用登陸介面,返回的Headers中沒有找到Cookie信息。 分析 首先,使用Postman測試該登陸介面,正常返回Cookie信息,說明是HttpCli ...
  • 國內文章 關於.NET在中國為什麼工資低的分析 https://www.cnblogs.com/thinkingmore/p/18406244 .NET在中國開發者的薪資偏低,主要因市場需求、技術棧選擇和企業文化等因素所致。歷史上,.NET曾因微軟的閉源策略發展受限,儘管後來推出了跨平臺的.NET ...
  • 在WPF開發應用中,動畫不僅可以引起用戶的註意與興趣,而且還使軟體更加便於使用。前面幾篇文章講解了畫筆(Brush),形狀(Shape),幾何圖形(Geometry),變換(Transform)等相關內容,今天繼續講解動畫相關內容和知識點,僅供學習分享使用,如有不足之處,還請指正。 ...
  • 什麼是委托? 委托可以說是把一個方法代入另一個方法執行,相當於指向函數的指針;事件就相當於保存委托的數組; 1.實例化委托的方式: 方式1:通過new創建實例: public delegate void ShowDelegate(); 或者 public delegate string ShowDe ...