网站首页 > 精选教程 正文
时间: 2021年2月25日星期四 多云
前言
面试是类似演讲演说的过程,网上的资料都是文字的,没法让面试者直观的体验到面试过程,本人已经将相关内容制作成音频节目,有兴趣的朋友可以去喜马拉雅搜索《2020年Java面试208题》收听音频版节目。
《2020年Java面试208题》整理了208个Java程序员的面试题,主要是针对三年以内开发经验的JAVA程序员提出的问题。
题目
本期要说的是《2020年Java面试208题》的第8题,面试官提了这样一个问题:
使用StringBuffer类如何实现字符串反转:
要求:
1 不要使用reserve方法
2 尽量节省内存的开销
不需要写代码,只要说出思路和理由就可以了。
知识点解析
这个题目看起来简单,但其中涉及到StringBuffer对字符串管理的内存机制,其实还是值得讲一讲的。
在演示面试之前,我先说1个知识点,否则可能有些基础薄弱的看不懂我的回答。
就是StringBuffer中的字符串在内存中是如何管理的?
StringBuffer的字符串,其实就是字符数组,其实也不仅仅StringBuffer是这样,字符串本身在内存中就是字符数组,也不仅仅Java这么处理 ---- 所有计算机编程语言都是这样的。
StringBuffer的独特之处在于,它为了提高字符串操作的性能,采取了空间换时间的策略,它的字符数组的长度并不是字符串的长度,它的字符数组会多分配一些空间,准确地说,StringBuffer默认是申请长度为16的字符数组内存空间,这个空间是在堆内存开辟的。
同时,StringBuffer在操作字符串的时候,如果堆内存中的字符数组长度够用,就直接使用;如果字符数组的长度不够了,就新创建一个字符数组,长度为当前字符数组的两倍,然后将当前字符数组中的内容复制到新字符数组中,然后将旧的字符数组丢弃给垃圾回收。
好,StringBuffer的内存管理的知识点讲完了。
再说一下StringBuffer的reserve方法,这个方法就是对字符串进行反转的,比如字符串为123,reserve后就变成321了。题目要求不使用reserve,那其实就是让自己写代码实现reserve。
这个题其实是从以前C的题目变化过来的,在C语言里面操作字符串都要自己操作内存实现。Java直接提供了常用的字符串操作方法,面试官为了看出程序员在内存和StringBuffer源代码的熟悉程度,特意出了这样的题目。
演示面试
那么现在就由我来演示一下面试:
你好,面试官。
1 我先说一下我的实现思路。
我会将StringBuffer中管理的字符串,循环取出第1个字符和最后1个字符、第2个字符和倒数第2个字符、第3个字符和倒数第3个字符,然后依次调换,最终就实现了字符串反转了。
2 这里有一个问题,两个字符变量 a 和 b 要想调换值,必须将a的值先赋值给 c,然后将b的值赋值给a,再将c的值赋值给b。这就好像甲乙两人每人端着一大盆水,他俩想把水盆互相换给对方端着,必须由甲先把水盆放地上,然后甲就空出手来接乙手里的水盆了,乙把水盆交给甲后,自己腾出手来了才能端起之前甲的那盆水。
所以,两个字符变量a和b要调换值, 得有一个字符的空间作为字符交换的临时空间或者叫缓存空间。
一般的方法,都是新创建一个字符变量来作为缓存空间,但本题目要求的是尽量节省内存的开销,新创建一个字符变量就会在栈里压入一个这个变量,循环交换字符的过程,就是循环的压栈出栈的过程,这就会在栈里面有一个字符的开销。
3 我考虑的是StringBuffer的特性,StringBuffer写入字符串的时候,实际内存中的形式的是字符数组,并且申请的内存数组的长度并不是与字符串的长度一样的,一般都会比字符串的长。那么我们可以这么想象一下,比如字符串为 abcdefg,一共7个字符,但StringBuffer在内存中字符数组默认是16个字符的空间 ---- 这个是StringBuffer的特性,如此一来,我就可以把字符数组的第8个字符的位置当做是缓存,来完成字符串abcdefg的反转。
这就是我的思路,我的回答结束了。
=========================================================
好了,以上就是我的演示面试,不知道是否让你满意。
下期再见
本人技术有限,凭借热情希望给程序员面试提供一点帮助,必有不足之处,希望业内人士积极批评指正,在留言区留言就是对我最大的鼓励。希望批评中肯一些,不要存在人身攻击,更不要波及到家人,善意中肯的批评我都能够虚心接受。 我们下期再见。
猜你喜欢
- 2024-11-03 4.5 Java的字符串操作和方法 java字符串使用教学
- 2024-11-03 一文教你Java字符串处理(String,StringBuffer...
- 2024-11-03 「Java工具类」Jackson工具类,json字符串转各种对象或者集合
- 2024-11-03 java int类型转char类型总结 java将int转换为char
- 2024-11-03 《JAVA编程思想》5分钟速成:第13章(字符串)
- 2024-11-03 Java字符串操作的函数式方法 java中字符串的操作
- 2024-11-03 Java基于代码实战的字符流父类、字符转换流、缓冲字符流、过滤流
- 2024-11-03 7. 反转整数(LeetCode 题解) 反转整数python
- 2024-11-03 JAVA 基本类型之间的转换(新手) java基础类型转换
- 2024-11-03 Java读取制表符文本转换为JSON java读取表格
你 发表评论:
欢迎- 04-11Java面试“字符串三兄弟”String、StringBuilder、StringBuffer
- 04-11Java中你知道几种从字符串中找指定的字符的数量
- 04-11探秘Java面试中问的最多的String、StringBuffer、StringBuilder
- 04-11Python字符串详解与示例(python字符串的常见操作)
- 04-11java正则-取出指定字符串之间的内容
- 04-11String s1 = new String("abc");这句话创建了几个字符串对象?
- 04-11java判断字符串中是否包含某个字符
- 04-11关于java开发中正确的发牌逻辑编写规范
- 最近发表
-
- Java面试“字符串三兄弟”String、StringBuilder、StringBuffer
- Java中你知道几种从字符串中找指定的字符的数量
- 探秘Java面试中问的最多的String、StringBuffer、StringBuilder
- Python字符串详解与示例(python字符串的常见操作)
- java正则-取出指定字符串之间的内容
- String s1 = new String("abc");这句话创建了几个字符串对象?
- java判断字符串中是否包含某个字符
- 关于java开发中正确的发牌逻辑编写规范
- windows、linux如何后台运行jar(并且显示进程名)
- 腾讯大佬私人收藏,GitHub上最受欢迎的100个JAVA库,值得学习
- 标签列表
-
- nginx反向代理 (57)
- nginx日志 (56)
- nginx限制ip访问 (62)
- mac安装nginx (55)
- java和mysql (59)
- java中final (62)
- win10安装java (72)
- java启动参数 (64)
- java链表反转 (64)
- 字符串反转java (72)
- java逻辑运算符 (59)
- java 请求url (65)
- java信号量 (57)
- java定义枚举 (59)
- java字符串压缩 (56)
- java中的反射 (59)
- java 三维数组 (55)
- java插入排序 (68)
- java线程的状态 (62)
- java异步调用 (55)
- java中的异常处理 (62)
- java锁机制 (54)
- java静态内部类 (55)
- java怎么添加图片 (60)
- java 权限框架 (55)
本文暂时没有评论,来添加一个吧(●'◡'●)