2021-03-18 20:31发布
net.coobird
thumbnailator
0.4.8
import java.awt.image.BufferedImage;
import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.OutputStream;
import javax.imageio.ImageIO;
import net.coobird.thumbnailator.Thumbnails;
import net.coobird.thumbnailator.geometry.Positions;
public class ThumbnailatorTest {
/**
*
* @param args
* @throws IOException
*/
public static void main(String[] args) throws IOException {
ThumbnailatorTest thumbnailatorTest = new ThumbnailatorTest();
thumbnailatorTest.test1();
thumbnailatorTest.test2();
thumbnailatorTest.test3();
thumbnailatorTest.test4();
thumbnailatorTest.test5();
thumbnailatorTest.test6();
thumbnailatorTest.test7();
thumbnailatorTest.test8();
thumbnailatorTest.test9();
}
* 指定大小进行缩放
private void test1() throws IOException {
/*
* size(width,height) 若图片横比200小,高比300小,不变
* 若图片横比200小,高比300大,高缩小到300,图片比例不变 若图片横比200大,高比300小,横缩小到200,图片比例不变
* 若图片横比200大,高比300大,图片按比例缩小,横为200或高为300
Thumbnails.of("images/test.jpg").size(200, 300).toFile(
"C:/image_200x300.jpg");
Thumbnails.of("images/test.jpg").size(2560, 2048).toFile(
"C:/image_2560x2048.jpg");
* 按照比例进行缩放
private void test2() throws IOException {
* scale(比例)
Thumbnails.of("images/test.jpg").scale(0.25f)
.toFile("C:/image_25%.jpg");
Thumbnails.of("images/test.jpg").scale(1.10f).toFile(
"C:/image_110%.jpg");
* 不按照比例,指定大小进行缩放
private void test3() throws IOException {
* keepAspectRatio(false) 默认是按照比例缩放的
Thumbnails.of("images/test.jpg").size(120, 120).keepAspectRatio(false)
.toFile("C:/image_120x120.jpg");
* 旋转
private void test4() throws IOException {
* rotate(角度),正数:顺时针 负数:逆时针
Thumbnails.of("images/test.jpg").size(1280, 1024).rotate(90).toFile(
"C:/image+90.jpg");
Thumbnails.of("images/test.jpg").size(1280, 1024).rotate(-90).toFile(
"C:/iamge-90.jpg");
* 水印
private void test5() throws IOException {
* watermark(位置,水印图,透明度)
Thumbnails.of("images/test.jpg").size(1280, 1024).watermark(
Positions.BOTTOM_RIGHT,
ImageIO.read(new File("images/watermark.png")), 0.5f)
.outputQuality(0.8f).toFile(
"C:/image_watermark_bottom_right.jpg");
Positions.CENTER,
.outputQuality(0.8f).toFile("C:/image_watermark_center.jpg");
* 裁剪
private void test6() throws IOException {
* 图片中心400*400的区域
Thumbnails.of("images/test.jpg").sourceRegion(Positions.CENTER, 400,
400).size(200, 200).keepAspectRatio(false).toFile(
"C:/image_region_center.jpg");
* 图片右下400*400的区域
Thumbnails.of("images/test.jpg").sourceRegion(Positions.BOTTOM_RIGHT,
400, 400).size(200, 200).keepAspectRatio(false).toFile(
"C:/image_region_bootom_right.jpg");
* 指定坐标
Thumbnails.of("images/test.jpg").sourceRegion(600, 500, 400, 400).size(
200, 200).keepAspectRatio(false).toFile(
"C:/image_region_coord.jpg");
* 转化图像格式
private void test7() throws IOException {
* outputFormat(图像格式)
Thumbnails.of("images/test.jpg").size(1280, 1024).outputFormat("png")
.toFile("C:/image_1280x1024.png");
Thumbnails.of("images/test.jpg").size(1280, 1024).outputFormat("gif")
.toFile("C:/image_1280x1024.gif");
* 输出到OutputStream
private void test8() throws IOException {
* toOutputStream(流对象)
OutputStream os = new FileOutputStream(
"C:/image_1280x1024_OutputStream.png");
Thumbnails.of("images/test.jpg").size(1280, 1024).toOutputStream(os);
* 输出到BufferedImage
private void test9() throws IOException {
* asBufferedImage() 返回BufferedImage
BufferedImage thumbnail = Thumbnails.of("images/test.jpg").size(1280,
1024).asBufferedImage();
ImageIO.write(thumbnail, "jpg", new File(
"C:/image_1280x1024_BufferedImage.jpg"));
————————————————
/***
* @Description:保存图片并且生成缩略图
*@paramimageFile 图片文件
*@paramrequest 请求对象
*@paramuploadPath 上传目录
*@return
public staticBaseResult uploadFileAndCreateThumbnail(MultipartFile imageFile,HttpServletRequest request,String uploadPath) {if(imageFile == null){return new BaseResult(false, "imageFile不能为空");
}if (imageFile.getSize() >= 10*1024*1024)
{return new BaseResult(false, "文件不能大于10M");
String uuid=UUID.randomUUID().toString();
String fileDirectory= CommonDateUtils.date2string(newDate(), CommonDateUtils.YYYY_MM_DD);//拼接后台文件名称
String pathName = fileDirectory + File.separator + uuid + "."
+FilenameUtils.getExtension(imageFile.getOriginalFilename());//构建保存文件路劲//2016-5-6 yangkang 修改上传路径为服务器上
String realPath = request.getServletContext().getRealPath("uploadPath");//获取服务器绝对路径 linux 服务器地址 获取当前使用的配置文件配置//String urlString=PropertiesUtil.getInstance().getSysPro("uploadPath");//拼接文件路劲
String filePathName = realPath + File.separator +pathName;
log.info("图片上传路径:"+filePathName);//判断文件保存是否存在
File file = newFile(filePathName);if (file.getParentFile() != null || !file.getParentFile().isDirectory()) {//创建文件
file.getParentFile().mkdirs();
InputStream inputStream= null;
FileOutputStream fileOutputStream= null;try{
inputStream=imageFile.getInputStream();
fileOutputStream= newFileOutputStream(file);//写出文件//2016-05-12 yangkang 改为增加缓存//IOUtils.copy(inputStream, fileOutputStream);
byte[] buffer = new byte[2048];
IOUtils.copyLarge(inputStream, fileOutputStream, buffer);
buffer= null;
}catch(IOException e) {
filePathName= null;return new BaseResult(false, "操作失败", e.getMessage());
}finally{try{if (inputStream != null) {
inputStream.close();
}if (fileOutputStream != null) {
fileOutputStream.flush();
fileOutputStream.close();
}//String fileId = FastDFSClient.uploadFile(file, filePathName);
/*** 缩略图begin*/
//拼接后台文件名称
String thumbnailPathName = fileDirectory + File.separator + uuid + "small."
+FilenameUtils.getExtension(imageFile.getOriginalFilename());//added by yangkang 2016-3-30 去掉后缀中包含的.png字符串
if(thumbnailPathName.contains(".png")){
thumbnailPathName= thumbnailPathName.replace(".png", ".jpg");
}long size =imageFile.getSize();double scale = 1.0d;if(size >= 200*1024){if(size > 0){
scale= (200*1024f) /size ;
}//拼接文件路劲
String thumbnailFilePathName = realPath + File.separator +thumbnailPathName;try{//added by chenshun 2016-3-22 注释掉之前长宽的方式,改用大小//Thumbnails.of(filePathName).size(width, height).toFile(thumbnailFilePathName);
if(size < 200>
Thumbnails.of(filePathName).scale(1f).outputFormat("jpg").toFile(thumbnailFilePathName);
}else{
Thumbnails.of(filePathName).scale(1f).outputQuality(scale).outputFormat("jpg").toFile(thumbnailFilePathName);
}catch(Exception e1) {return new BaseResult(false, "操作失败", e1.getMessage());
}/*** 缩略图end*/Map map = new HashMap();//原图地址
map.put("originalUrl", pathName);//缩略图地址
map.put("thumbnailUrl", thumbnailPathName);return new BaseResult(true, "操作成功", map);
用PS(CS4版本)解决的方法:1.打开图片,文件-存储为WEB和设备所用格式,(在预设后有个小下拉箭头,在里面选择:优化文件大小,在大小里设置自己想要的大小),在预设下面的文件格式框里选择gif,然后存储,关闭文件。(如果不一定要BMP格式,这个时候也可以弄成JPEG,PNG,GIF格式的,就已经OK了。一定要BMP的话继续第二步)2.再打开刚才存储过的GIF文件,点存储为,在格式里选择BMP文件,点保存会出现一个对话框,这个时候深度为8位,那个压缩变为可用的,打上勾,存储。OK了,文件小了。比对了一下,图像基本没损失,尺寸也不变。存在的问题:分辨率是72,文件图像模式为索引颜色,如果改变模式,图像大小又和原来一样大了。但是如果拿原图直接改变颜色模式,图片质量又破坏了。其关键作用的地方就在于存储时候勾选那个压缩,因为直接打开图片存储,压缩是不可用状态。
Statement的execute(String query)方法用来执行任意的SQL查询,如果查询的结果是一个ResultSet,这个方法就返回true。如果结果不是ResultSet,比如insert或者update查询,它就会返回false。我们可以通过它的getResultSet方法来获取ResultSet,或者通过getUpda...
忙的时候项目期肯定要加班 但是每天加班应该还不至于
虽然Java人才越来越多,但是人才缺口也是很大的,我国对JAVA工程师的需求是所有软件工程师当中需求大的,达到全部需求量的60%-70%,所以Java市场在短时间内不可能饱和。其次,Java市场不断变化,人才需求也会不断增加。马云说过,未来的制造业要的不是石油,...
工信部证书含金量较高。工信部是国务院的下属结构,具有发放资质、证书的资格。其所发放的证书具有较强的权威性,在全国范围内收到认可,含金量通常都比较高。 工信部证书,其含义也就是工信部颁发并承认的某项技能证书,是具有法律效力的,并且是国家认可的...
学Java好不好找工作?看学完Java后能做些什么吧。一、大数据技术Hadoop以及其他大数据处理技术都是用Java或者其他,例如Apache的基于Java 的 HBase和Accumulo以及ElasticSearchas。但是Java在此领域并未占太大空间,但只要Hadoop和ElasticSearchas能够成长壮...
就是java的基础知识啊,比如Java 集合框架;Java 多线程;线程的五种状态;Java 虚拟机;MySQL (InnoDB);Spring 相关;计算机网络;MQ 消息队列诸如此类
#{}和${}这两个语法是为了动态传递参数而存在的,是Mybatis实现动态SQL的基础,总体上他们的作用是一致的(为了动态传参),但是在编译过程、是否自动加单引号、安全性、使用场景等方面有很多不同,下面详细比较两者间的区别:1.#{} 是 占位符 :动态解析 ...
没问题的,专科学历也能学习Java开发的,主要看自己感不感兴趣,只要认真学,市面上的培训机构不少都是零基础课程,能跟得上,或是自己先找些资料学习一下。
1、反射对单例模式的破坏采用反射的方式另辟蹊径实例了该类,导致程序中会存在不止一个实例。解决方案其思想就是采用一个全局变量,来标记是否已经实例化过了,如果已经实例化过了,第 二次实例化的时候,抛出异常2、clone()对单例模式的破坏当需要实现单例的...
优点: 一、实例控制 单例模式会阻止其他对象实例化其自己的单例对象的副本,从而确保所有对象都访问唯一实例。 二、灵活性 因为类控制了实例化过程,所以类可以灵活更改实例化过程。 缺点: 一、开销 虽然数量很少,但如果每次对象请求引用时都要...
这个主要是看你数组的长度是多少, 比如之前写过的一个程序有个数组存的是各个客户端的ip地址:string clientIp[4]={XXX, xxx, xxx, xxx};这个时候如果想把hash值对应到上面四个地址的话,就应该对4取余,这个时候p就应该为4...
哈希表的大小 · 关键字的分布情况 · 记录的查找频率 1.直接寻址法:取关键字或关键字的某个线性函数值为散列地址。即H(key)=key或H(key) = a·key + b,其中a和b为常数(这种散列函数叫做自身函数)。...
哈希表的大小取决于一组质数,原因是在hash函数中,你要用这些质数来做模运算(%)。而分析发现,如果不是用质数来做模运算的话,很多生活中的数据分布,会集中在某些点上。所以这里最后采用了质数做模的除数。 因为用质数做了模的除数,自然存储空间的大小也用质数了...
是啊,哈希函数的设计至关重要,好的哈希函数会尽可能地保证计算简单和散列地址分布均匀,但是,我们需要清楚的是,数组是一块连续的固定长度的内存空间
解码查表优化算法,seo优化
1.对对象元素中的关键字(对象中的特有数据),进行哈希算法的运算,并得出一个具体的算法值,这个值 称为哈希值。2.哈希值就是这个元素的位置。3.如果哈希值出现冲突,再次判断这个关键字对应的对象是否相同。如果对象相同,就不存储,因为元素重复。如果对象不同,就...
最多设置5个标签!
import java.awt.image.BufferedImage;
import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.OutputStream;
import javax.imageio.ImageIO;
import net.coobird.thumbnailator.Thumbnails;
import net.coobird.thumbnailator.geometry.Positions;
public class ThumbnailatorTest {
/**
*
* @param args
* @throws IOException
*/
public static void main(String[] args) throws IOException {
ThumbnailatorTest thumbnailatorTest = new ThumbnailatorTest();
thumbnailatorTest.test1();
thumbnailatorTest.test2();
thumbnailatorTest.test3();
thumbnailatorTest.test4();
thumbnailatorTest.test5();
thumbnailatorTest.test6();
thumbnailatorTest.test7();
thumbnailatorTest.test8();
thumbnailatorTest.test9();
}
/**
* 指定大小进行缩放
*
* @throws IOException
*/
private void test1() throws IOException {
/*
* size(width,height) 若图片横比200小,高比300小,不变
* 若图片横比200小,高比300大,高缩小到300,图片比例不变 若图片横比200大,高比300小,横缩小到200,图片比例不变
* 若图片横比200大,高比300大,图片按比例缩小,横为200或高为300
*/
Thumbnails.of("images/test.jpg").size(200, 300).toFile(
"C:/image_200x300.jpg");
Thumbnails.of("images/test.jpg").size(2560, 2048).toFile(
"C:/image_2560x2048.jpg");
}
/**
* 按照比例进行缩放
*
* @throws IOException
*/
private void test2() throws IOException {
/**
* scale(比例)
*/
Thumbnails.of("images/test.jpg").scale(0.25f)
.toFile("C:/image_25%.jpg");
Thumbnails.of("images/test.jpg").scale(1.10f).toFile(
"C:/image_110%.jpg");
}
/**
* 不按照比例,指定大小进行缩放
*
* @throws IOException
*/
private void test3() throws IOException {
/**
* keepAspectRatio(false) 默认是按照比例缩放的
*/
Thumbnails.of("images/test.jpg").size(120, 120).keepAspectRatio(false)
.toFile("C:/image_120x120.jpg");
}
/**
* 旋转
*
* @throws IOException
*/
private void test4() throws IOException {
/**
* rotate(角度),正数:顺时针 负数:逆时针
*/
Thumbnails.of("images/test.jpg").size(1280, 1024).rotate(90).toFile(
"C:/image+90.jpg");
Thumbnails.of("images/test.jpg").size(1280, 1024).rotate(-90).toFile(
"C:/iamge-90.jpg");
}
/**
* 水印
*
* @throws IOException
*/
private void test5() throws IOException {
/**
* watermark(位置,水印图,透明度)
*/
Thumbnails.of("images/test.jpg").size(1280, 1024).watermark(
Positions.BOTTOM_RIGHT,
ImageIO.read(new File("images/watermark.png")), 0.5f)
.outputQuality(0.8f).toFile(
"C:/image_watermark_bottom_right.jpg");
Thumbnails.of("images/test.jpg").size(1280, 1024).watermark(
Positions.CENTER,
ImageIO.read(new File("images/watermark.png")), 0.5f)
.outputQuality(0.8f).toFile("C:/image_watermark_center.jpg");
}
/**
* 裁剪
*
* @throws IOException
*/
private void test6() throws IOException {
/**
* 图片中心400*400的区域
*/
Thumbnails.of("images/test.jpg").sourceRegion(Positions.CENTER, 400,
400).size(200, 200).keepAspectRatio(false).toFile(
"C:/image_region_center.jpg");
/**
* 图片右下400*400的区域
*/
Thumbnails.of("images/test.jpg").sourceRegion(Positions.BOTTOM_RIGHT,
400, 400).size(200, 200).keepAspectRatio(false).toFile(
"C:/image_region_bootom_right.jpg");
/**
* 指定坐标
*/
Thumbnails.of("images/test.jpg").sourceRegion(600, 500, 400, 400).size(
200, 200).keepAspectRatio(false).toFile(
"C:/image_region_coord.jpg");
}
/**
* 转化图像格式
*
* @throws IOException
*/
private void test7() throws IOException {
/**
* outputFormat(图像格式)
*/
Thumbnails.of("images/test.jpg").size(1280, 1024).outputFormat("png")
.toFile("C:/image_1280x1024.png");
Thumbnails.of("images/test.jpg").size(1280, 1024).outputFormat("gif")
.toFile("C:/image_1280x1024.gif");
}
/**
* 输出到OutputStream
*
* @throws IOException
*/
private void test8() throws IOException {
/**
* toOutputStream(流对象)
*/
OutputStream os = new FileOutputStream(
"C:/image_1280x1024_OutputStream.png");
Thumbnails.of("images/test.jpg").size(1280, 1024).toOutputStream(os);
}
/**
* 输出到BufferedImage
*
* @throws IOException
*/
private void test9() throws IOException {
/**
* asBufferedImage() 返回BufferedImage
*/
BufferedImage thumbnail = Thumbnails.of("images/test.jpg").size(1280,
1024).asBufferedImage();
ImageIO.write(thumbnail, "jpg", new File(
"C:/image_1280x1024_BufferedImage.jpg"));
}
}
————————————————
/***
* @Description:保存图片并且生成缩略图
*@paramimageFile 图片文件
*@paramrequest 请求对象
*@paramuploadPath 上传目录
*@return
*/
public staticBaseResult uploadFileAndCreateThumbnail(MultipartFile imageFile,HttpServletRequest request,String uploadPath) {if(imageFile == null){return new BaseResult(false, "imageFile不能为空");
}if (imageFile.getSize() >= 10*1024*1024)
{return new BaseResult(false, "文件不能大于10M");
}
String uuid=UUID.randomUUID().toString();
String fileDirectory= CommonDateUtils.date2string(newDate(), CommonDateUtils.YYYY_MM_DD);//拼接后台文件名称
String pathName = fileDirectory + File.separator + uuid + "."
+FilenameUtils.getExtension(imageFile.getOriginalFilename());//构建保存文件路劲//2016-5-6 yangkang 修改上传路径为服务器上
String realPath = request.getServletContext().getRealPath("uploadPath");//获取服务器绝对路径 linux 服务器地址 获取当前使用的配置文件配置//String urlString=PropertiesUtil.getInstance().getSysPro("uploadPath");//拼接文件路劲
String filePathName = realPath + File.separator +pathName;
log.info("图片上传路径:"+filePathName);//判断文件保存是否存在
File file = newFile(filePathName);if (file.getParentFile() != null || !file.getParentFile().isDirectory()) {//创建文件
file.getParentFile().mkdirs();
}
InputStream inputStream= null;
FileOutputStream fileOutputStream= null;try{
inputStream=imageFile.getInputStream();
fileOutputStream= newFileOutputStream(file);//写出文件//2016-05-12 yangkang 改为增加缓存//IOUtils.copy(inputStream, fileOutputStream);
byte[] buffer = new byte[2048];
IOUtils.copyLarge(inputStream, fileOutputStream, buffer);
buffer= null;
}catch(IOException e) {
filePathName= null;return new BaseResult(false, "操作失败", e.getMessage());
}finally{try{if (inputStream != null) {
inputStream.close();
}if (fileOutputStream != null) {
fileOutputStream.flush();
fileOutputStream.close();
}
}catch(IOException e) {
filePathName= null;return new BaseResult(false, "操作失败", e.getMessage());
}
}//String fileId = FastDFSClient.uploadFile(file, filePathName);
/*** 缩略图begin*/
//拼接后台文件名称
String thumbnailPathName = fileDirectory + File.separator + uuid + "small."
+FilenameUtils.getExtension(imageFile.getOriginalFilename());//added by yangkang 2016-3-30 去掉后缀中包含的.png字符串
if(thumbnailPathName.contains(".png")){
thumbnailPathName= thumbnailPathName.replace(".png", ".jpg");
}long size =imageFile.getSize();double scale = 1.0d;if(size >= 200*1024){if(size > 0){
scale= (200*1024f) /size ;
}
}//拼接文件路劲
String thumbnailFilePathName = realPath + File.separator +thumbnailPathName;try{//added by chenshun 2016-3-22 注释掉之前长宽的方式,改用大小//Thumbnails.of(filePathName).size(width, height).toFile(thumbnailFilePathName);
if(size < 200>
Thumbnails.of(filePathName).scale(1f).outputFormat("jpg").toFile(thumbnailFilePathName);
}else{
Thumbnails.of(filePathName).scale(1f).outputQuality(scale).outputFormat("jpg").toFile(thumbnailFilePathName);
}
}catch(Exception e1) {return new BaseResult(false, "操作失败", e1.getMessage());
}/*** 缩略图end*/Map map = new HashMap();//原图地址
map.put("originalUrl", pathName);//缩略图地址
map.put("thumbnailUrl", thumbnailPathName);return new BaseResult(true, "操作成功", map);
}
用PS(CS4版本)解决的方法:
1.打开图片,文件-存储为WEB和设备所用格式,(在预设后有个小下拉箭头,在里面选择:优化文件大小,在大小里设置自己想要的大小),在预设下面的文件格式框里选择gif,然后存储,关闭文件。(如果不一定要BMP格式,这个时候也可以弄成JPEG,PNG,GIF格式的,就已经OK了。一定要BMP的话继续第二步)
2.再打开刚才存储过的GIF文件,点存储为,在格式里选择BMP文件,点保存会出现一个对话框,这个时候深度为8位,那个压缩变为可用的,打上勾,存储。OK了,文件小了。
比对了一下,图像基本没损失,尺寸也不变。
存在的问题:分辨率是72,文件图像模式为索引颜色,如果改变模式,图像大小又和原来一样大了。但是如果拿原图直接改变颜色模式,图片质量又破坏了。
其关键作用的地方就在于存储时候勾选那个压缩,因为直接打开图片存储,压缩是不可用状态。
相关问题推荐
Statement的execute(String query)方法用来执行任意的SQL查询,如果查询的结果是一个ResultSet,这个方法就返回true。如果结果不是ResultSet,比如insert或者update查询,它就会返回false。我们可以通过它的getResultSet方法来获取ResultSet,或者通过getUpda...
忙的时候项目期肯定要加班 但是每天加班应该还不至于
虽然Java人才越来越多,但是人才缺口也是很大的,我国对JAVA工程师的需求是所有软件工程师当中需求大的,达到全部需求量的60%-70%,所以Java市场在短时间内不可能饱和。其次,Java市场不断变化,人才需求也会不断增加。马云说过,未来的制造业要的不是石油,...
工信部证书含金量较高。工信部是国务院的下属结构,具有发放资质、证书的资格。其所发放的证书具有较强的权威性,在全国范围内收到认可,含金量通常都比较高。 工信部证书,其含义也就是工信部颁发并承认的某项技能证书,是具有法律效力的,并且是国家认可的...
学Java好不好找工作?看学完Java后能做些什么吧。一、大数据技术Hadoop以及其他大数据处理技术都是用Java或者其他,例如Apache的基于Java 的 HBase和Accumulo以及ElasticSearchas。但是Java在此领域并未占太大空间,但只要Hadoop和ElasticSearchas能够成长壮...
就是java的基础知识啊,比如Java 集合框架;Java 多线程;线程的五种状态;Java 虚拟机;MySQL (InnoDB);Spring 相关;计算机网络;MQ 消息队列诸如此类
#{}和${}这两个语法是为了动态传递参数而存在的,是Mybatis实现动态SQL的基础,总体上他们的作用是一致的(为了动态传参),但是在编译过程、是否自动加单引号、安全性、使用场景等方面有很多不同,下面详细比较两者间的区别:1.#{} 是 占位符 :动态解析 ...
没问题的,专科学历也能学习Java开发的,主要看自己感不感兴趣,只要认真学,市面上的培训机构不少都是零基础课程,能跟得上,或是自己先找些资料学习一下。
1、反射对单例模式的破坏采用反射的方式另辟蹊径实例了该类,导致程序中会存在不止一个实例。解决方案其思想就是采用一个全局变量,来标记是否已经实例化过了,如果已经实例化过了,第 二次实例化的时候,抛出异常2、clone()对单例模式的破坏当需要实现单例的...
优点: 一、实例控制 单例模式会阻止其他对象实例化其自己的单例对象的副本,从而确保所有对象都访问唯一实例。 二、灵活性 因为类控制了实例化过程,所以类可以灵活更改实例化过程。 缺点: 一、开销 虽然数量很少,但如果每次对象请求引用时都要...
这个主要是看你数组的长度是多少, 比如之前写过的一个程序有个数组存的是各个客户端的ip地址:string clientIp[4]={XXX, xxx, xxx, xxx};这个时候如果想把hash值对应到上面四个地址的话,就应该对4取余,这个时候p就应该为4...
哈希表的大小 · 关键字的分布情况 · 记录的查找频率 1.直接寻址法:取关键字或关键字的某个线性函数值为散列地址。即H(key)=key或H(key) = a·key + b,其中a和b为常数(这种散列函数叫做自身函数)。...
哈希表的大小取决于一组质数,原因是在hash函数中,你要用这些质数来做模运算(%)。而分析发现,如果不是用质数来做模运算的话,很多生活中的数据分布,会集中在某些点上。所以这里最后采用了质数做模的除数。 因为用质数做了模的除数,自然存储空间的大小也用质数了...
是啊,哈希函数的设计至关重要,好的哈希函数会尽可能地保证计算简单和散列地址分布均匀,但是,我们需要清楚的是,数组是一块连续的固定长度的内存空间
解码查表优化算法,seo优化
1.对对象元素中的关键字(对象中的特有数据),进行哈希算法的运算,并得出一个具体的算法值,这个值 称为哈希值。2.哈希值就是这个元素的位置。3.如果哈希值出现冲突,再次判断这个关键字对应的对象是否相同。如果对象相同,就不存储,因为元素重复。如果对象不同,就...