一个有趣的面试题:如何用三个字节存储年月日

开发 前端
一个有趣的面试题,如何用3个字节存储年月日呢?我们都知道一个字节存储数据最大是255,年份超过255,需要2个字节,月份和天数只需要一个字节就够了,但是我们发现这样存储的话,就需要4个字节了,那么用3个字节到底怎么处理呢?

一个有趣的面试题,如何用3个字节存储年月日呢?我们都知道一个字节存储数据最大是255,年份超过255,需要2个字节,月份和天数只需要一个字节就够了,但是我们发现这样存储的话,就需要4个字节了,那么用3个字节到底怎么处理呢?

我们思考一下,1个字节是8位,3个字节就是24位。一个月最多31天,只需要5位就够了,12个月份也只用占4位,还剩下15位用来存储年份,最大能表示3万多年,是足够的,所以理论上是可以用3个字节来存储年月日。代码应该怎么实现呢,我们将上面的思路用一个表格来表示。 

由上表可知,我们可以存储的最大年份是32767年,月份是15,天数是31,完全符合我们的实际需求。以下用java代码来实现。 

  1. public class Demo { 
  2.  
  3.   /** 
  4.    * 将传入的年月日存储在3个字节的数组中 
  5.    * 3个字节总共24位,从左到右前15位存年份,中间4位存月份,最后5位存储天数 
  6.    * @param year 年份 
  7.    * @param month 月份 
  8.    * @param day 天数 
  9.    * @return 返回存储字节数组 
  10.    */ 
  11.   private static byte[] date2bytes(int yearint monthint day) { 
  12.     byte[] bytes = new byte[3]; 
  13.     bytes[2] = (byte) (((0x7 & month) << 5) | (0x1F & day)); 
  14.     bytes[1] = (byte) (((0x7F & year) << 1) | ((0x8 & month) >> 3)); 
  15.     bytes[0] = (byte) ((0x7F80 & year) >> 7); 
  16.     return bytes; 
  17.   } 
  18.  
  19.   /** 
  20.    * 从存储年月日的3个字节中解析出年月日数据 
  21.    * @param bytes 待解析的字节数组 
  22.    * @return 返回长度为3的数组,依次表示年,月和日 
  23.    */ 
  24.   private static int[] bytes2date(byte[] bytes) { 
  25.     int[] date = new int[3]; 
  26.     date[2] = bytes[2] & 0x1F; 
  27.     date[1] = ((bytes[1] & 0x1) << 3) | ((bytes[2] & 0xE0) >> 5); 
  28.     date[0] = ((bytes[0] & 0xFF) << 7) | ((bytes[1] & 0xFE) >> 1); 
  29.     return date
  30.   } 

我们以2021年12月31日来测试一下最终的效果:

我们可以看到存储的三个字节中的值,最后解析3个字节也还原成了最初我们设置的日期。

 

责任编辑:未丽燕 来源: 今日头条
相关推荐

2011-07-18 15:08:19

SQL存储过程

2014-09-19 11:17:48

面试题

2022-11-18 09:03:12

线程顺序打印

2012-08-02 09:36:58

fork面试题

2023-06-20 08:25:53

NESTED源码mybatis

2024-09-05 13:02:41

2024-03-12 09:34:01

2011-08-17 10:28:53

多对多查询SQL Server

2010-08-18 08:53:53

Scala

2024-05-27 07:48:23

2014-12-02 10:02:30

2021-03-16 08:56:35

Go interface面试

2020-03-02 17:00:24

程序员数据库MySQL

2023-02-26 01:37:57

goORM代码

2024-09-26 08:03:25

2021-06-02 12:12:46

DevOps面试Linux

2019-03-23 20:00:04

面试react.js前端

2020-06-16 14:52:41

面试官模型递归

2015-08-27 09:27:34

JavaScript面试题

2017-08-29 14:12:16

Java面试题
点赞
收藏

51CTO技术栈公众号