尚硅谷Java自学习
尚硅谷Java自学习
小太阳i
这个作者很懒,什么都没留下…
展开
-
Java自学习-枚举类的使用
1.枚举类的说明:1.枚举类的理解:类的对象只有有限个,确定的。我们称此类为枚举类2.当需要定义一组常量时,强烈建议使用枚举类3.如果枚举类中只一个对象,则可以作为单例模式的实现方式。2.如何自定义枚举类?步骤://自定义枚举类class Season{ //1.声明Season对象的属性:private final修饰 private final String seasonName; private final String seasonDesc; /原创 2021-06-09 14:50:57 · 82 阅读 · 0 评论 -
Java自学习day20-System类、Math类、BigInteger类、BigDecimal类
Java自学习day20-每日一考原创 2021-05-17 23:00:25 · 127 阅读 · 0 评论 -
Java自学习day20-Java比较器
Java中两个Date类的使用原创 2021-05-17 22:59:31 · 123 阅读 · 0 评论 -
Java自学习day20-JDK 8之前日期时间API
Java语言高级-String、StringBuffer、StringBuilder效率对比原创 2021-05-17 22:58:20 · 108 阅读 · 0 评论 -
Java自学习day20-StringBuffer和StringBuilder的介绍
StringBuffer和StringBuilder的介绍原创 2021-05-17 22:57:46 · 144 阅读 · 0 评论 -
Java自学习day20-面试string考察问题
Java自学习day20-面试string考察问题原创 2021-05-17 22:55:38 · 115 阅读 · 0 评论 -
Java自学习day22-自定义注解
package com.atguigu.java1;import org.junit.Test;import java.lang.annotation.Annotation;import java.util.ArrayList;import java.util.Date;/** * 3. 如何自定义注解:参照@SuppressWarnings定义 * ① 注解声明为:@interface * ② 内部定义成员,通常使用value表示 * ③ 可以..原创 2021-05-17 16:43:12 · 127 阅读 · 0 评论 -
Java自学习day22-JDK内置的三个基本注解
JDK内置的三个基本注解 @Override: 限定重写父类方法, 该注解只能用于方法 @Deprecated: 用于表示所修饰的元素(类, 方法等)已过时。通常是因为所修饰的结构危险或存在更好的选择 @SuppressWarnings: 抑制编译器警告package com.atguigu.java1;import org.junit.Test;import java.lang.annotation.Annotation;import java.util.Arr原创 2021-05-17 16:18:24 · 163 阅读 · 0 评论 -
Java自学习day22-注解的理解
注解的概述1.从 JDK 5.0 开始, Java 增加了对元数据(MetaData) 的支持, 也就是Annotation(注解)2.Annotation 其实就是代码里的特殊标记, 这些标记可以在编译, 类加载, 运行时被读取, 并执行相应的处理。通过使用 Annotation, 程序员可以在不改变原有逻辑的情况下, 在源文件中嵌入一些补充信息。代码分析工具、开发工具和部署工具可以通过这些补充信息进行验证或者进行部署。3.Annotation 可以像修饰符一样被使用, 可用于修饰包,类, 构造器原创 2021-05-17 15:10:33 · 86 阅读 · 0 评论 -
Java自学习day20- String 与 byte[]之间的转换
package com.atguigu.java;import org.junit.Test;import java.io.UnsupportedEncodingException;import java.util.Arrays;public class StringTest1 { /* String 与 byte[]之间的转换 编码:String --> byte[]:调用String的getBytes() 解码:byte[] --> Str原创 2021-05-17 10:04:29 · 111 阅读 · 0 评论 -
Java自学习day20-String与char[]之间转换
package com.atguigu.java;import org.junit.Test;import java.io.UnsupportedEncodingException;import java.util.Arrays;public class StringTest1 { /* String 与 char[]之间的转换 String --> char[]:调用String的toCharArray() char[] --> Strin原创 2021-05-17 10:03:35 · 111 阅读 · 0 评论 -
Java自学习day20-String常用方法
package com.atguigu.java;import org.junit.Test;public class StringMethodTest { /*替换:String replace(char oldChar, char newChar):返回一个新的字符串,它是通过用 newChar 替换此字符串中出现的所有 oldChar 得到的。String replace(CharSequence target, CharSequence replacement):使用指..原创 2021-05-16 20:39:28 · 116 阅读 · 0 评论 -
Java自学习day20-String面试题-char[] ch = { ‘t‘, ‘e‘, ‘s‘, ‘t‘ };
package com.atguigu.exer;public class StringTest { String str = new String("good"); char[] ch = { 't', 'e', 's', 't' }; public void change(String str, char ch[]) { str = "test ok"; ch[0] = 'b'; } public static void m原创 2021-05-16 18:59:32 · 555 阅读 · 1 评论 -
Java自学习day20-String不同拼接操作的对比
String不同拼接操作的对比结论:1.常量与常量的拼接结果在常量池。且常量池中不会存在相同内容的常量。2.只要其中有一个是变量,结果就在堆中。3.如果拼接的结果调用intern()方法,返回值就在常量池中package com.atguigu.java;import org.junit.Test;public class StringTest { @Test public void test4(){ String s1 = "javaEEhadoo原创 2021-05-16 18:39:41 · 139 阅读 · 0 评论 -
Java自学习day20-String不同实例化方式对比
String的实例化方式: 方式一:通过字面量定义的方式 方式二:通过new + 构造器的方式 面试题:String s = new String("abc");方式创建对象,在内存中创建了几个对象? 两个:一个是堆空间中new结构,另一个是char[]对应的常量池中的数据:"abc"package com.atguigu.java;import org.junit.Test;public class StringTest { */原创 2021-05-16 17:21:42 · 153 阅读 · 0 评论 -
Java自学习day20-理解String不可变性及使用
String:字符串,使用一对""引起来表示。 1.String声明为**final**的,**不可被继承** 2.String实现了Serializable接口:表示字符串是支持**序列化**的。 实现了Comparable接口:表示String可以**比较大小** 3.String内部定义了final char[] **value用于存储字符串数据** 4.String:代表**不可变的字符序列**。简称:不可变性。 体现:1.当对原创 2021-05-16 15:25:02 · 202 阅读 · 1 评论 -
Java自学习day20-多线程总结下(Thread类、线程的同步机制、同步代码块、Lock锁、线程安全的单例模式、死锁问题、线程通信)
Thread类中的常用的方法* 1. start():启动当前线程;调用当前线程的run()* 2. run(): 通常需要重写Thread类中的此方法,将创建的线程要执行的操作声明在此方法中* 3. currentThread():静态方法,返回执行当前代码的线程* 4. getName():获取当前线程的名字* 5. setName():设置当前线程的名字* 6. yield():释放当前cpu的执行权* 7. join():在线程a中调用线程b的join(),此时线程a就进入阻塞状态,直原创 2021-05-16 14:04:20 · 171 阅读 · 0 评论 -
Java自学习day19-创建线程的方式四:使用线程池
创建线程的方式四:使用线程池 * 好处: * 1.提高响应速度(减少了创建新线程的时间) * 2.降低资源消耗(重复利用线程池中线程,不需要每次都创建) * 3.便于线程管理 * corePoolSize:核心池的大小 * maximumPoolSize:最大线程数 * keepAliveTime:线程没有任务时最多保持多长时间后会终止面试题:创建多线程有几种方式?四种!package com.atguigu.java2;import java.uti转载 2021-05-16 13:06:25 · 87 阅读 · 0 评论 -
Java自学习day19-创建线程的方式三:实现Callable接口
创建线程的方式三:实现Callable接口。 — JDK 5.0新增如何理解实现Callable接口的方式创建多线程比实现Runnable接口创建多线程方式强大? * 1. call()可以有返回值的。 * 2. call()可以抛出异常,被外面的操作捕获,获取异常的信息 * 3. Callable是支持泛型的package com.atguigu.java2;import java.util.concurrent.Callable;import java.util.concurrent.原创 2021-05-16 12:00:48 · 114 阅读 · 0 评论 -
Java自学习day19-线程通信的应用:经典例题:生产者/消费者问题
生产者(Productor)将产品交给店员(Clerk),而消费者(Customer)从店员处取走产品,店员一次只能持有固定数量的产品(比如:20),如果生产者试图生产更多的产品,店员会叫生产者停一下,如果店中有空位放产品了再通知生产者继续生产;如果店中没有产品了,店员会告诉消费者等一下,如果店中有产品了再通知消费者来取走产品。分析: * 1. 是否是多线程问题?是,生产者线程,消费者线程 * 2. 是否有共享数据?是,店员(或产品) * 3. 如何解决线程的安全问题?同步机制,有三种方法 * 4原创 2021-05-16 12:00:18 · 157 阅读 · 0 评论 -
Java自学习day19-面试题:sleep() 和 wait()的异同?
面试题:sleep() 和 wait()的异同? * 1.相同点:一旦执行方法,都可以使得当前的线程进入阻塞状态。 * 2.不同点:1)两个方法声明的位置不同:Thread类中声明sleep() , Object类中声明wait() * 2)调用的要求不同:sleep()可以在任何需要的场景下调用。 wait()必须使用在同步代码块或同步方法中 * 3)关于是否释放同步监视器:如果两个方法都使用在同步代码块或同步方法中,sleep()不会释放锁,wait()会释放原创 2021-05-16 12:00:33 · 122 阅读 · 0 评论 -
Java自学习day19-wait()、notify()、notifyall()——使用两个线程打印 1-100。线程1, 线程2 交替打印
线程通信的例子:使用两个线程打印 1-100。线程1, 线程2 交替打印涉及到的三个方法: * wait():一旦执行此方法,当前线程就进入阻塞状态,并释放同步监视器。 * notify():一旦执行此方法,就会唤醒被wait的一个线程。如果有多个线程被wait,就唤醒优先级高的那个。 * notifyAll():一旦执行此方法,就会唤醒所有被wait的线程。 * * 说明: * 1.wait(),notify(),notifyAll()三个方法必须使用在同步代码块或同步方法中。 * 2.w转载 2021-05-15 19:23:36 · 230 阅读 · 0 评论 -
Java自学习day19-两个储户分别向同一个账户存3000元,每次存1000,存3次。每次存完打印账户余额
银行有一个账户。有两个储户分别向同一个账户存3000元,每次存1000,存3次。每次存完打印账户余额。分析:1.是否是多线程问题? 是,两个储户线程2.是否有共享数据? 有,账户(或账户余额)3.是否有线程安全问题?有4.需要考虑如何解决线程安全问题?同步机制:有三种方式。package com.atguigu.exer;class Account{ private double balance; public Account(double balance) {原创 2021-05-15 18:15:24 · 581 阅读 · 0 评论 -
Java自学习day19-Lock锁
解决线程安全问题的方式三:Lock锁 — JDK5.0新增1.面试题:synchronized 与 Lock的异同? * 相同:二者都可以解决线程安全问题 * 不同:synchronized机制在执行完相应的同步代码以后,自动的释放同步监视器 * Lock需要手动的启动同步(lock()),同时结束同步也需要手动的实现(unlock())2.优先使用顺序: * Lock 同步代码块(已经进入了方法体,分配了相应资源) 同步方法(在方法体之外) * * *转载 2021-05-15 16:43:31 · 119 阅读 · 0 评论 -
Java自学习day19-死锁问题
演示线程的死锁问题 * 1.死锁的理解:不同的线程分别占用对方需要的同步资源不放弃, * 都在等待对方放弃自己需要的同步资源,就形成了线程的死锁 * * 2.说明: * 1)出现死锁后,不会出现异常,不会出现提示,只是所有的线程都处于阻塞状态,无法继续 * 2)我们使用同步时,要避免出现死锁。package com.atguigu.java1;public class ThreadTest { public static void main(String[] args) {原创 2021-05-15 15:16:22 · 113 阅读 · 0 评论 -
Java自学习day19-使用同步机制将单例模式中的懒汉式改写为线程安全的
package com.atguigu.java1;public class BankTest {}class Bank{ private Bank(){} private static Bank instance = null; public static Bank getInstance(){ //方式一:效率稍差// synchronized (Bank.class) {// if(instance =原创 2021-05-15 14:37:06 · 148 阅读 · 0 评论 -
Java自学习day19-使用同步方法处理继承Thread类的方式中的线程安全问题
package com.atguigu.java;class Window4 extends Thread { private static int ticket = 100; @Override public void run() { while (true) { show(); } } private static synchronized void show(){//同步监视器:Windo原创 2021-05-15 12:38:35 · 169 阅读 · 0 评论 -
Java自学习day19-使用同步方法解决实现Runnable接口的线程安全问题
使用同步方法解决实现Runnable接口的线程安全问题 * 关于同步方法的总结: * 1. 同步方法仍然涉及到同步监视器,只是不需要我们显式的声明。 * 2. 非静态的同步方法,同步监视器是:this * 静态的同步方法,同步监视器是:当前类本身package com.atguigu.java;class Window3 implements Runnable { private int ticket = 100; @Override public原创 2021-05-15 12:35:51 · 166 阅读 · 0 评论 -
Java自学习day19-同步代码块处理实现Runnable的线程安全问题
之前的博客链接例子:创建三个窗口卖票,总票数为100张.使用实现Runnable接口的方式遇到的问题: * 1.问题:卖票过程中,出现了重票、错票 -->出现了线程的安全问题 * 2.问题出现的原因:当某个线程操作车票的过程中,尚未操作完成时,其他线程参与进来,也操作车票。 * 3.如何解决:当一个线程a在操作ticket的时候,其他线程不能参与进来。直到线程a操作完ticket时,其他 * 线程才可以开始操作ticket。这种情况即使线程a出现了阻塞,也不能被改变。转载 2021-05-15 11:29:02 · 177 阅读 · 0 评论 -
Java自学习day19-线程的生命周期
Java语言使用Thread类及其子类的对象来表示线程,在它的一个完整的生命周期中通常要经历如下的五种状态:新建: 当一个Thread类或其子类的对象被声明并创建时,新生的线程对象处于新建状态就绪:处于新建状态的线程被start()后,将进入线程队列等待CPU时间片,此时它已具备了运行的条件,只是没分配到CPU资源运行:当就绪的线程被调度并获得CPU资源时,便进入运行状态, run()方法定义了线程的操作和功能阻塞:在某种特殊情况下,被人为挂起或执行输入输出操作时,让出 CPU 并临时中止自己的执行原创 2021-05-15 09:22:37 · 121 阅读 · 0 评论 -
Java自学习day19-多线程总结(程序进程线程、并行并发、Thread类。Runnable接口)
程序、进程、线程的理解01. 程序(programm)概念:是为完成特定任务、用某种语言编写的一组指令的集合。即指一段静态的代码。02. 进程(process)概念:程序的一次执行过程,或是正在运行的一个程序。说明:进程作为资源分配的单位,系统在运行时会为每个进程分配不同的内存区域03. 线程(thread)概念:进程可进一步细化为线程,是一个程序内部的一条执行路径。说明:线程作为调度和执行的单位,每个线程拥独立的运行栈和程序计数器(pc),线程切换的开销小。补充:内存结构原创 2021-05-15 00:41:23 · 179 阅读 · 0 评论 -
Java自学习day18-创建三个窗口卖票,总票数为100张.使用实现Runnable接口的方式
package atguigu.java;class Window1 implements Runnable{ private int ticket = 100; @Override public void run() { while(true){ if(ticket > 0){ System.out.println(Thread.currentThread().getName() + ":卖票原创 2021-05-14 23:08:34 · 374 阅读 · 0 评论 -
Java自学习day18-创建多线程的方式二:实现Runnable接口
创建多线程的方式二:实现Runnable接口 * 1. 创建一个实现了Runnable接口的类 * 2. 实现类去实现Runnable中的抽象方法:run() * 3. 创建实现类的对象 * 4. 将此对象作为参数传递到Thread类的构造器中,创建Thread类的对象 * 5. 通过Thread类的对象调用start() * * * 比较创建线程的两种方式。 * 开发中:优先选择:实现Runnable接口的方式 * 原因:1. 实现的方式没有类的单继承性的局限性 * 2.转载 2021-05-14 22:56:00 · 108 阅读 · 0 评论 -
Java自学习day18-创建三个窗口卖票,总票数为100张.使用继承Thread类的方式
package atguigu.java;class Window extends Thread{ private static int ticket = 100; @Override public void run() { while(true){ if(ticket > 0){ System.out.println(getName() + ":卖票,票号为:" + ticket);原创 2021-05-14 22:40:06 · 326 阅读 · 0 评论 -
Java自学习day18-线程优先级的设置
* 线程的优先级: * 1. * MAX_PRIORITY:10 * MIN _PRIORITY:1 * NORM_PRIORITY:5 -->默认优先级 * 2.如何获取和设置当前线程的优先级: * getPriority():获取线程的优先级 * setPriority(int p):设置线程的优先级 * * 说明:高优先级的线程要抢占低优先级线程cpu的执行权。但是只是从概率上讲,高优先级的线程高概率的情况下 * 被执行。并不意味着只有当高优先级的线程执行.原创 2021-05-14 21:53:40 · 158 阅读 · 0 评论 -
Java自学习day18-测试Thread中的常用方法
测试Thread中的常用方法: * 1. start():启动当前线程;调用当前线程的run() * 2. run(): 通常需要重写Thread类中的此方法,将创建的线程要执行的操作声明在此方法中 * 3. currentThread():静态方法,返回执行当前代码的线程 * 4. getName():获取当前线程的名字 * 5. setName():设置当前线程的名字 * 6. yield():释放当前cpu的执行权 * 7. join():在线程a中调用线程b的join(),此时线程a就原创 2021-05-14 20:37:58 · 149 阅读 · 0 评论 -
Java自学习day18-创建两个分线程,其中一个线程遍历100以内的偶数,另一个线程遍历100以内的奇数
练习:创建两个分线程,其中一个线程遍历100以内的偶数,另一个线程遍历100以内的奇数法一:package atguigu.exer;public class ThreadDemo { public static void main(String[] args) { MyThread1 m1 = new MyThread1(); MyThread2 m2 = new MyThread2(); m1.start(); m2.s原创 2021-05-14 20:35:51 · 808 阅读 · 0 评论 -
Java自学习day18-多线程的创建方式一:继承于Thread类
多线程的创建,方式一:继承于Thread类 * 1. 创建一个继承于Thread类的子类 * 2. 重写Thread类的run() --> 将此线程执行的操作声明在run()中 * 3. 创建Thread类的子类的对象 * 4. 通过此对象调用start()例子:遍历100以内的所有的偶数验证问题一:我们不能通过直接调用run()的方式启动线程。run();package atguigu.java;//1. 创建一个继承于Thread类的子类class MyThread e原创 2021-05-14 20:14:02 · 187 阅读 · 0 评论 -
Java自学习day18-程序、进程、线程基本概念
程序(program)是为完成特定任务、用某种语言编写的一组指令的集合。即指一段静态的代码,静态对象。进程(process)是程序的一次执行过程,或是正在运行的一个程序。是一个动态的过程:有它自身的产生、存在和消亡的过程。——生命周期如:运行中的QQ,运行中的MP3播放器程序是静态的,进程是动态的进程作为资源分配的单位,系统在运行时会为每个进程分配不同的内存区域线程(thread)进程可进一步细化为线程,是一个程序内部的一条执行路径。若一个进程同一时间并行执行多个线程,就原创 2021-05-14 18:59:28 · 121 阅读 · 0 评论 -
Java自学习day18-常用快捷键
原创 2021-05-14 16:58:29 · 138 阅读 · 0 评论