我不得不说我不太了解文件格式的工作原理。 我的问题是,我有一个 200 像素 x 200 像素的 jpeg 文件,如何计算该文件的最大大小(以兆字节/字节为单位)?
我认为导致这个问题的推理会帮助一些人回答我。我有一个 Java 小程序,可以将人们用它绘制的图像上传到我的服务器。我需要知道这个文件可以达到的最大大小。它始终为 200x200。
这听起来很愚蠢,但是有没有比其他颜色占用更多字节大小的颜色?如果有,哪种颜色最昂贵?
最佳答案
有很多方法可以制作异常大的“病态”JPEG/JFIF 文件。
在范围的极端,大小没有限制,因为标准不限制某些类型的标记出现多次 - 例如一个充满许多 GB 的 DRI(定义重启间隔)标记的 JFIF 文件,最后是一个 8x8 像素的 MCU 在技术上是有效的。
如果我们限制自己使用“正常”标记,那么我们会找到一个上限如下:
一些背景-
JPEG 将像素编码为 8x8 像素 block (DCT block )的 MCU(组),每个分量(Y、Cb、Cr)一个 DCT block 。
为了获得最佳压缩效果(和最小尺寸),使用了 4:2:0 色度子采样方案,其中省略了 75% 的色度信息。为了获得最佳质量(和最大尺寸),该文件是 2/3 的色度,1/3 的亮度信息。
霍夫曼比特流符号用于对 DCT 分量进行编码,其中每个 DCT block 最多有 65 个(64 AC + 1 DC)。
霍夫曼符号的长度范围为 1 到 16 位,并且由编码器选择为尽可能小;但是,可以指定符号长度的选择。
必须完成霍夫曼比特流的最终编码,以便标记可以被唯一识别。即,输出中出现的任何 0xff 字节都必须替换为两个字节 - 0xff、0x00。
使用所有这些信息,我们可以构建一个病态但有效的 JPEG 文件,libjpeg(最常见的 JPEG 解码器实现)很乐意对其进行解码。
首先,我们需要尽可能长的霍夫曼符号。起初想到,定义一个全为 1 的最大长度霍夫曼符号(16 位)会占用大部分空间,但是 libjpeg 拒绝处理全为 1 的霍夫曼符号,这似乎并没有被标准排除在外——因为它仍然是一个独特的符号,因为已知其大小为 16 位,与其他可变长度符号不同,而且确实有些解码器可以处理它 (JPEGSnoop)。
所以我们定义了一个霍夫曼表,它将最后两个符号设置如下:
11111111_1111110 -> (0,0) (EOB - end of block value)
11111111_11111110 -> (0,15)
这样的霍夫曼表将在 JPEG 文件中显示为:
0xFF, 0xC4 ; DHT - define huffman table
0x00, 35 ; length
0x00 ; DC 0
1,1,1,1,1,1,1,1,1,1, 1, 1, 1, 1, 1, 1 ; histogram
1,2,3,4,5,6,7,8,9,10,11,12,13,14,0,15 ; symbols
现在编码一个最大长度的 DCT block :
1 x DC of 31 bits ( 11111111 11111110 11111111 1111111 )
64 x AC of 31 bits ( 11111111 11111110 11111111 1111111 )
= 2015 bits
由于一个 MCU 将有 3 个 DCT block (每个组件一个),因此 MCU 大小为 6045 位。
这些字节中的大部分将是 0xff,根据标准,它们在输出流中被 0xff、0x00 替换,以便将比特流与有效标记区分开来。
执行此映射,完整的 DCT 由以下字节模式的 8 次重复表示:
0xff,0x00,0xfe,0xff,0x00,0xff,0x00
0xff,0x00,0xfd,0xff,0x00,0xff,0x00
0xff,0x00,0xfb,0xff,0x00,0xff,0x00
0xff,0x00,0xf7,0xff,0x00,0xff,0x00
0xff,0x00,0xef,0xff,0x00,0xff,0x00
0xff,0x00,0xdf,0xff,0x00,0xff,0x00
0xff,0x00,0xbf,0xff,0x00,0xff,0x00
0xff,0x00,0x7f,0xff,0x00
总计 8*54 = 432 字节
所有这些加起来,我们有: 3 个组件 *(每个组件 432 字节) = 每 8x8 像素 1296 字节
SOI/DHT/DQT/SOS 段需要 339 字节的 header 来设置图像属性和哈夫曼表,需要 2 字节的 EOI 标记来结束图像。
由于 200x200 的图像将是 25x25 的 MCU,因此我们的最终尺寸为:
339 + (25 * 25 * 1296) + 2 = 810341 字节
每像素略高于 20.25 字节,比未压缩的 BMP/TGA 大 6 倍多。
关于java - Jpeg 计算最大尺寸,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2734678/
这里是Ruby新手。完成一些练习后碰壁了。练习:计算一系列成绩的字母等级创建一个方法get_grade来接受测试分数数组。数组中的每个分数应介于0和100之间,其中100是最大分数。计算平均分并将字母等级作为字符串返回,即“A”、“B”、“C”、“D”、“E”或“F”。我一直返回错误:avg.rb:1:syntaxerror,unexpectedtLBRACK,expecting')'defget_grade([100,90,80])^avg.rb:1:syntaxerror,unexpected')',expecting$end这是我目前所拥有的。我想坚持使用下面的方法或.join,
我真的很习惯使用Ruby编写以下代码:my_hash={}my_hash['test']=1Java中对应的数据结构是什么? 最佳答案 HashMapmap=newHashMap();map.put("test",1);我假设? 关于java-等价于Java中的RubyHash,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/22737685/
我正在尝试使用boilerpipe来自JRuby。我看过guide从JRuby调用Java,并成功地将它与另一个Java包一起使用,但无法弄清楚为什么同样的东西不能用于boilerpipe。我正在尝试基本上从JRuby中执行与此Java等效的操作:URLurl=newURL("http://www.example.com/some-location/index.html");Stringtext=ArticleExtractor.INSTANCE.getText(url);在JRuby中试过这个:require'java'url=java.net.URL.new("http://www
我只想对我一直在思考的这个问题有其他意见,例如我有classuser_controller和classuserclassUserattr_accessor:name,:usernameendclassUserController//dosomethingaboutanythingaboutusersend问题是我的User类中是否应该有逻辑user=User.newuser.do_something(user1)oritshouldbeuser_controller=UserController.newuser_controller.do_something(user1,user2)我
什么是ruby的rack或python的Java的wsgi?还有一个路由库。 最佳答案 来自Python标准PEP333:Bycontrast,althoughJavahasjustasmanywebapplicationframeworksavailable,Java's"servlet"APImakesitpossibleforapplicationswrittenwithanyJavawebapplicationframeworktoruninanywebserverthatsupportstheservletAPI.ht
这篇文章是继上一篇文章“Observability:从零开始创建Java微服务并监控它(一)”的续篇。在上一篇文章中,我们讲述了如何创建一个Javaweb应用,并使用Filebeat来收集应用所生成的日志。在今天的文章中,我来详述如何收集应用的指标,使用APM来监控应用并监督web服务的在线情况。源码可以在地址 https://github.com/liu-xiao-guo/java_observability 进行下载。摄入指标指标被视为可以随时更改的时间点值。当前请求的数量可以改变任何毫秒。你可能有1000个请求的峰值,然后一切都回到一个请求。这也意味着这些指标可能不准确,你还想提取最小/
HashMap中为什么引入红黑树,而不是AVL树呢1.概述开始学习这个知识点之前我们需要知道,在JDK1.8以及之前,针对HashMap有什么不同。JDK1.7的时候,HashMap的底层实现是数组+链表JDK1.8的时候,HashMap的底层实现是数组+链表+红黑树我们要思考一个问题,为什么要从链表转为红黑树呢。首先先让我们了解下链表有什么不好???2.链表上述的截图其实就是链表的结构,我们来看下链表的增删改查的时间复杂度增:因为链表不是线性结构,所以每次添加的时候,只需要移动一个节点,所以可以理解为复杂度是N(1)删:算法时间复杂度跟增保持一致查:既然是非线性结构,所以查询某一个节点的时候
项目介绍随着我国经济迅速发展,人们对手机的需求越来越大,各种手机软件也都在被广泛应用,但是对于手机进行数据信息管理,对于手机的各种软件也是备受用户的喜爱小学生兴趣延时班预约小程序的设计与开发被用户普遍使用,为方便用户能够可以随时进行小学生兴趣延时班预约小程序的设计与开发的数据信息管理,特开发了小程序的设计与开发的管理系统。小学生兴趣延时班预约小程序的设计与开发的开发利用现有的成熟技术参考,以源代码为模板,分析功能调整与小学生兴趣延时班预约小程序的设计与开发的实际需求相结合,讨论了小学生兴趣延时班预约小程序的设计与开发的使用。开发环境开发说明:前端使用微信微信小程序开发工具:后端使用ssm:VU
遍历文件夹我们通常是使用递归进行操作,这种方式比较简单,也比较容易理解。本文为大家介绍另一种不使用递归的方式,由于没有使用递归,只用到了循环和集合,所以效率更高一些!一、使用递归遍历文件夹整体思路1、使用File封装初始目录,2、打印这个目录3、获取这个目录下所有的子文件和子目录的数组。4、遍历这个数组,取出每个File对象4-1、如果File是否是一个文件,打印4-2、否则就是一个目录,递归调用代码实现publicclassSearchFile{publicstaticvoidmain(String[]args){//初始目录Filedir=newFile("d:/Dev");Datebeg
我基本上来自Java背景并且努力理解Ruby中的模运算。(5%3)(-5%3)(5%-3)(-5%-3)Java中的上述操作产生,2个-22个-2但在Ruby中,相同的表达式会产生21个-1-2.Ruby在逻辑上有多擅长这个?模块操作在Ruby中是如何实现的?如果将同一个操作定义为一个web服务,两个服务如何匹配逻辑。 最佳答案 在Java中,模运算的结果与被除数的符号相同。在Ruby中,它与除数的符号相同。remainder()在Ruby中与被除数的符号相同。您可能还想引用modulooperation.