先自我介绍一下,小编浙江大学毕业,去过华为、字节跳动等大厂,目前阿里P7
深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年最新Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上Java开发知识点,真正体系化!
由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新
如果你需要这些资料,可以添加V获取:vip1024b (备注Java)
正文
-
调用mark()会将mark设为当前的position的值,以后调用reset()会将position属性设置为mark的值。
-
mark的值总是小于等于position的值,如果将position的值设的比mark小,当前的mark值会被抛弃掉。
这些属性总是满足以下条件:
0 <= mark <= position <= limit <= capacity
ByteBuffer的常用方法
-
ByteBuffer allocate(int capacity) //创建一个指定容量capacity的ByteBuffer。
-
ByteBuffer allocateDirect(int capacity) //创建一个direct的ByteBuffer,这样的ByteBuffer在参与IO操作时性能会更好
-
ByteBuffer wrap(byte [] array)// 把一个byte数组包装成ByteBuffer。
-
ByteBuffer wrap(byte [] array, int offset, int length) //把一个byte数组或byte数组的一部分包装成ByteBuffer。
-
Buffer clear() 把position设为0,把limit设为capacity,一般在把数据写入Buffer前调用。
-
Buffer flip() 把limit设为当前position,把position设为0,一般在从Buffer读出数据前调用。
-
Buffer rewind() 把position设为0,limit不变,一般在把数据重写入Buffer前调用。
-
compact() 将 position 与 limit之间的数据复制到buffer的开始位置,复制后 position = limit -position,limit = capacity, 但如果position 与limit 之间没有数据的话发,就不会进行复制。
-
mark() & reset() 通过调用Buffer.mark()方法,可以标记Buffer中的一个特定position。之后可以通过调用Buffer.reset()方法恢复到这个position。
-
int remaining() 剩余可读元素,limit - position
-
boolean isReadOnly() 是否是只可读缓冲区
-
boolean isDirect() 是否是堆外内存
-
//get put
-
byte get(int index)
-
ByteBuffer put(byte b)
-
int getInt() //从ByteBuffer中读出一个int值。
-
ByteBuffer putInt(int value) // 写入一个int值到ByteBuffer中。
-
xxx
端点排序
endian 字节存放次序
字节序,顾名思义字节的顺序,再多说两句就是大于一个字节类型的数据在内存中的存放顺序(一个字节的数据当然就无需谈顺序的问题了)。
-
LITTLE-ENDIAN(小字节序、低字节序),即低位字节排放在内存的低地址端,高位字节排放在内存的高地址端。
-
与之对应的是:BIG-ENDIAN(大字节序、高字节序)
不同语言、场景下的字节序
JAVA默认是Big-Endian 大端点序
TCP/IP各层协议将字节序定义为Big-Endian,因此TCP/IP协议中使用的字节序通常称之为网络字节序
代码示例
大端点序
ByteBuffer byteBuffer = ByteBuffer.allocate(4);
byteBuffer.order(ByteOrder.BIG_ENDIAN);
byteBuffer.putInt(88);
byte[] result = byteBuffer.array();
System.out.println(Arrays.toString(result));
打印[0,0,0,88]
小端点序
ByteBuffer byteBuffer = ByteBuffer.allocate(4);
byteBuffer.order(ByteOrder.LITTLE_ENDIAN);
byteBuffer.putInt(88);
byte[] result = byteBuffer.array();
System.out.println(Arrays.toString(result));
打印[88,0,0,0]
读数据
flip
开始读的时候,将postion复位到0,并将limit设为当前postion。(即写转读的时候用到)
get
从buffer里读一个字节,并把postion移动一位。上限是limit,即写入数据的最后位置。
clear
将limit设置为容量大小,将position置为0,并不清除buffer内容。
写数据
put
写模式下,往buffer里写一个字节,并把postion移动一位。写模式下,一般limit与capacity相等。
实例
以Mysql空间数据类型 Geometry 来实操一波
Geometry 实际存储格式为:长度为25个字节
-
4个字节用于整数SRID(0)
-
1个字节(整数字节顺序)(1 =小字节序)
-
4个字节用于整数类型信息
-
8字节的双精度X坐标
-
8字节的双精度Y坐标
例如,POINT(1 -1)
由以下25个字节的序列组成,每个序列由两个十六进制数字表示:
mysql> SET @g = ST_GeomFromText(‘POINT(1 -1)’);
mysql> SELECT LENGTH(@g);
±-----------+
| LENGTH(@g) |
±-----------+
| 25 |
±-----------+
mysql> SELECT HEX(@g);
±---------------------------------------------------+
| HEX(@g) |
±---------------------------------------------------+
| 000000000101000000000000000000F03F000000000000F0BF |
±---------------------------------------------------+
| 组成 | 大小 | 值 |
| :-- | :-- | :-- |
| SRID | 4个字节 | 00000000
|
| 字节顺序 | 1个字节 | 01
|
| WKB类型 | 4字节 | 01000000
|
| X坐标 | 8字节 | 000000000000F03F
|
写在最后
很多人感叹“学习无用”,实际上之所以产生无用论,是因为自己想要的与自己所学的匹配不上,这也就意味着自己学得远远不够。无论是学习还是工作,都应该有主动性,所以如果拥有大厂梦,那么就要自己努力去实现它。
最后祝愿各位身体健康,顺利拿到心仪的offer!
由于文章的篇幅有限,所以这次的蚂蚁金服和京东面试题答案整理在了PDF文档里
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
需要这份系统化的资料的朋友,可以添加V获取:vip1024b (备注Java)
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
g-WFJSxLCs-1713596710556)]
[外链图片转存中…(img-TWTyGLuf-1713596710556)]
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
需要这份系统化的资料的朋友,可以添加V获取:vip1024b (备注Java)
[外链图片转存中…(img-oKr6fYe8-1713596710557)]
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!