この記事では、Object クラス、日時クラス、StringBuilder クラス、パッケージング クラスなど、将来の開発で頻繁に使用される、一般的に使用される Java API をいくつか紹介します。
オブジェクトクラス
Java.lang.Objectクラスは、Java言語のルートクラスであり、すべてのクラスの親クラスです。これで記述されたすべてのメソッドはサブクラスで使用できます。子オブジェクトがインスタンス化されると、最後に見つかった親クラスは Object です。
Object クラスには 11 個のメンバー メソッドが含まれています。一般的に使用される 2 つのメソッドのみをリストします:
- public String toString():返回该对象的字符串表示。 - public boolean equals(Object obj):指示其他某个对象是否与此对象“相等”。
1. toString メソッド
public String toString()
: オブジェクトの文字列表現を返します。 public String toString()
:返回该对象的字符串表示。
toString方法返回该对象的字符串表示,其实该字符串内容就是对象的类型+@+内存地址值,由于toString方法返回的结果是内存地址,而在开发中,经常需要按照对象的属性得到相应的字符串表现形式,一般都会重写它。
方法重写:
//重写toString方法 @Override public String toString() { return "Person{" + "name='" + name + '\'' + ", age=" + age + '}'; }
2.equals方法
public boolean equals(Object obj)
:指示其他某个对象是否与此对象“相等”。
调用成员方法equals并指定参数为另一个对象,则可以判断这两个对象是否是相同的。这里的“相同”有默认和自定义两种方式。
如果没有覆盖重写equals方法,那么Object类中默认进行==
运算符的对象地址比较,只要不是同一个对象,结果必然为false。
方法重写:
/* Object类的equals方法,默认比较的是两个对象的地址值 重写equals方法,比较两个对象的属性 问题: 隐含这一个多态,无法使用子类特有的内容(属性和方法) 解决: 可以使用向下转型(强制类型转换)把o类型转换为Person */ //重写equals方法 @Override public boolean equals(Object o){ //增加一个判断,如果传递的参数是this本身,直接返回true if(this==o) return true; //增加一个判断,如果传递的参数是null,直接返回false if(o==null) return false; //增加一个判断,防止类型转换一次ClassCastException if(o instanceof Person){ //使用向下转型,把o转换为Person类型 Person p=(Person)o; //比较两个对象的属性,一个对象是this(p1),一个对象是p(o->p2) boolean b=this.name.equals(p.name) && this.age==p.age; return b; } //不是Person类型,返回false return false;
日期时间类
1.Date类
java.util.Date 类表示特定的瞬间,精确到毫秒。
常用方法:
public long getTime() 把日期对象转换成对应的时间毫秒值。
实例:
/* long getTime() 把日期转换为毫秒值(相当于System.currentTimeMillis()方法) 返回自1970年1月1日0点0分0秒 GMT以来此Date对象表示的毫秒数 */ public static void demo3(){ Date date =new Date(); long time=date.getTime(); System.out.println(time); } //结果值 1533119389083
2.DateFormat类
java.text.DateFormat
是日期/时间格式化子类的抽象类,我们通过这个类可以帮我们完成日期和文本之间的转换,也就是可以在Date对象与String对象之间进行来回转换。
格式化:按照指定的格式,从Date对象转换为String对象。
解析:按照指定的格式,从String对象转换为Date对象。
常用两个方法:
- public String format(Date date):将Date对象格式化为字符串。 - public Date parse(String source):将字符串解析为Date对象。
实例:
package demo2_Date; import java.text.ParseException; import java.text.SimpleDateFormat; import java.util.Date; public class Test02_Dateformat { public static void main(String[] args) throws ParseException { //将date对象格式化为字符串 find_Date01(); //将字符串解析为date对象 find_Date02(); } //将字符串解析为date对象 public static void find_Date01() throws ParseException { SimpleDateFormat sdf=new SimpleDateFormat("yyyy-MM-dd HH-mm-ss"); String str="2018年8月1日 7点12分23秒"; Date s=sdf.parse(str); System.out.println(new Date()); } //将date对象格式化为字符串 public static void find_Date02(){ SimpleDateFormat sdf=new SimpleDateFormat("yyyy年MM月dd日 HH时mm分ss秒"); String s=sdf.format(new Date()); System.out.println(s); } }
计算出生天数:
package demo2_Date; import java.text.ParseException; import java.text.SimpleDateFormat; import java.util.Date; import java.util.Scanner; /* 计算出生天数 1.键盘录入出生日期,并转换date类型(毫秒值) 2.获取当前日期毫秒值 3.相减得到差值毫秒值,转换得到天数 */ public class Test03_FindBirthday { public static void main(String[] args) throws ParseException { //录入出生日期 Scanner sc=new Scanner(System.in); System.out.println("请输入你的出生日期:格式(yyyy-MM-dd)"); String bithDateString=sc.next(); //使用DateFormat类中的parse方法,把字符串类型的出生日期,转换成为date类型 SimpleDateFormat sdf=new SimpleDateFormat("yyyy-MM-dd"); Date birthDate=sdf.parse(bithDateString); //把出生日期转换为毫秒值 long birthDateTime=birthDate.getTime(); long nowDateTime=new Date().getTime(); long daysTime=nowDateTime-birthDateTime; //获取天数 System.out.println(daysTime/1000/60/60/24); } }
输出结果:
请输入你的出生日期:格式(yyyy-MM-dd) 1996-05-24 8104 Process finished with exit code 0
3.Calendar类
概念:
java.util.Calendar
public static Calendar getInstance():使用默认时区和语言环境获得一个日历2.equalsメソッド
public boolean equals(Object obj)
: 他のオブジェクトがこのオブジェクトと「等しい」かどうかを示します。 メンバーメソッドequalsを呼び出し、パラメータを別のオブジェクトとして指定すると、2つのオブジェクトが同じかどうかを判断できます。ここでの「同じ」には、デフォルトとカスタムの 2 つの方法があります。 equals メソッドがオーバーライドされていない場合、==
演算子のオブジェクト アドレス比較が Object クラスでデフォルトで実行され、それらが同じオブジェクトでない限り、結果は false になる必要があります。 。 メソッドのオーバーライド: - public int get(int field):返回给定日历字段的值。 - public void set(int field, int value):将给定的日历字段设置为给定值。 - public abstract void add(int field, int amount):根据日历的规则,为给定的日历字段添加或减去指定的时间量。 - public Date getTime():返回一个表示此Calendar时间值(从历元到现在的毫秒偏移量)的Date对象Date time クラス1.Date クラスjava.util.Date クラスは、ミリ秒単位の精度で特定の瞬間を表します。 共通メソッド:
package demo2_Date;
import java.util.Calendar;
import java.util.Date;
/*
四种常用成员方法:
- public int get(int field):返回给定日历字段的值。
- public void set(int field, int value):将给定的日历字段设置为给定值。
- public abstract void add(int field, int amount):根据日历的规则,
为给定的日历字段添加或减去指定的时间量。
- public Date getTime():返回一个表示此Calendar时间值(从历元到现在的毫秒偏移量)的Date对象。
*/
public class Test04_Calendar {
public static void main(String[] args) {
// demo1();
// demo2();
demo3();
demo4();
}
/*
- public Date getTime():返回一个表示此Calendar时间值(从历元到现在的毫秒偏移量)的Date对象。
*/
public static void demo4(){
Calendar cal=Calendar.getInstance();
Date date=cal.getTime();
System.out.println(date); //Wed Aug 01 19:20:51 CST 2018
}
/*
public abstract void add(int field, int amount):根据日历的规则,
为给定的日历字段添加或减去指定的时间量。
参数:设定指定的日历字段以及修改量
返回值:修改过后的日历字段代表的值
*/
public static void demo3(){
Calendar cal =Calendar.getInstance();
//加两年,减两月
cal.add(Calendar.YEAR,+2);
cal.add(Calendar.MONTH,-2);
int year =cal.get(Calendar.YEAR);
int month=cal.get(Calendar.MONTH)+1;
int day=cal.get(Calendar.DAY_OF_MONTH);
System.out.println(year+"年"+month+"月"+day+"日");// 2020年6月1日
}
/*
public void set(int field, int value):将给定的日历字段设置为给定值。
参数:设定指定的日历字段以及设置值
返回值:重新设定的日历字段代表的值
*/
public static void demo2(){
//创建Calendar对象
Calendar cal= Calendar.getInstance();
cal.set(Calendar.YEAR ,2020);
int year=cal.get(Calendar.YEAR);
System.out.println(year+"年"); //2020年
}
/*
public int get(int field):返回给定日历字段的值。
参数:传递指定的日历字段(YEAR,MONTH)
返回值:日历字段代表的具体的值
*/
public static void demo1(){
//创建Calendar对象
Calendar cal= Calendar.getInstance();
//获取年份
int year =cal.get(Calendar.YEAR);
//获取月份
int month=cal.get(Calendar.MONTH)+1;
int day=cal.get(Calendar.DAY_OF_MONTH);
System.out.println(year+"年"+month+"月"+day+"日"); //2018年8月1日
}
}
インスタンス: package demo3_System; import java.util.Arrays; /* 两个常用方法: 1.currentTimeMillis 2.arraycopy */ public class Test01_System { public static void main(String[] args) { demo1(); demo2(); } //将数组中指定的数据拷贝到另一个数组中。 public static void demo2(){ int[] arr1={1,2,3,4,5}; int[] arr2={6,7,8,9,10}; System.arraycopy(arr1,0,arr2,0,3); System.out.println(Arrays.toString(arr2)); //[1, 2, 3, 9, 10] } //返回以毫秒为单位的时间 public static void demo1(){ long begin=System.currentTimeMillis(); int sum=0; for(int i=0;i<10000;i++){ System.out.println(i); } long end=System.currentTimeMillis(); System.out.println(end-begin); //205毫秒 }2.DateFormat クラス
java.text.DateFormat
は日付/時刻書式設定サブクラスの抽象クラスです。このクラスを使用すると便利です。日付とテキストの間の変換を完了します。つまり、Date オブジェクトと String オブジェクトの間で相互に変換できます。
フォーマット
: 指定されたフォーマットに従って、Date オブジェクトから String オブジェクトに変換します。解析
: 指定された形式に従って String オブジェクトから Date オブジェクトに変換します。出生日数の計算: | rrreee出力結果: | rrreee
概念: |
java.util.Calendar これは、Date の後に表示され、多くの Date メソッドを置き換えるカレンダー クラスです。このクラスは、簡単にアクセスできるように、すべての可能な時間情報を静的メンバー変数としてカプセル化します。 Calendar クラスは、さまざまな時間属性を取得するのに便利です。 |
Calendarは抽象クラスであり、静的メソッドを通じてサブクラスオブジェクトを作成して返します: | rrreee共通メソッド: Calendarには4つの共通メソッドがあり、主にgetメソッドとgetTimeメソッドです | rrreee
システム クラス | 1.currentTimeMillis メソッド |
2.arraycopyメソッド | 配列に指定されたデータを別の配列にコピーします。 |
StringBuilderクラス | 1. 概要 |
2. よく使用されるメソッド: | rrreee3. 例: | rrreee
1. | 基本タイプ - パッケージングクラス |
基本タイプ | 対応するパッケージングクラス(java.langパッケージの下にあります) |
2. アンボックス化とパッキング
基本型と対応するパッケージング クラス オブジェクトの間で相互に変換するプロセスは、「ボックス化」および「アンボックス化」と呼ばれます。
ボックス化: 基本型から対応するラッパー クラス オブジェクトに変換します。
Unboxing: ラッパー クラス オブジェクトから対応する基本型に変換します。
3. 自動アンボックス化と自動パッキング
Java 5 (JDK 1.5) 以降では、基本型とパッケージング クラスの間で変換が必要になることが多いため、基本型とパッケージ化クラスのボックス化とアンボックス化のアクションが自動的に実行されるようになりました。だから私たちは何もする必要はありません。そう、これが自動梱包、自動箱詰めなのです。
関連記事:
【javaチュートリアル】Java StringBufferクラスとStringBuilderクラス
以上が一般的に使用される Java API: オブジェクト クラス、日付と時刻のクラス、StringBuilder クラス、パッケージ化クラスの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

クラスローダーは、統一されたクラスファイル形式、動的読み込み、親代表団モデル、プラットフォーム非依存バイトコードを通じて、さまざまなプラットフォーム上のJavaプログラムの一貫性と互換性を保証し、プラットフォームの独立性を実現します。

Javaコンパイラによって生成されたコードはプラットフォームに依存しませんが、最終的に実行されるコードはプラットフォーム固有です。 1。Javaソースコードは、プラットフォームに依存しないバイトコードにコンパイルされます。 2。JVMは、特定のプラットフォームのバイトコードをマシンコードに変換し、クロスプラットフォーム操作を保証しますが、パフォーマンスは異なる場合があります。

マルチスレッドは、プログラムの応答性とリソースの利用を改善し、複雑な同時タスクを処理できるため、最新のプログラミングで重要です。 JVMは、スレッドマッピング、スケジューリングメカニズム、同期ロックメカニズムを介して、異なるオペレーティングシステム上のマルチスレッドの一貫性と効率を保証します。

Javaのプラットフォームの独立性とは、書かれたコードがJVMが変更なしでインストールされた任意のプラットフォームで実行できることを意味します。 1)JavaソースコードはBytecodeにコンパイルされ、2)BytecodeはJVMによって解釈および実行されます、3)JVMは、プログラムが異なるオペレーティングシステムで実行されることを確認するために、メモリ管理とガベージコレクション機能を提供します。

JavaApplicationScanIndEDENCOUNTIONPLATFORM-SPECISTESUESUSESEJVM'SABSTRACTION.REASONSINCLUDE:1)NativeCodeandLibraries、2)OperatingSystemDifferences、3)JVMimplementationVariations、および4)HardweardePencies.TomiteTETETETESES、DEVELAPERSHOULD:1)

クラウドコンピューティングにより、Javaのプラットフォームの独立性が大幅に向上します。 1)JavaコードはBytecodeにコンパイルされ、異なるオペレーティングシステムでJVMによって実行され、クロスプラットフォーム操作が確保されます。 2)DockerとKubernetesを使用してJavaアプリケーションを展開して、携帯性とスケーラビリティを向上させます。

java'splatformendenceallowsdevelopersowritecodeodeonceanceandonitondeviceoros withajvm.

Dockerなどのコンテナ化技術は、Javaのプラットフォームの独立性を置き換えるのではなく、強化します。 1)環境全体の一貫性を確保し、2)特定のJVMバージョンを含む依存関係を管理する、3)展開プロセスを簡素化して、Javaアプリケーションをより順応性と管理しやすくする。


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

SAP NetWeaver Server Adapter for Eclipse
Eclipse を SAP NetWeaver アプリケーション サーバーと統合します。

MantisBT
Mantis は、製品の欠陥追跡を支援するために設計された、導入が簡単な Web ベースの欠陥追跡ツールです。 PHP、MySQL、Web サーバーが必要です。デモおよびホスティング サービスをチェックしてください。

AtomエディタMac版ダウンロード
最も人気のあるオープンソースエディター

Dreamweaver Mac版
ビジュアル Web 開発ツール

SublimeText3 Linux 新バージョン
SublimeText3 Linux 最新バージョン
