import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
// 使用注解@Data,在类编译的时候,自动给class文件生成getter,setter,toString 以及其他方法
@Data
// 自动生成无参构造
@NoArgsConstructor
// 自动生成有参构造
@AllArgsConstructor
public class Person {
private String name;
private String sex;
private int age;
}
// String类
public final class String
implements java.io.Serializable, Comparable<String>, CharSequence {
/** The value is used for character storage. */
private final char value[];
...
String 底层是使用char数组进行存储的,由于在String类中,char数组是用final修饰的,因此String类型的数据不可以被改变!!!
String str = "test01";
char[] cs = str.toCharArray();
// .toCharArray(),使用System.arraycopy方法,将String底层数组复制并输出给cs
String()无参构造// String无参构造 -- 空字符串
String tmp = new String();
// 创建出来的空字符串默认没有任何字符存储
String(byte[] bytes)字节数组(每一个字符所对应的字符集编码)作为参数// 将字节数组,转化为字符数组,再将字符数组拼接存储到字符串中
byte[] bs = {65,66,67,68};
String tmp = new String(bs);
String(char[] value)char数组作为参数// 将字符数组拼接存储到字符串中
char[] cs = {'a','q','c'};
String tmp = new String(cs);
String (String original)String字符串作作为参数 ---- 字符数组的引用传递// 将目标字符串底层存储所使用的char数组的内存地址,传递给当前字符串对象所对应的字符数组引用
String tmp = new String("test");
// 等同于
// 使用等号赋值的字符串,默认会使用字符串常量池,来进行字符串对象的复用
String tmp = "test";
// 通过等号赋值直接定义的字符串是存放在运行时常量池中的,内存地址相同
String tmp = "test";
String tmp1 = "test";
System.out.println(tmp.equals(tmp1)); // true
System.out.println(tmp == tmp1); // true
// 而用new定义的字符串,实在堆中创建,内存地址不同
String tmp = new String("test");
String tmp1 = new String("test1");
System.out.println(tmp.equals(tmp1)); // true
System.out.println(tmp == tmp1); // false
内存地址判断 -> 长度判断 -> 逐位比较
// 源码
public boolean equals(Object anObject) {
if (this == anObject) { // 判断两个对象内存地址是否相同
return true;
}
if (anObject instanceof String) { // 判断传入的参数是不是String对象
String anotherString = (String)anObject; // 向下转型,方便后续访问String特有的方法和属性
int n = value.length; // 当前调用equals方法的字符串所对应的char数组的长度
if (n == anotherString.value.length) { // 判断两个字符串的长度是不是一致
char v1[] = value; // v1代表当前字符串所对应的char数组
char v2[] = anotherString.value; // v2代表参数字符串所对应的char数组
int i = 0;
while (n-- != 0) { // 逐位比较
if (v1[i] != v2[i])
return false;
i++;
}
return true;
}
}
return false;
}
str.charAt()通过下表获取索引处的值String tmp = "test";
System.out.println(tmp.charAt(3)); // t
str.concat("...")返回拼接结果,不改变str本身String tmp = "test";
System.out.println(tmp.concat(" plus")); // test plus
str.contains("...")判断是否包含子字符串String tmp = "test";
System.out.println(tmp.contains("es")); // true
str.endsWith("...")判断是不是以...结尾String tmp = "test";
System.out.println(tmp.endsWith("st")); // true
str.equalsIgnoreCase(String tmp)比较时忽略大小写String tmp = "test";
String tmp1 = "test01";
System.out.println(tmp.equalsIgnoreCase(tmp1)); // false
str.indexof("...")返回指定字符第一次出现时的索引值String tmp = "test";
System.out.println(tmp.indexOf("t")); // 0
str.indexof("...",index)返回从index开始往后指定字符第一次出现时的索引值String tmp = "test";
System.out.println(tmp.indexOf("t",2)); // 3
str.isEmpty当且仅当length()为0时返回trueString tmp = "test";
System.out.println(tmp.isEmpty()); // false
str.toCharArray()将字符串还原成char数组String tmp = "test";
System.out.println(tmp.toCharArray()); // test
str.split("...")将字符串根据...拆分String tmp = "This is a test";
String[] res = tmp.split(" ");
for (String i : res) {
System.out.print(i + " \\ "); // This \ is \ a \ test \
}
str.startsWith(...)判断是否以指定字符串开头String tmp = "This is a test";
System.out.println(tmp.startsWith("This")); // true
str.substring()字符串截取String tmp = "This is a test";
// 一个参数确定开始位置
System.out.println(tmp.substring(3)); // s is a test
// 两个参数确定起止位置(左闭右开)
System.out.println(tmp.substring(3,8)); // s is
str.toLowerCase() / str.toUpperCase()将字符强制大小写String tmp = "This is a test";
System.out.println(tmp.toLowerCase()); // this is a test
System.out.println(tmp.toUpperCase()); // THIS IS A TEST
str.trim()去除前面和后面的空格String tmp = " This is a test ";
System.out.println(tmp.trim()); // This is a test
StringBuffer:支持线程安全,性能相对较差
StringBuilder: 不支持线程安全,性能相对较好
// StringBuilder的底层数组比较String的数组,少了一个final修饰符,因此说明StingBuilder时可变的
// 构造方法:
// 无参构造
StringBuilder tmp = new StringBuilder();
// StringBuilder底层使用的是一个叫做value的字符数组(默认16个字符)
System.out.println(tmp.capacity()); // 16
// 如果不断的使用append方法进行字符串拼接,StringBuilder就会自动扩容
tmp.append("Hei bro, this is a test !");
System.out.println(tmp.capacity()); // 34
// 有参构造
// 如果出现有参构造,StringBuilder的容量会在初始化字符串的基础上加上16
StringBuilder tmp = new StringBuilder("This is a test");
System.out.println(tmp.capacity()); // 30
新数组容量 =(原数组的容量+1)*2 :这种扩容机制会使扩容的次数越来越少,增加性能
// 如果StringBuilder需要扩容,就会定义一个新的char数组
// 新数组容量是(原数组的容量+1)*2
// 并且会将指向原数组的指针指向新数组,原数组会被GC进行回收
private int newCapacity(int minCapacity) {
// overflow-conscious code
int newCapacity = (value.length << 1) + 2;
if (newCapacity - minCapacity < 0) {
newCapacity = minCapacity;
}
return (newCapacity <= 0 || MAX_ARRAY_SIZE - newCapacity < 0)
? hugeCapacity(minCapacity)
: newCapacity;
}
str.capacity()返回StringBuilder容量str.delete(a,b)删除此序列的子字符串中的字符// 删除子字符串之后,并不影响StringBuilder容量
StringBuilder tmp = new StringBuilder("This is a test");
System.out.println(tmp.delete(3,8)); // Thia test
str.deleteCharAt(a)删除指定下标的元素str.replace(a,b,...) 用指定字符串替换指定区间StringBuilder tmp = new StringBuilder("This is a test");
System.out.println(tmp.replace(4,8," have fun! ")); // This have fun! a test
str.setCharAt()设定指定位置的字符StringBuilder tmp = new StringBuilder("This is a test");
tmp.setCharAt(4,'G');
System.out.println(tmp); // ThisGis a test
str.toString()创建一个新的String对象,去除尾部多余的空格@Override
public String toString() {
// Create a copy, don't share the array
return new String(value, 0, count);
}
System.out.println(System.currentTimeMillis());
针对八种基本数据类型进行定义以及使用的,封装类有八个
| 基本数据类型 | 对应的封装类 |
|---|---|
| byte | Byte |
| short | Short |
| int | Integer |
| long | Long |
| float | Float |
| double | Double |
| char | Character |
// 四种整型的封装类支持使用常量池技术(-128 ~ 127)
// 通过 = 号赋值的整数,会被存储在常量池中
// 等号直接赋值(常量池)
Integer tmp1 = 1;
// 使用构造方法(堆)
Integer tmp2 = new Integer(1);
// 导入包
import java.util.Scanner;
// 使用Scanner类创建一个对象
Scanner s = new Scanner(System.in);
// 获取系统输入
// 获取String类型数据
String input = s.nextline();
// 获取整型数据
int input = Integer.parseInt(s.nextLine());
// 获取浮点型数据
float input = Float.parseFloat(s.nextLine());
装箱:将基本类型转换为封装类类型的过程
拆箱:将封装类类型转换为基本类型的过程
int a = 1;
Integer b = 1;
// 自动装箱
Integer tmp = a;
// 手动装箱
Integer tmp = new Interger(a);
// 自动拆箱
int tmp = b;
// 手动拆箱
int tmp = b.intValue();
我真的很习惯使用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
对于作为String#tr参数的单引号字符串文字中反斜杠的转义状态,我觉得有些神秘。你能解释一下下面三个例子之间的对比吗?我特别不明白第二个。为了避免复杂化,我在这里使用了'd',在双引号中转义时不会改变含义("\d"="d")。'\\'.tr('\\','x')#=>"x"'\\'.tr('\\d','x')#=>"\\"'\\'.tr('\\\d','x')#=>"x" 最佳答案 在tr中转义tr的第一个参数非常类似于正则表达式中的括号字符分组。您可以在表达式的开头使用^来否定匹配(替换任何不匹配的内容)并使用例如a-f来匹配一
我只想对我一直在思考的这个问题有其他意见,例如我有classuser_controller和classuserclassUserattr_accessor:name,:usernameendclassUserController//dosomethingaboutanythingaboutusersend问题是我的User类中是否应该有逻辑user=User.newuser.do_something(user1)oritshouldbeuser_controller=UserController.newuser_controller.do_something(user1,user2)我
在Ruby1.9.3(可能还有更早的版本,不确定)中,我试图弄清楚为什么Ruby的String#split方法会给我某些结果。我得到的结果似乎与我的预期相反。这是一个例子:"abcabc".split("b")#=>["a","ca","c"]"abcabc".split("a")#=>["","bc","bc"]"abcabc".split("c")#=>["ab","ab"]在这里,第一个示例返回的正是我所期望的。但在第二个示例中,我很困惑为什么#split返回零长度字符串作为返回数组的第一个值。这是什么原因呢?这是我所期望的:"abcabc".split("a")#=>["bc"
什么是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)删:算法时间复杂度跟增保持一致查:既然是非线性结构,所以查询某一个节点的时候
目录前言滤波电路科普主要分类实际情况单位的概念常用评价参数函数型滤波器简单分析滤波电路构成低通滤波器RC低通滤波器RL低通滤波器高通滤波器RC高通滤波器RL高通滤波器部分摘自《LC滤波器设计与制作》,侵权删。前言最近需要学习放大电路和滤波电路,但是由于只在之前做音乐频谱分析仪的时候简单了解过一点点运放,所以也是相当从零开始学习了。滤波电路科普主要分类滤波器:主要是从不同频率的成分中提取出特定频率的信号。有源滤波器:由RC元件与运算放大器组成的滤波器。可滤除某一次或多次谐波,最普通易于采用的无源滤波器结构是将电感与电容串联,可对主要次谐波(3、5、7)构成低阻抗旁路。无源滤波器:无源滤波器,又称
@作者:SYFStrive @博客首页:HomePage📜:微信小程序📌:个人社区(欢迎大佬们加入)👉:社区链接🔗📌:觉得文章不错可以点点关注👉:专栏连接🔗💃:感谢支持,学累了可以先看小段由小胖给大家带来的街舞👉微信小程序(🔥)目录自定义组件-behaviors 1、什么是behaviors 2、behaviors的工作方式 3、创建behavior 4、导入并使用behavior 5、behavior中所有可用的节点 6、同名字段的覆盖和组合规则总结最后自定义组件-behaviors 1、什么是behaviorsbehaviors是小程序中,用于实现