异常

第九天

异常:就是程序在运行时出现不正常情况。
异常由来:问题也是现实生活中一个具体的事物,也可以通过java的类的形式进行描述。并封装成对象。
   其实就是java对不正常情况进行描述后的对象体现。
对于问题的划分:两种:一种是严重的问题,一种非严重的问题。
对于严重的,java通过Error类进行描述。
 对于Error一般不编写针对性的代码对其进行处理。
对与非严重的,java通过Exception类进行描述。
 对于Exception可以使用针对性的处理方式进行处理。
无论Error或者Exception都具有一些共性内容。
比如:不正常情况的信息,引发原因等。
Throwable
     |--Error
     |--Exception
            |--RuntimeException(运行异常)
finally代码块:定义一定执行的代码。通常用于关闭资源。

异常的处理
java 提供了特有的语句进行处理。
异常处理语句:

try
{
	需要被检测的代码;
}
catch ()
{
	处理异常的代码;
}
finally
{
	一定会执行的代码;
}

有三个结合格式:
1.	try
	{
		
	}
	catch ()
	{
	}

2.	try
	{
		
	}
	finally
	{
	
	}
//记住一点:catch是用于处理异常。如果没有catch就代表异常没有被处理过,如果该异常是检测时异常。那么必须声明。

3.	try
	{
		
	}
	catch ()
	{
	}
	finally
	{
	
	}


 

Throwable中的方法:
对捕获到的异常对象进行常见方法操作。
getMessage()
获取异常信息。
toString()
获取异常类名和异常信息,返回字符串。
printStackTrace()
获取异常类名和异常信息,以及异常出现在程序中的位置。返回值void。
printStackTrace(PrintStream s)
通常用该方法将异常内容保存在日志文件中,以便查阅

throw和throws的用法:
throw定义在函数内,用于抛出异常对象。
 throw new XxxxxxException("异常提示信息");
throws定义在函数上,用于抛出异常类,可以抛出多个用逗号隔开。

class Demo
{
	int div(int a,int b)throws ArithmeticException,ArrayIndexOutOfBoundsException//在功能上通过throws的关键字声明了该功能有可能会出现问题。
	{
		int[] arr = new int[a];
		System.out.println(arr[4]);
		return a/b;
	}
}


 

当函数内容有throw抛出异常对象,并未进行try处理。必须要在函数上声明,都在编译失败。
注意,RuntimeException除外。也就说,函数内如果抛出的RuntimeExcpetion异常,函数上可以不用声明。
如果函数声明了异常,调用者需要进行处理。处理方法可以throws可以try。

对多异常的处理。

1,声明异常时,建议声明更为具体的异常。这样处理的可以更具体。
2,对方声明几个异常,就对应有几个catch块。不要定义多余的catch块。
 如果多个catch块中的异常出现继承关系,父类异常catch块放在最下面。
建立在进行catch处理时,catch中一定要定义具体处理方式。
不要简单定义一句 e.printStackTrace(),
也不要简单的就书写一条输出语句。

异常有两种:
 编译时被检测异常
  该异常在编译时,如果没有处理(没有抛也没有try),编译失败。
  该异常被标识,代表这可以被处理。
 运行时异常(编译时不检测)
  在编译时,不需要处理,编译器不检查。
  该异常的发生,建议不处理,让程序停止。需要对代码进行修正。

理解异常(编译期,运行期):
编译错误:语法已经错误  编译通不过的,不能生成.class
受检异常:语法是正确的,但你的语句存在一些安全隐患,如逻辑等问题,java语言是安全 语言,遇到安全问题就会提醒你,你要是不处理它不会让你编译通过
            不会生成.class,处理或声明,才会把这个安全提醒清除掉的,会生成.class(处
理异常处理方式两种:声明,try、catch)
不受检查异常:不小心编码造成的;(RuntimeException及其他子类)(处理异常处理方式三  种:声明,try、catch,什么都不处理)

自定义异常:
必须是自定义类继承Exception。
继承Exception原因:
异常体系有一个特点:因为异常类和异常对象都被抛出。
他们都具备可抛性。这个可抛性是Throwable这个体系中独有特点。
自定义异常实例:

class FuShuException extends Exception
{
	private int value;

	FuShuException()
	{
		super();
	}
/*如何定义异常信息呢?
因为父类中已经把异常信息的操作都完成了。
所以子类只要在构造时,将异常信息传递给父类通过super语句。
那么就可以直接通过getMessage方法获取自定义的异常信息。
*/
	FuShuException(String msg,int value)
	{
		super(msg);
		this.value = value;
	}

	public int getValue()
	{
		return value;
	}
}
class  ExceptionDemo3
{
	public static void main(String[] args) 
	{		
		try
		{
			检测代码		
		}
		catch (FuShuException e)//e,自定义异常对象引用。
		{
			e.getValue()//获取自定义异常方法;catch要写出具体处理方法,自己没办法处理的就抛出异常对象交给会处理的人去处理
		}
	}
}


