- Java锁的逻辑(结合对象头和ObjectMonitor)
- 还在用饼状图?来瞧瞧这些炫酷的百分比可视化新图形(附代码实现)⛵
- 自动注册实体类到EntityFrameworkCore上下文,并适配ABP及ABPVNext
- 基于Sklearn机器学习代码实战
由于String类的对象内容不可改变,每次拼接都会构建一个新的String对象,既耗时,又浪费内存空间 这时需要通过java提供的StringBuild类解决这个问题 StringBuilder又称为可变字符序列,它是一个类似于 String 的字符串缓冲区,可以看作是一个容器,容器中可以装很多字符串 。
可变指的是StringBuilder对象中的内容是可变的 。
public StringBuilder() : 创建一个空的缓冲区 public StringBuilder(String srt) : 创建一个存储了str的缓冲区 。
//public StringBuilder():创建一个空白可变字符串对象,不含有任何内容
StringBuilder sb = new StringBuilder();
System.out.println("sb:" + sb);
System.out.println("sb.length():" + sb.length());
//public StringBuilder(String str):根据字符串的内容,来创建可变字符串对象
StringBuilder sb2 = new StringBuilder("hello");
System.out.println("sb2:" + sb2);
System.out.println("sb2.length():" + sb2.length());
public StringBuilder append(Object obj) : 向容器中追加任意类型数据, 转为字符串 。
// 链式编程, 链式编程返回结果 看最后调用的方法
StringBuilder abc = new StringBuilder(stringBuilder.append(10).append("abc").append(10.1).append(new Object()).toString());
System.out.println("abc = " + abc);
public StringBuilding reverse() : 将缓冲区数据反转 。
String string = new StringBuilder(abc).reverse().toString();
System.out.println(string);
java.util.Date 表示特定的瞬间,精确到毫秒 。
public Date() : 当前日期对象, 从运行程序的时间到时间原点经历的毫秒值,转换成Date对象,分配Date对象并初始化此对象,以表示分配它的时间(精确到毫秒)。 public Date(long date) :将指定参数的毫秒值date,转换成Date对象,分配Date对象并初始化此对象 。
时间原点: 1970年1月1日 00:00:00 中国处于东8区 严格来说是1970年1月1日 00:08:00 1s = 1000ms 。
public static void main(String[] args) {
// 创建日期对象,把当前的时间
System.out.println(new Date()); // Tue Jan 16 14:37:35 CST 2020
// 创建日期对象,把当前的毫秒值转成日期对象
System.out.println(new Date(0)); // Thu Jan 01 08:00:00 CST 1970
}
long getTime() : 获取日期对象的毫秒值 。
// 获取从 时间原点 到 当前日期 的毫秒值
long time = nowTime.getTime();
System.out.println(time);
void setTime(long time) : 设置毫秒值 。
// 设置偏移毫秒值为0, 即时间原点
nowTime.setTime(0);
System.out.println(nowTime);
java.text.DateFormat 是日期/时间格式化子类的抽象类,我们通过这个类可以帮我们完成日期和文本之间的转换,也就是可以在Date对象与String对象之间进行来回转换.
由于DateFormat为抽象类,不能直接使用,所以需要常用的子类 java.text.SimpleDateFormat 。 这个类需要一个模式(格式)来指定格式化或解析的标准.
public SimpleDateFormat() : 用默认的模式和语言环境的日期格式符号构造SimpleDateFormat.
默认格式为: (年)-(月)-(日) (上午/下午)xx:xx 。
public SimpleDateFormat(String pattern) :用给定的模式和默认语言环境的日期格式符号构造SimpleDateFormat.
参数pattern是一个字符串,代表日期时间的自定义格式.
常用的格式规则为:
标识字母(区分大小写) | 含义 |
---|---|
y | 年 |
M | 月 |
d | 日 |
H | 时 |
m | 分 |
s | 秒 |
备注:更详细的格式规则,可以参考SimpleDateFormat类的API文档.
public String format(Date date) : 传递日期对象,返回格式化后的字符串.
// 将当前日期 转换为 x年x月x日 xx:xx:xx
Date nowTime = new Date();
DateFormat df = new SimpleDateFormat("yyyy年MM月dd日 HH:mm:ss E");
System.out.println(df.format(nowTime));
public Date parse(String source) 传递字符串,返回日期对象 。
// 获取sDate所代表的时间的毫秒值
String sDate = "1949-10-01";
DateFormat df2 = new SimpleDateFormat("yyyy-MM-dd");
// parse 若无法解析字符串会抛出异常 ParseException
Date date = df2.parse(sDate);
long time = date.getTime();
System.out.println(time);
java.util.Calendar Calendar 日历类, 替换掉了许多Date的方法 它是一个抽象类, 但提供了静态方法创建对象, 同时也提供了很多静态属性 。
月份 0-11 代表 1-12月 国外每周的第一天是星期日 。
public static Calendar getInstance() :使用默认时区和语言环境获得一个日历.
Calendar c = Calendar.getInstance();
System.out.println(c);
使用 类名.属性名 调用,代表给定的日历字段:
字段值 | 含义 |
---|---|
YEAR | 年 |
MONTH | 月(从0开始,可以+1使用) |
DAY_OF_MONTH | 月中的天(几号) |
HOUR | 时(12小时制) |
HOUR_OF_DAY | 时(24小时制) |
MINUTE | 分 |
SECOND | 秒 |
DAY_OF_WEEK | 周中的天(周几,周日为1,可以-1使用) |
int get(int field) : 返回给定日历字段的值 。
int year = c.get(Calendar.YEAR);
// 0-11表示月份 需要+1
int month = c.get(Calendar.MONTH) + 1;
// DATE 和 DAY_OF_MONTH 的值是一样的
int day = c.get(Calendar.DAY_OF_MONTH);
System.out.println(year+"年"+month+"月"+day+"日");
TimeZone getTimeZone() 获取时区 。
TimeZone timeZone = c.getTimeZone();
System.out.println(timeZone);
void add(int field, int amount) : 根据日历规则 为给定的字段添加或减去指定的时间量 。
// 将日历设置为2000.5.1, 当前时间为2023.4.5
// add方法设置偏移量
c.add(Calendar.YEAR, -23);
c.add(Calendar.MONTH, 1);
c.add(Calendar.DATE, -4);
System.out.println(c.get(Calendar.YEAR)+"."+(c.get(Calendar.MONTH) + 1)+"."+c.get(Calendar.DAY_OF_MONTH));
void set(int field, int value) : 将给定的日历字段设置为给定值 void set(int year, int month, int date) 直接设置年月日为指定值 。
// set(int field, int value)方法 将日历设置为2001.4.2
c.set(Calendar.YEAR, 2001);
c.set(Calendar.MONTH, 3);
c.set(Calendar.DAY_OF_MONTH, 2);
System.out.println(c.get(Calendar.YEAR)+"."+(c.get(Calendar.MONTH) + 1)+"."+c.get(Calendar.DAY_OF_MONTH));
// set(int year, int month, int date)方法 将日历设置为2003.10.1
c.set(2003, 9, 1);
System.out.println(c.get(Calendar.YEAR)+"."+(c.get(Calendar.MONTH) + 1)+"."+c.get(Calendar.DAY_OF_MONTH));
Date getTime() : 将日历对象转为日期对象 。
Date date = c.getTime();
System.out.println(date);
public class Demo {
public static void main(String[] args) {
int[] arr = {3,765,8234,1,23};
System.out.println(arrayConcatToSting(arr));
}
public static String arrayConcatToSting(int[] arr) {
StringBuilder stringBuilder1 = new StringBuilder("[");
for (int i = 0; i < arr.length; i++) {
stringBuilder1.append(arr[i]);
if (i < arr.length - 1) {
stringBuilder1.append(", ");
} else if (i == arr.length - 1){
stringBuilder1.append("]");
}
}
return stringBuilder1.toString();
}
}
import java.text.DateFormat;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.Scanner;
public class Demo {
public static void main(String[] args) throws ParseException {
Scanner sc = new Scanner(System.in);
System.out.print("请输入您的生日(年.月.日): ");
System.out.println("您活了"+howLongHaveYouLived(sc.nextLine())+"天");
}
public static long howLongHaveYouLived (String str) throws ParseException {
DateFormat df = new SimpleDateFormat("yyyy.MM.dd");
Date birthDay = df.parse(str);
long birthDayTime = birthDay.getTime();
long nowTime = new Date().getTime();
return (nowTime - birthDayTime) / 1000 / 60 / 60 /24;
}
}
import java.util.Calendar;
import java.util.Date;
import java.util.Scanner;
public class Demo {
public static void main(String[] args) {
// 计算指定年份的2月有多少天
Scanner sc = new Scanner(System.in);
System.out.print("请输入您要指定的年份: ");
int inputYear = sc.nextInt();
System.out.println(inputYear+"年的2月有"+getDay(inputYear)+"天");
}
public static int getDay(int year) {
Calendar calendar = Calendar.getInstance();
calendar.set(year, 2, 1);
calendar.add(Calendar.DATE, -1);
return calendar.get(Calendar.DATE);
}
}
最后此篇关于java--Stringbuild、Date和Calendar类的文章就讲到这里了,如果你想了解更多关于java--Stringbuild、Date和Calendar类的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
也许是一个愚蠢的问题,但我有一个在 Java 文档中没有找到的问题。 Calendar.get(Calendar.DAY_OF_WEEK) 的值是否会根据 Calendar.getFirstDayOf
假设以下代码在 2009 年 8 月 22 日(星期六)执行 Calendar c = Calendar.getInstance(); c.set(Calendar.DAY_OF_WEEK
我正在使用以下代码检查所选月份是否为一月: if (calendar.get(Calendar.MONTH) == Calendar.JANUARY) { ... } 这给了我一个 lint
我有两个 Calendar 变量,分别命名为 calendar1 和 calendar2 其中存储了一些日历值。 我想比较这些变量的 MINUTE 值。 我找到了两种方法,但我想知道有什么区别以及哪一
根据文档 ( here ),Google 提供了一些相同的范围: https://www.googleapis.com/auth/calendar读/写访问到日历 https://www.google
我想问一下,是否可以在不调用 Google 日历 API(需要互联网连接)或启动 native 日历 Activity (不需要)的情况下添加日历事件?只需将日历事件添加到设备 native 日历中(
我们可以从谷歌日历设置中获取工作时间数据吗?我已经了解了日历的 API : https://developers.google.com/calendar/v3/reference/settings/g
我正在尝试使用 Exchange Web 服务访问日历数据,但我似乎无法弄清楚如何访问其他用户共享的日历(当它不是他们的默认日历时)。假设我公司的另一个用户创建了一个共享日历并与我共享,我什至找不到日
我对 Java/Android 中的日期比较有点困惑 DateFormat df = new SimpleDateFormat("dd/MM/yy HH:mm");
我正在使用Google的Calendar API,但遇到了一个问题。当我设置要插入的事件的dateTime时,需要设置小时偏移量,但是由于o DST的原因,它需要一个小时。我可以为日历设置一个属性,以
在Google日历的常规网络用户界面中,当我添加事件时,可以选择将其设置为“提醒”,而不是“事件”。 我正在尝试使用Python API进行复制,但是似乎找不到有关如何执行该操作的信息。我找到的所有文
我们可以使用这个link通过参数向Google日历添加新事件 https://www.google.com/calendar/render? action=TEMPLATE& text=EventNa
除了在纪元显式设置它们之外,是否有任何现有方法可以使用日历 API 来获取填充纪元时间的日历?我所能做的就是获取当前时间。 最佳答案 没有预定义的构造函数或工厂方法来执行此操作,但它相当简单: Cal
我试图在我的应用程序上次更新时显示在 TextView 中(例如,“上次更新时间为 12:13”)。我正在尝试使用 Calendar 实例,我认为我理解正确,但我似乎遇到了麻烦. 我知道要获取一个实例
这个问题在这里已经有了答案: Calendar.before(Object when), why Object? (3 个答案) 关闭 8 年前。 我遇到了问题,因为我试图将日期传递给 Calend
在IOS5上使用获取所有日历时 EKEventStore *eventStore = [[EKEventStore alloc] init]; NSArray * calendars = [event
当我运行以下代码时: int year = 2017; int month = 7; int dayOfMonth = 10; Calendar dateOfBirth = new Gregorian
要么我不理解方法 getActualMaximum(int) 或字段 WEEK_OF_YEAR,要么涉及 Sun 错误(或所有三个)...有人可以向我解释为什么(至少在德语语言环境中...) 以下代码
我正在检查我几年前写的代码。然后我意识到 Android Studio 在 Calendar.AM 处给出了注释,它说它必须是 Calendar.SUNDAY、Calendar.MONDAY 之一等等
我需要将给定日期复制 100 次(我无法通过引用传递)。我想知道以下两个中哪个是更好的选择 newTime=Calendar.getInstance().setTime(originalDate);
我是一名优秀的程序员,十分优秀!