- Leetcode 热题100道刷题
Not--found
leetcode算法
哈希算法哈希表(HashTable)是一种根据关键字直接访问内存存储位置的数据结构。通过哈希表,数据元素的存放位置和数据元素的关键字之间建立起某种对应关系,建立这种对应关系的函数称为哈希函数。1.两数之和(Leetcode1)给定一个整数数组nums和一个整数目标值target,请你在该数组中找出和为目标值target的那两个整数,并返回它们的数组下标。你可以假设每种输入只会对应一个答案。但是,数
- Redis - ZSet数据结构与滑动窗口应用
Redis的ZSET(有序集合)是一种结合了哈希表和跳跃表(SkipList)的混合数据结构,既能实现O(1)复杂度的成员存在性判断,又能以O(logN)复杂度维护有序性。RedisZSET数据存储机制ZSET有两种实现机制:SkipList+HashTable数据实际上是同时存在于两个数据结构中的跳表(SkipList)按score排序存储member支持范围查询(ZRANGE等命令)维护成员的
- Java - Map 集合简单介绍
希尔大
本文简单介绍一下Java中Map集合,包括HashMap,HashTable,LinkedHashMap。HashMapHashMap内部用于存放键值对,其中key可以为null。HashMap内部使用数组加链表(1.8+红黑树)的结构实现。数组元素的类型为Entry,Entry是链表的节点,也代表了一个键值对。HashMap初始化时可以指定两个参数:initialCapacity(默认为16)与
- java基础----HashMap,ConCurrentHashMap,HashTable的区别
pgydbh
引用了http://www.importnew.com/24822.html知识点①hash集合中,不能存在key相同键值对。后面插入的会替换前面的。put(1,100);put(1,200)。get(1)=200。②hashmap不是线程安全的。③hashtable是线程安全的。用的是整个数组加锁。④conCurrentHaskMap是线程安全的。用的是分段加锁,不同的段可以同时插入。所以速度比
- 【C++11】哈希表与无序容器:从概念到应用
卜及中
C++初阶知识C++进阶哈希算法c++算法
文章目录一、前言二、哈希表(HashTable)1.基本概念2.哈希函数3.冲突解决方法链地址法(SeparateChaining)开放寻址法(OpenAddressing)4.性能分析5.动态扩容6.应用场景7.优缺点二.无序容器的介绍1.unordered_set2.unordered_map3.unordered_multiset4.unordered_multimap5.总结三.无序容器与
- 多线程进阶——线程安全的集合类
iナナ
java开发语言
目录一、多线程环境使用ArrayList(一)自行加锁(二)Collections.synchronizedList(newArrayList);(三)使用CopyOnWriteArrayList二、多线程环境使用哈希表(一)Hashtable(二)ConcurrentHashMap原来的集合类,大部分都不是线程安全的。Vector,Stack,HashTable,是线程安全的(不建议用),其他集
- ConcurrentHashMap深度解析
编程界的彭于晏qaq
javajava
ConcurrentHashMap深度解析引言:并发容器的"扛鼎之作"在Java并发编程领域,ConcurrentHashMap无疑是最核心的容器之一。作为HashMap的线程安全替代品,它既解决了Hashtable全表锁导致的性能瓶颈,又规避了HashMap在并发环境下的数据不一致风险(如死循环、数据丢失)。自JDK1.5引入以来,ConcurrentHashMap经历了三次重大演进(JDK7分
- Redis的ziplist与hashtable性能对比测试
无级程序员
java数据库大数据
测试一下ziplist长度为2048时性能。机器为4C,8G虚拟机另外,记录一下,200个节点的Redis集群要消耗大约200mbps带宽用于节点间通讯。
- C# 代码(`Hashtable` 和 `SortedList`)
张謹礧
c#哈希算法开发语言
一、Hashtable(哈希表)1.基本概念非泛型集合:存储键值对(object类型),通过哈希算法实现快速查找。线程安全:默认非线程安全,可通过Hashtable.Synchronized创建线程安全版本。键的唯一性:键必须唯一,且不可为null(值可为null)。2.创建与初始化//创建空的HashtableHashtablehashtable=newHashtable();//创建并初始化
- HashMap的Get(),Put()源码解析
Ttang23
哈希算法散列表算法
1、什么是HashMap?HashMap是Java中用于存储键值对(Key-Value)的集合类,它实现了Map接口。其核心特点是:无序性:不保证元素的存储顺序,也不保证顺序恒定不变。唯一性:键(Key)不能重复,若插入重复键会覆盖原有值。允许null:允许一个null键和任意数量的null值。非线程安全:相比HashTable,HashMap不支持同步,性能更高。2.核心数据结构:哈希表(Has
- 零基础数据结构与算法—— 第三章:高级数据结构-总结
qqxhb
零基础数据结构与算法小学生编程算法数据结构算法树堆哈希表图
3.1树(上)3.1树(下)3.2堆(Heap)3.3哈希表(HashTable)3.4图(Graph)3.5高级树结构3.6本章小结在本章中,我们深入学习了几种重要的高级数据结构,这些数据结构在解决复杂问题时具有强大的能力。让我们回顾一下本章的主要内容:1.堆(Heap)堆是一种特殊的完全二叉树,具有堆序性质。我们学习了:最大堆和最小堆的概念和性质堆的基本操作(插入、删除堆顶、获取堆顶、构建堆)
- Java线程安全集合类
paishishaba
java开发语言
目录概述主要线程安全集合类及对比1.List系列2.Map系列3.Set系列4.Queue系列核心区别与选择标准使用场景案例实践建议概述Java集合框架提供了多种线程安全的集合实现,主要分为三大类:早期线程安全集合:Vector、Hashtable同步包装集合:Collections.synchronizedXxx()并发集合:java.util.concurrent包下的实现主要线程安全集合类及
- java基础——java集合map详解
喜欢敲代码的程序员
学习java开发语言java
目录一、引言二、Map接口概述1.常用方法2.实现Map的主要类2.1.HashMap2.2.LinkedHashMap2.3.Hashtable(遗留类,已过时)2.4.TreeMap2.5.ConcurrentHashMap3.总结对比4.不常用的实现类4.1.IdentityHashMap4.2.WeakHashMap4.3.EnumMap4.4.ConcurrentSkipListMap5
- Linux网络协议栈的基石:深入剖析inet_hashtables.c的高效设计
109702008
编程#C语言网络linux网络协议人工智能
百万并发连接的背后,是哈希表与锁的精妙博弈在Linux网络协议栈中,inet_hashtables.c是实现TCP/IP协议高性能的核心模块。它通过三层哈希表结构管理海量套接字,支撑百万级并发连接。本文将深入解析其设计思想与关键实现。一、哈希表分层设计:连接管理的基石Linux内核通过三层哈希结构管理套接字,应对不同场景:绑定哈希表(bhash):管理端口绑定关系structinet_bind_b
- python中的集合和字典
Nnbwbyhxy
笔记
集合(set)和字典(dict)是Python中两种常用的内建数据结构,它们都基于哈希表(hashtable)实现,具有一些相似的特性,但也有显著的不同。下面是它们的详细比较:1.数据存储形式集合(set):存储的是无序的、唯一的元素。集合中的每个元素必须是可哈希的,并且没有重复的值。示例:python复制代码s={1,2,3,4}#集合中的元素是唯一的字典(dict):存储的是键值对(key-v
- Java后端开发岗高频面试题及答案(面试必看)
禅与Bug的修复艺术
Java面试java面试开发语言Java面试Java后端后端开发程序员
Java面试随着时间的改变而改变。在过去的日子里,当你知道String和StringBuilder的区别就能让你直接进入第二轮面试,但是现在问题变得越来越高级,面试官问的问题也更深入。在我初入职场的时候,类似于Vector与Array的区别、HashMap与Hashtable的区别是最流行的问题,只需要记住它们,就能在面试中获得更好的机会,但这种情形已经不复存在。如今,你将会被问到许多Java程序
- 【JAVA】集合
superkcl2022
#javajava开发语言
List、Set接口继承于Collection接口List接口的实现类有ArrayList和LinkedList还有一个实现类是Vector!Set接口的实现类有HashSet(常用,底层结构是HashMap,存key不存value)TreeSet(不常用)Map接口最长的见的实现类是HashMap,底层是数组+链表或红黑树不常见的实现类有HashTable、TreeMapput(Kkey,Vva
- Android基础入门教程,致Android开发者
2401_84408058
程序员android
那么在市场紧缩以及大前端的趋势下,我们移动端程序员如何突破职业瓶颈,保持个人的核心竞争力呢?一、硬技能:专业的技术知识1.Java/Kotlin开发语言Java常用数据结构:ArrayList、Vector、CopyOnWriteArrayList、HaspMap、ConcurrentHashMap、HashTable等使用场景。JVM虚拟机包括Java内存管理,GC垃圾回收机制,类加载机制。推荐
- 算法第5天|哈希表基础理论总结、有效的字母异位词LeetCode242、两个数组的交集LeetCode349、快乐数LeetCode202、两数之和LeetCode1
孟大本事要学习
算法散列表哈希算法
今日整体问题总结:1、在使用map中要注意find(x)查询的是键,而不是值2、要注意多使用迭代器来解决问题,而不是总是使用下标,要知道set、map常用的一些函数,便于简化计算。3、当判断一个值是不是出现过,要注意使用哈希表(数组、map、set要注意使用场合)哈希希表(散列表,hashtable)基础理论总结简单理解:哈希表就是一个数组,通过数组的下标索引访问数组中的元素哈希表作用:1、将一个
- Java经典面试题
Carver猫哥
后端笔记【Java】java开发语言
一:HashMap,Hashtable,ConcurrentHashMap的区别: HashMap、Hashtable和ConcurrentHashMap是Java中用于存储键值对的三种主要实现,它们在设计理念、线程安全性、性能以及使用方式上有所区别。设计理念与实现HashMap:基于哈希表实现的Map接口,它使用数组+链表(JDK1.7及以前)或数组+链表+红黑树(JDK1.8)的数
- leetcode刷题经验
lucky_jiexia
leetcode哈希算法算法
Hash相关(HashSet、HashMap、HashTable)快速查找需要频繁判断某个元素是否存在,或快速获取某个键对应的值:1两数之和217存在重复元素统计频率或计数统计元素出现的次数,或按条件分组:32有效的字母异位词60前k个高频元素387字符串中的第一个唯一字符滑动窗口或子串需要在窗口内快速判断字符是否重复或满足条件3无重复字符的最长子串76最小覆盖子串(困难)去重或判断重复119最长
- 【 java 集合知识 第二篇 】
张哈大
面经java开发语言笔记哈希算法
目录1.Map集合1.1.快速遍历Map1.2.HashMap实现原理1.3.HashMap的扩容机制1.4.HashMap在多线程下的问题1.5.解决哈希冲突的方法1.6.HashMap的put过程1.7.HashMap的key使用什么类型1.8.HashMapkey可以为null的原因1.9.HashMap为什么不采用平衡二叉树1.10.HashMap的负载因子1.11.HashTable介绍
- JAVA集合面试分享十五:HashMap、HashTable、TreeMap、LinkedHashMap之间有什么区别呢?
之乎者也·
Java集合内容分享集合java
HashMap、HashTable、TreeMap、LinkedHashMap的区别如下:底层数据结构:HashMap:基于哈希表实现,允许使用null作为key或value。HashTable:也基于哈希表,但不允许使用null作为key或value。TreeMap:基于红黑树实现,可以确保Map中的元素处于排序状态。LinkedHashMap:基于哈希表和链表实现,维护了一个运行于所有条目的双
- 秋招Day5 - Java集合(下) - Map
Java初学者小白
八股#集合java
HashMapvsHashTable线程安全:HashMap不是线程安全的(如果想要线程安全就使用ConcurrentHashMap;HashTable内部方法由synchronized修饰,线程安全效率:HashMap由于没有加同步锁,所以相比HashTable效率更高一点对NULLKey和NULLvalue的支持:HashMap支持一个NULLkey,多个NULLvalue;HashTable
- Leetcode刷题指南C++(每日更新)
战士小小白
leetcodeleetcodec++算法
1.两数之和两数之和https://leetcode-cn.com/problems/two-sum///暴力枚举classSolution{public:vectortwoSum(vector&nums,inttarget){intn=nums.size();for(inti=0;itwoSum(vector&nums,inttarget){unordered_maphashtable;for(
- ConcurrentHashMap
Klong.k
java开发语言
ConcurrentHashMap是Java中的一个并发集合类,属于java.util.concurrent包。它是线程安全的HashMap实现,允许多个线程高效地并发访问和修改映射数据。核心特点特性说明线程安全通过内部分段或锁机制实现并发访问高性能允许多个线程同时读写不同的部分,性能远优于Hashtable不允许空键或空值put(null,...)或put(...,null)都会抛出NullPo
- 双列集合(Map集合)
naoguaziteng
JAVASE基础知识javaMap集合
目录一.Map集合1.概述2.Map接口和Collection接口的不同3.Map集合体系4.键对应关系5.Map集合中的方法6.Map集合的遍历二.HashMap集合(元素唯一,无序)1.HashMap简介2.HashMap与Hashtable的区别三.LinkedHashMap集合(元素唯一,有序)四.TreeMap集合(元素唯一,有序且可排序)一.Map集合1.概述针对于键值对应关系的数据,
- 【java第58集】java Map双列集合详解
程序员水自流
java基础java开发语言
文章目录一.Map接口概述1.1Map的核心概念1.2Map与Collection的区别二、Map的常见实现类2.1HashMap2.2TreeMap2.3LinkedHashMap2.4Hashtable2.5ConcurrentHashMap2.6EnumMap2.7Properties三、Map的常用方法3.1添加/更新键值对3.2获取值3.3删除键值对3.4查询操作3.5遍历操作3.6Ja
- 【unordered_set】
sslings
哈希算法算法
C++中的unordered_set:一种高效的无序集合容器在C++标准库中,unordered_set是一个高度优化的关联式容器,用于存储具有唯一性的元素。与std::set不同,unordered_set不维护元素的有序性,而是通过哈希表(HashTable)来组织内部数据。这种底层实现方式使得unordered_set在元素的插入、删除和查找操作上通常能达到平均常数时间复杂度O(1)O(1)
- 哈希表实现(C语言)
请向我看齐
数据结构数据结构
哈希表概念哈希表(HashTable)是一种数据结构,它通过哈希函数来存储和检索键值对(key-valuepairs)。哈希表能够提供快速的插入、删除和查找操作,其时间复杂度平均情况下接近常数时间,即O(1)。哈希表原理哈希表的工作原理主要涉及以下几个核心概念:哈希函数:哈希表使用哈希函数将键转换成数组索引。理想情况下,哈希函数应该能够将不同的键均匀分布到数组的不同位置,以减少冲突。数组:哈希表的
- 基本数据类型和引用类型的初始值
3213213333332132
java基础
package com.array;
/**
* @Description 测试初始值
* @author FuJianyong
* 2015-1-22上午10:31:53
*/
public class ArrayTest {
ArrayTest at;
String str;
byte bt;
short s;
int i;
long
- 摘抄笔记--《编写高质量代码:改善Java程序的151个建议》
白糖_
高质量代码
记得3年前刚到公司,同桌同事见我无事可做就借我看《编写高质量代码:改善Java程序的151个建议》这本书,当时看了几页没上心就没研究了。到上个月在公司偶然看到,于是乎又找来看看,我的天,真是非常多的干货,对于我这种静不下心的人真是帮助莫大呀。
看完整本书,也记了不少笔记
- 【备忘】Django 常用命令及最佳实践
dongwei_6688
django
注意:本文基于 Django 1.8.2 版本
生成数据库迁移脚本(python 脚本)
python manage.py makemigrations polls
说明:polls 是你的应用名字,运行该命令时需要根据你的应用名字进行调整
查看该次迁移需要执行的 SQL 语句(只查看语句,并不应用到数据库上):
python manage.p
- 阶乘算法之一N! 末尾有多少个零
周凡杨
java算法阶乘面试效率
&n
- spring注入servlet
g21121
Spring注入
传统的配置方法是无法将bean或属性直接注入到servlet中的,配置代理servlet亦比较麻烦,这里其实有比较简单的方法,其实就是在servlet的init()方法中加入要注入的内容:
ServletContext application = getServletContext();
WebApplicationContext wac = WebApplicationContextUtil
- Jenkins 命令行操作说明文档
510888780
centos
假设Jenkins的URL为http://22.11.140.38:9080/jenkins/
基本的格式为
java
基本的格式为
java -jar jenkins-cli.jar [-s JENKINS_URL] command [options][args]
下面具体介绍各个命令的作用及基本使用方法
1. &nb
- UnicodeBlock检测中文用法
布衣凌宇
UnicodeBlock
/** * 判断输入的是汉字 */ public static boolean isChinese(char c) { Character.UnicodeBlock ub = Character.UnicodeBlock.of(c);
- java下实现调用oracle的存储过程和函数
aijuans
javaorale
1.创建表:STOCK_PRICES
2.插入测试数据:
3.建立一个返回游标:
PKG_PUB_UTILS
4.创建和存储过程:P_GET_PRICE
5.创建函数:
6.JAVA调用存储过程返回结果集
JDBCoracle10G_INVO
- Velocity Toolbox
antlove
模板toolboxvelocity
velocity.VelocityUtil
package velocity;
import org.apache.velocity.Template;
import org.apache.velocity.app.Velocity;
import org.apache.velocity.app.VelocityEngine;
import org.apache.velocity.c
- JAVA正则表达式匹配基础
百合不是茶
java正则表达式的匹配
正则表达式;提高程序的性能,简化代码,提高代码的可读性,简化对字符串的操作
正则表达式的用途;
字符串的匹配
字符串的分割
字符串的查找
字符串的替换
正则表达式的验证语法
[a] //[]表示这个字符只出现一次 ,[a] 表示a只出现一
- 是否使用EL表达式的配置
bijian1013
jspweb.xmlELEasyTemplate
今天在开发过程中发现一个细节问题,由于前端采用EasyTemplate模板方法实现数据展示,但老是不能正常显示出来。后来发现竟是EL将我的EasyTemplate的${...}解释执行了,导致我的模板不能正常展示后台数据。
网
- 精通Oracle10编程SQL(1-3)PLSQL基础
bijian1013
oracle数据库plsql
--只包含执行部分的PL/SQL块
--set serveroutput off
begin
dbms_output.put_line('Hello,everyone!');
end;
select * from emp;
--包含定义部分和执行部分的PL/SQL块
declare
v_ename varchar2(5);
begin
select
- 【Nginx三】Nginx作为反向代理服务器
bit1129
nginx
Nginx一个常用的功能是作为代理服务器。代理服务器通常完成如下的功能:
接受客户端请求
将请求转发给被代理的服务器
从被代理的服务器获得响应结果
把响应结果返回给客户端
实例
本文把Nginx配置成一个简单的代理服务器
对于静态的html和图片,直接从Nginx获取
对于动态的页面,例如JSP或者Servlet,Nginx则将请求转发给Res
- Plugin execution not covered by lifecycle configuration: org.apache.maven.plugin
blackproof
maven报错
转:http://stackoverflow.com/questions/6352208/how-to-solve-plugin-execution-not-covered-by-lifecycle-configuration-for-sprin
maven报错:
Plugin execution not covered by lifecycle configuration:
- 发布docker程序到marathon
ronin47
docker 发布应用
1 发布docker程序到marathon 1.1 搭建私有docker registry 1.1.1 安装docker regisry
docker pull docker-registry
docker run -t -p 5000:5000 docker-registry
下载docker镜像并发布到私有registry
docker pull consol/tomcat-8.0
- java-57-用两个栈实现队列&&用两个队列实现一个栈
bylijinnan
java
import java.util.ArrayList;
import java.util.List;
import java.util.Stack;
/*
* Q 57 用两个栈实现队列
*/
public class QueueImplementByTwoStacks {
private Stack<Integer> stack1;
pr
- Nginx配置性能优化
cfyme
nginx
转载地址:http://blog.csdn.net/xifeijian/article/details/20956605
大多数的Nginx安装指南告诉你如下基础知识——通过apt-get安装,修改这里或那里的几行配置,好了,你已经有了一个Web服务器了。而且,在大多数情况下,一个常规安装的nginx对你的网站来说已经能很好地工作了。然而,如果你真的想挤压出Nginx的性能,你必
- [JAVA图形图像]JAVA体系需要稳扎稳打,逐步推进图像图形处理技术
comsci
java
对图形图像进行精确处理,需要大量的数学工具,即使是从底层硬件模拟层开始设计,也离不开大量的数学工具包,因为我认为,JAVA语言体系在图形图像处理模块上面的研发工作,需要从开发一些基础的,类似实时数学函数构造器和解析器的软件包入手,而不是急于利用第三方代码工具来实现一个不严格的图形图像处理软件......
&nb
- MonkeyRunner的使用
dai_lm
androidMonkeyRunner
要使用MonkeyRunner,就要学习使用Python,哎
先抄一段官方doc里的代码
作用是启动一个程序(应该是启动程序默认的Activity),然后按MENU键,并截屏
# Imports the monkeyrunner modules used by this program
from com.android.monkeyrunner import MonkeyRun
- Hadoop-- 海量文件的分布式计算处理方案
datamachine
mapreducehadoop分布式计算
csdn的一个关于hadoop的分布式处理方案,存档。
原帖:http://blog.csdn.net/calvinxiu/article/details/1506112。
Hadoop 是Google MapReduce的一个Java实现。MapReduce是一种简化的分布式编程模式,让程序自动分布到一个由普通机器组成的超大集群上并发执行。就如同ja
- 以資料庫驗證登入
dcj3sjt126com
yii
以資料庫驗證登入
由於 Yii 內定的原始框架程式, 採用綁定在UserIdentity.php 的 demo 與 admin 帳號密碼: public function authenticate() { $users=array( &nbs
- github做webhooks:[2]php版本自动触发更新
dcj3sjt126com
githubgitwebhooks
上次已经说过了如何在github控制面板做查看url的返回信息了。这次就到了直接贴钩子代码的时候了。
工具/原料
git
github
方法/步骤
在github的setting里面的webhooks里把我们的url地址填进去。
钩子更新的代码如下: error_reportin
- Eos开发常用表达式
蕃薯耀
Eos开发Eos入门Eos开发常用表达式
Eos开发常用表达式
>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
蕃薯耀 2014年8月18日 15:03:35 星期一
&
- SpringSecurity3.X--SpEL 表达式
hanqunfeng
SpringSecurity
使用 Spring 表达式语言配置访问控制,要实现这一功能的直接方式是在<http>配置元素上添加 use-expressions 属性:
<http auto-config="true" use-expressions="true">
这样就会在投票器中自动增加一个投票器:org.springframework
- Redis vs Memcache
IXHONG
redis
1. Redis中,并不是所有的数据都一直存储在内存中的,这是和Memcached相比一个最大的区别。
2. Redis不仅仅支持简单的k/v类型的数据,同时还提供list,set,hash等数据结构的存储。
3. Redis支持数据的备份,即master-slave模式的数据备份。
4. Redis支持数据的持久化,可以将内存中的数据保持在磁盘中,重启的时候可以再次加载进行使用。
Red
- Python - 装饰器使用过程中的误区解读
kvhur
JavaScriptjqueryhtml5css
大家都知道装饰器是一个很著名的设计模式,经常被用于AOP(面向切面编程)的场景,较为经典的有插入日志,性能测试,事务处理,Web权限校验, Cache等。
原文链接:http://www.gbtags.com/gb/share/5563.htm
Python语言本身提供了装饰器语法(@),典型的装饰器实现如下:
@function_wrapper
de
- 架构师之mybatis-----update 带case when 针对多种情况更新
nannan408
case when
1.前言.
如题.
2. 代码.
<update id="batchUpdate" parameterType="java.util.List">
<foreach collection="list" item="list" index=&
- Algorithm算法视频教程
栏目记者
Algorithm算法
课程:Algorithm算法视频教程
百度网盘下载地址: http://pan.baidu.com/s/1qWFjjQW 密码: 2mji
程序写的好不好,还得看算法屌不屌!Algorithm算法博大精深。
一、课程内容:
课时1、算法的基本概念 + Sequential search
课时2、Binary search
课时3、Hash table
课时4、Algor
- C语言算法之冒泡排序
qiufeihu
c算法
任意输入10个数字由小到大进行排序。
代码:
#include <stdio.h>
int main()
{
int i,j,t,a[11]; /*定义变量及数组为基本类型*/
for(i = 1;i < 11;i++){
scanf("%d",&a[i]); /*从键盘中输入10个数*/
}
for
- JSP异常处理
wyzuomumu
Webjsp
1.在可能发生异常的网页中通过指令将HTTP请求转发给另一个专门处理异常的网页中:
<%@ page errorPage="errors.jsp"%>
2.在处理异常的网页中做如下声明:
errors.jsp:
<%@ page isErrorPage="true"%>,这样设置完后就可以在网页中直接访问exc