RuntimeException异常:
Exceptoin中有一个特殊的子类异常RuntimeException 运行时异常。
如果在函数内容抛出该异常,函数上可以不用声明,编译一样通过。
如果在函数上声明了该异常。调用者可以不用进行处理。编译一样通过;
之所以不用在函数声明,是因为不需要让调用者处理。
当该异常发生,希望程序停止。因为在运行时,出现了无法继续运算的情况,希望停止程序后,
对代码进行修正。

class Demo
{
	int div(int a,int b)//运行异常:可抛RuntimeException,也可不抛。
	{
		return a/b;//运行期间,如果除数为0,报异常,即运行异常。
	}
}


自定义异常时:如果该异常的发生,无法在继续进行运算,
就让自定义异常继承RuntimeException。

class MyException extends RuntimeException
{
	MyException(String msg)
	{
		super(msg);
	}
}


第十天:
异常在子父类覆盖中的体现;
1,子类在覆盖父类时,如果父类的方法抛出异常,那么子类的覆盖方法,只能抛出父类的异常或者该异常的子类。
2,如果父类方法抛出多个异常,那么子类在覆盖该方法时,只能抛出父类异常的子集。
3,如果父类或者接口的方法中没有异常抛出,那么子类在覆盖方法时,也不可以抛出异常。
 如果子类方法发生了异常。就必须要进行try处理。绝对不能抛。

class AException extends Exception
{
}

class BException extends AException
{
}

class CException extends Exception
{
}
/*
Exception 
	|--AException
		|--BException
	|--CException
*/
class Fu
{
	void show()throws AException
	{
	
	}
}
class Test
{
	void function(Fu f)
	{
		try
		{
			f.show();
		}
		catch (AException e)
		{

		}
		
	}
}
class Zi extends Fu
{
	void show()throws CException
	{
		
	}
}
class  
{
	public static void main(String[] args) 
	{
		Test t = new Test();
		t.function(new Zi());
	}
}


异常的处理原则:
 1,处理方式有两种:try 或者 throws。
 2,调用到抛出异常的功能时,抛出几个,就处理几个。
  一个try对应多个catch。
 3,多个catch,父类的catch放到最下面。
 4,catch内,需要定义针对性的处理方式。不要简单的定义printStackTrace,输出语句。
  也不要不写。
  当捕获到的异常,本功能处理不了时,可以继续在catch中抛出。

try
		{
			throw new AException();
		}
		catch (AException e)
		{
			throw e;
		}


 

如果该异常处理不了,但并不属于该功能出现的异常。
  可以将异常转换后,在抛出和该功能相关的异常。

  或者异常可以处理,当需要将异常产生的和本功能相关的问题提供出去,
  当调用者知道。并处理。也可以将捕获异常处理后,转换新的异常。

try
		{
			throw new AException();
		}
		catch (AException e)
		{
			// 对AException处理。
			throw new BException();
		}


常见异常:
算术异常类:ArithmeticExecption
空指针异常类:NullPointerException
类型强制转换异常:ClassCastException
数组负下标异常:NegativeArrayException
数组下标越界异常:ArrayIndexOutOfBoundsException
违背安全原则异常:SecturityException
文件已结束异常:EOFException
文件未找到异常:FileNotFoundException
字符串转换为数字异常:NumberFormatException
操作数据库异常:SQLException
输入输出异常:IOException
方法未找到异常:NoSuchMethodException

内容概要:本文详细介绍了“秒杀商城”微服务架构的设计与实战全过程,涵盖系统从需求分析、服务拆分、技术选型到核心功能开发、分布式事务处理、容器化部署及监控链路追踪的完整流程。重点解决了高发场景下的超卖问题,采用Redis预减库存、消息队列削峰、数据库乐观锁等手段保障数据一致性,通过Nacos实现服务注册发现与配置管理,利用Seata处理跨服务分布式事务,结合RabbitMQ实现异步下单,提升系统吞吐能力。同时,项目支持Docker Compose快速部署和Kubernetes生产级编排,集成Sleuth+Zipkin链路追踪与Prometheus+Grafana监控体系,构建可观测性强的微服务系统。; 适合人群:具备Java基础和Spring Boot开发经验,熟悉微服务基本概念的中高级研发人员,尤其是希望深入理解高发系统设计、分布式事务、服务治理等核心技术的开发者;适合工作2-5年、有志于转型微服务或提升架构能力的工程师; 使用场景及目标:①学习如何基于Spring Cloud Alibaba构建完整的微服务项目;②掌握秒杀场景下高发、超卖控制、异步化、削峰填谷等关键技术方案;③实践分布式事务(Seata)、服务熔断降级、链路追踪、统一配置中心等企业级中间件的应用;④完成从本地开发到容器化部署的全流程落地; 阅读建议:建议按照文档提供的七个阶段循序渐进地动手实践,重点关注秒杀流程设计、服务间通信机制、分布式事务实现和系统性能优化部分,结合代码调试与监控工具深入理解各组件协作原理,真正掌握高发微服务系统的构建能力。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值