常用类1(内部类、Object类、String类)-第一阶段-第十一天-2021-7-27

2024-02-25 18:08

本文主要是介绍常用类1(内部类、Object类、String类)-第一阶段-第十一天-2021-7-27,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1. 内部类

在一个类的内部又定义了另外一个完整的类,类的定义上的嵌套

内部类分为:成员内部类 静态内部类 局部内部类 匿名内部类(局部内部类)

1.1 成员内部类

  1. 成员内部类和属性方法同一级别
  2. 内部内的方法中可以直接访问外部类的成员
    如果成员内部类中存在和外部类同名的属性优先访问自己的,如果非要访问外部类对象中的属性,使用语法:外部类名称.this.成员变量
  3. 在成员内部类中不能定义静态的成员,因为内部类对象必须依赖外部类对象的存在而存在,但是static类型的成员无法保证外部类对象是否创建了,这是可以使用静态内部类,在类的修饰前面加上一个static关键字

1.2 局部内部类

  1. 将类的定义放在某个方法的内部
    方法中定义的内容不能使用访问权限修饰符
    方法中定义的类只能在当前方法中去使用
  2. 在局部内部类中可以访问当前方法的局部变量,但是这个变量在JDK的高版本中无需显示的去指定默认就是final不可变的
  3. 使用匿名内部类的方式来解决类的泛滥问题
    匿名内部类本质上就是一个局部内部内
    语法:new 接口名称(){//对接口的方法进行实现}

2. Object类

object类是所有类的根基类,任何类都直接或者间接的继承了Object类
在方法设计的时候,如果形参为Object类型,那么就可以通过向上转型(父类的引用指向子类的对象)来指向传入对象,然后通过向下转型(指向子类对象的父类引用被强制转换为子类的引用)来调用相应的方法。

Object类的常用方法

  1. getClass()方法:获取当前对象的实际类型(类名)
  2. toString()方法:获取当前对象的地址值(一般用来被子类重写)
  3. hashCode()方法:获取当前对象的哈希码(地址值的十进制)
  4. equals()方法:判断两个对象的地址值是否相同(一般用来重写)
  5. finalist()方法:和垃圾回收相关

3. String类

3.1 String类的两种创建方式

String string1 = "abcd";
String string1 = new String("efgh");

3.2 String两张不同创建方式的内存分析

//1.字面量的方式
String s1="hello";
//2.new的方式
String s2=new String("hello");
System.out.println(s1==s2);//false
System.out.println(s1.equals(s2));//true
String s3="hello";
String s4=new String("hello");
System.out.println(s1==s3);//true
System.out.println(s2==s4);//false
  1. 通过字面量的方式创建字符串的时候会直接指向内存中的字符串常量池(串池)的值
  2. 通过创建对象的方式创建字符串的时候,会先指向堆中的对象,然后通过对象再去指向常量池中的值

3.3 和一般的引用数据类型不同,String具有不可变性

我们说的字符串不可变指的是字符串内容,一个字符串一旦在内存中创建好了之后就不能被改变
如果在创建好的字符串后面继续添加字符,那么这个添加的字符会在常量池中开辟一个新的空间来表示添加后的字符串。

3.4 java中将String类设置成不可见的方式和理由

在原码中java将String设置为

private final char[] value;
//一个字符串对象其实是通过内部的一个char类型的数组来保存这个字符串的内容
//final保证了变量value这个数组的引用不可变得
//private:只能在String类的内部被使用,同时String类对外没有提供对应的get和set方法

设置为这样的理由为:

  1. 为了实现共享,串池的实现
  2. 为了线程的安全

3.5 String类的常用方法

package com.qianfeng.day11;public class StringWorkMethodTest {public static void main(String[] args) {//1.charAt(int index)System.out.println("1).charAt(int index)  返回 char指定索引处的值。返回值char类型");//遍历整个字符串String aString = "abcdefg";for (int i = 0; i < aString.length(); i++) {System.out.print(aString.charAt(i));}//2.compareTo(String anotherString)和compareToIgnoreCase(String str)System.out.println("\n\n2).compareTo(String anotherString) 按字典顺序比较两个字符串。比较其ASCII码\n"+ "compareToIgnoreCase(String str) 比较两个字符串但忽略大小写 返回值类型皆为int");//名单排序String bString = "cdefghi";System.out.println(bString.compareTo(aString));System.out.println("B".compareTo(aString));System.out.println("B".compareToIgnoreCase(aString));//3.concat(String str)System.out.println("\n3).concat(String str) 字符串连接  相当于是+。返回值为String");String cString = "123";System.out.println(cString.concat("abc"));//4.contains(CharSequence s)System.out.println("\n4).contains(CharSequence s) 判断一个字符串中是否包含另一个字符串。返回值为boolean");//判断邮箱地址是否合法String dString = "1434@162.com";if (dString.contains("@162.com")) {System.out.println("确定为网易云邮箱");} else {System.out.println("邮箱格式错误");}//5.endsWith(String suffix)System.out.println("\n5).endsWith(String suffix) 判断某个字符串是否以另一个字符串结尾,返回值boolean");//判断文件格式是否正确String eString = "图片.png";if (eString.endsWith(".png")) {System.out.println("格式正确能够上传");} else {System.out.println("格式错误,请重新上传");}//6.equals(Object anObject)System.out.println("\n6).equals(Object anObject) 判断两个字符串的内容是否相等,返回一个boolean值");String fString = "hello";System.out.println(fString.equals("hello"));//7.equalsIgnoreCase(String anotherString)System.out.println("\n7).equalsIgnoreCase(String anotherString) 忽略大小写比较,返回boolean类型");String gString = "Hello";System.out.println(gString.equalsIgnoreCase("hello"));//8.toLowerCase()和toUpperCase()System.out.println("\n8).toLowerCase()转为小写 toUpperCase()转为大写 大小写转换,返回值为String");String hString = "Hello World";System.out.println(hString.toLowerCase());System.out.println(hString.toUpperCase());//9.hashCode()System.out.println("\n9).hashCode() 获取字符串的哈希码,返回值为int");String iString = "wer";System.out.println(iString.hashCode());//10.indexOf(int ch)System.out.println("\n10).indexOf(int ch) 从字符串中获取某个字符第一次出现的位置,返回值为int");String jString = "abc1defgh";System.out.println(jString.indexOf("1de"));//11.isEmpty()System.out.println("\n11).isEmpty()判断字符串是否为空   注意这里的空不是null,返回值类型为boolean");String kString = "";System.out.println(kString.isEmpty());//12.replace(char oldChar, char newChar)System.out.println("\n12).replace(char oldChar, char newChar) 将与字面目标序列匹配的字符串的每个子字符串替换为指定的字面替换序列。"+ "返回值类型为String");String lString = "哈哈嘿嘿哈哈吼吼";System.out.println(lString.replace("哈哈", "滋滋"));//13.split(String regex)System.out.println("\n13).split(String regex) 对字符串按照某个指定的字符进行分割,返回一个字符串数组");String mString = "你,我,他,她,它";String[] arr = mString.split(",");for (int i = 0; i < arr.length; i++) {System.out.println(arr[i]);}//14.substring(int beginIndex)System.out.println("\n14).substring(int beginIndex) 字符串的截取,返回值是一个String类型"+ ".substring(int beginIndex, int endIndex) >=beginIndex <endIndex");String nString = "123456";System.out.println(nString.substring(2));//15.trim()System.out.println("\n15).trim() 对字符串去除前后的空格,不能去除中间的空间,返回值为String");String oString = "   meng fan   ";System.out.println(oString.length());System.out.println(oString.trim());System.out.println(oString.length());}
}

API截图
在这里插入图片描述

3.6 可变字符串

由于String类型在改变它的值的时候会在常量池中去创建一个新的地址,如果多次操作会导致对空间的损耗太大

3.6.1 StringBuffer的构造方法

>

3.6.2 StringBuffer的常用方法

StringBuffer sb = new StringBuffer("abc");
//sb = sb + "123";这种方式是错误的,StringBuffer类型字符串不能用+的方式完成拼接
sb.append("123");//完成字符串拼接的正确姿势
System.out.println(sb);//abc123
sb.insert(4, "hello");//在指定位置插入字符串
System.out.println(sb);//abc1hello123

虽然StringBuffer有着大多数的字符串处理方法,但是相比较于String来说还是少了一些常用方法,所以可以通过StringBuffer中toString方法来转化为String来进行操作。

3.6.3 StringBuilder的用法

StringBuilder的用法和StringBuffer用法完全一致,处理的效率更高

3.7 String、StringBuffer、StringBuilder三者的区别

  1. String类型的字符串为不可变型,对内存的损耗太大,但是它能够实现共享和字符安全,还有很多好用的方法
  2. StringBuffer类型的字符串类型,为可变类型,在内存中可以直接对原有值进行改变,对内存消耗较小,而且在StringBuffer中几乎每一个方法都用synchronized(同步化)关键字进行修饰,保证线程的安全。
  3. StringBuilder类型的字符串类型虽然用法跟StringBuffer一样,但是在原码当中,StringBuilder类型没有线程保护,相对来说它处理字符的效率更高。

这篇关于常用类1(内部类、Object类、String类)-第一阶段-第十一天-2021-7-27的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/746276

相关文章

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

JS常用组件收集

收集了一些平时遇到的前端比较优秀的组件,方便以后开发的时候查找!!! 函数工具: Lodash 页面固定: stickUp、jQuery.Pin 轮播: unslider、swiper 开关: switch 复选框: icheck 气泡: grumble 隐藏元素: Headroom

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

常用的jdk下载地址

jdk下载地址 安装方式可以看之前的博客: mac安装jdk oracle 版本:https://www.oracle.com/java/technologies/downloads/ Eclipse Temurin版本:https://adoptium.net/zh-CN/temurin/releases/ 阿里版本: github:https://github.com/

30常用 Maven 命令

Maven 是一个强大的项目管理和构建工具,它广泛用于 Java 项目的依赖管理、构建流程和插件集成。Maven 的命令行工具提供了大量的命令来帮助开发人员管理项目的生命周期、依赖和插件。以下是 常用 Maven 命令的使用场景及其详细解释。 1. mvn clean 使用场景:清理项目的生成目录,通常用于删除项目中自动生成的文件(如 target/ 目录)。共性规律:清理操作

019、JOptionPane类的常用静态方法详解

目录 JOptionPane类的常用静态方法详解 1. showInputDialog()方法 1.1基本用法 1.2带有默认值的输入框 1.3带有选项的输入对话框 1.4自定义图标的输入对话框 2. showConfirmDialog()方法 2.1基本用法 2.2自定义按钮和图标 2.3带有自定义组件的确认对话框 3. showMessageDialog()方法 3.1

工作常用指令与快捷键

Git提交代码 git fetch  git add .  git commit -m “desc”  git pull  git push Git查看当前分支 git symbolic-ref --short -q HEAD Git创建新的分支并切换 git checkout -b XXXXXXXXXXXXXX git push origin XXXXXXXXXXXXXX

STM32内部闪存FLASH(内部ROM)、IAP

1 FLASH简介  1 利用程序存储器的剩余空间来保存掉电不丢失的用户数据 2 通过在程序中编程(IAP)实现程序的自我更新 (OTA) 3在线编程(ICP把整个程序都更新掉) 1 系统的Bootloader写死了,只能用串口下载到指定的位置,启动方式也不方便需要配置BOOT引脚触发启动  4 IAP(自己写的Bootloader,实现程序升级) 1 比如蓝牙转串口,

java常用面试题-基础知识分享

什么是Java? Java是一种高级编程语言,旨在提供跨平台的解决方案。它是一种面向对象的语言,具有简单、结构化、可移植、可靠、安全等特点。 Java的主要特点是什么? Java的主要特点包括: 简单性:Java的语法相对简单,易于学习和使用。面向对象:Java是一种完全面向对象的语言,支持封装、继承和多态。跨平台性:Java的程序可以在不同的操作系统上运行,称为"Write once,

nginx介绍及常用功能

什么是nginx nginx跟Apache一样,是一个web服务器(网站服务器),通过HTTP协议提供各种网络服务。 Apache:重量级的,不支持高并发的服务器。在Apache上运行数以万计的并发访问,会导致服务器消耗大量内存。操作系统对其进行进程或线程间的切换也消耗了大量的CPU资源,导致HTTP请求的平均响应速度降低。这些都决定了Apache不可能成为高性能WEB服务器  nginx: