国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

目次
データ クラスを使用する
參考:
空のセキュリティを使用する
1. Null 可能型
2. 安全な通話
3. エルヴィス演算子 (?:)
4. !! 演算子 (非 null アサーション)
5. 関數(shù)パラメータの null 許容性
6. 安全な変換 (as? 演算子)
7. ラムダ式における Null の安全性
8. let 関數(shù)を使用する
9. ベストプラクティス
デフォルトで不変性
1. デフォルトで不変である変數(shù) (val)
ホームページ Java &#&チュートリアル Java 開(kāi)発者のための Kotlin (パート 1)

Java 開(kāi)発者のための Kotlin (パート 1)

Jan 27, 2025 pm 04:04 PM

Kotlin for Java Developers (Part 1)

Java はプログラミング言語(yǔ)の中で優(yōu)勢(shì)であるため、Java 開(kāi)発者が Kotlin を使用中に同じ間違いを犯しているのを何度も見(jiàn)かけます。誤解しないでください。これは、これらがバグであると言っているのではなく、開(kāi)発者が Java での開(kāi)発に慣れていて Kotlin の機(jī)能を活用していない場(chǎng)合、Kotlin で「コードの臭い」が発生する傾向があるということです。

この記事では、私がよく目にするコードの匂いと、それを「Kotlin 方式」で理想的に実裝する方法について説明します。

このシリーズのパート 1 では以下について説明します:

  • データ クラスを使用する
  • 空のセキュリティを使用する
  • デフォルトで不変性

データ クラスを使用する

私の Java 開(kāi)発者にもレコード クラスの使用経験がある人が増えてくると、このトピックはすぐに消えるかもしれません。それでも、Java レコードと Kotlin データ クラスの間にはいくつかの違いがあります。

Java メソッド:

public class Person {
  private String name;
  private int age;

  public Person(String name, int age) {
    this.name = name;
    this.age = age;
  }
  // Getters, setters, ...
}

または記録のために:

public record Person(
    String name,
    int age
) {
}

Kotlin の方法:

data class Person(val name: String, var age: Int)

Java レコードと Kotlin データ クラスの間には、知っておくとよい相違點(diǎn)がいくつかあります。

  • Java レコードと Kotlin データ クラスは両方とも不変のデータ キャリアです。
  • Java では、フィールドは暗黙的に最終的なものであり、構(gòu)築後に変更することはできません。一方、Kotlin では、val または var を使用してフィールドを変更可能にするかどうかを選択できます。
  • もう 1 つの違いは、Java のレコード クラスは暗黙的に Final でシールされており、拡張できないことを意味しますが、Kotlin ではデータ クラスを拡張できることです。
  • Kotlin では、Java では不可能な、equals、hashCode、toString メソッドをオーバーライドすることもできます。
  • Kotlin は、Java では使用できない、すぐに使用できる copy メソッドを提供します。

いくつかの例:

Java でオブジェクトをコピー

Person p2 = new Person(p1.getName(), p1.getAge());

Kotlin:

val p2 = p1.copy(age = 42)

または Java での宣言の構(gòu)造化:

String name = p1.getName();
int age = p1.getAge();

Kotlin:

val (name, age) = p1
println(name) // "John"
println(age) // 42

參考

  • Kotlin データ クラス
  • Baeldung: Kotlin データ クラス

空のセキュリティを使用する

私の意見(jiàn)では、Kotlin の null 安全性は最も強(qiáng)力な機(jī)能の 1 つです。これは、時(shí)間と手間を大幅に節(jié)約する畫(huà)期的な機(jī)能です。 Kotlin では、null 安全性が型システムに組み込まれているため、null 関連のランタイム エラーを回避しやすくなります。

1. Null 可能型

Kotlin では、null 許容型は明示的に宣言されます。これは、null 値を保持できる変數(shù)を持つことができますが、それを宣言で明示的に指定する必要があることを意味します。

null 非許容型 (デフォルトの動(dòng)作)

デフォルトでは、Kotlin のすべての型は null 非許容です。つまり、変數(shù)は null 値を保持できません。

val name: String = "John" // 不可空
name = null // 編譯錯(cuò)誤!

Nullable 型

NULL 値を保持できる変數(shù)を宣言するには、? 演算子を使用する必要があります。

val name: String? = null // 可空

2. 安全な通話

強(qiáng)力な機(jī)能は、安全な通話オペレーター? です。これにより、NullPointerException をスローせずに、安全にメソッドを呼び出したり、プロパティにアクセスしたりできるようになります。

public class Person {
  private String name;
  private int age;

  public Person(String name, int age) {
    this.name = name;
    this.age = age;
  }
  // Getters, setters, ...
}

?.operator は、オブジェクトが空かどうかをチェックし、空の場(chǎng)合はすぐに null を返し、そうでない場(chǎng)合はメソッドの呼び出しまたはプロパティへのアクセスを続けます。オブジェクトが空の場(chǎng)合、式全體が null と評(píng)価されます。

3. エルヴィス演算子 (?:)

Elvis 演算子?: 演算子の左側(cè)の式が空の場(chǎng)合にデフォルト値を返す略語(yǔ)です。

public record Person(
    String name,
    int age
) {
}

4. !! 演算子 (非 null アサーション)

!! 演算子を使用して、値が null ではないことをコンパイラーに伝えることができます。値が null の場(chǎng)合は、NullPointerException がスローされます。

data class Person(val name: String, var age: Int)

ヒント: この !! 演算子の使用は、null 安全性の目的に反しているため、非推奨です。

5. 関數(shù)パラメータの null 許容性

関數(shù)を定義するときに、パラメーターを null にできるかどうかを指定できます。この場(chǎng)合、呼び出し側(cè)が処理する必要があります。

Person p2 = new Person(p1.getName(), p1.getAge());

6. 安全な変換 (as? 演算子)

? として安全な変換演算子があり、変換が不可能な場(chǎng)合は null を返します。

val p2 = p1.copy(age = 42)

7. ラムダ式における Null の安全性

ラムダ式や高階関數(shù)で null 安全機(jī)能を使用することもできます。

String name = p1.getName();
int age = p1.getAge();

8. let 関數(shù)を使用する

let 関數(shù)は、null 以外のオブジェクトでコードのブロックを?qū)g行できるようにするスコープ関數(shù)です。これは、安全な方法で null 許容オブジェクトのコードを?qū)g行するためによく使用されます。

例とデフォルト値:

val (name, age) = p1
println(name) // "John"
println(age) // 42

9. ベストプラクティス

  • !! 演算子の使用は避けてください
  • 安全な呼び出しと Elvis 演算子を使用して、null 許容型を安全に処理し、デフォルト値を提供します
  • 必要な場(chǎng)合にのみ null 許容型を使用してください

參考:

  • Kotlin Null の安全性

デフォルトで不変性

Kotlin は関數(shù)型プログラミング スタイルを強(qiáng)く推奨しています。関數(shù)型プログラミング スタイルの場(chǎng)合、不変性は、特にマルチスレッド アプリケーションでエラーを回避する上で重要な役割を果たします。

おそらく Kotlin または Java での関數(shù)型プログラミングについては別の記事を書(shū)くことになると思いますが、今は不変性に焦點(diǎn)を當(dāng)てましょう。

Kotlin は基本的に、可変オブジェクトよりも不変オブジェクトを好みます。これにより、特に同時(shí)実行環(huán)境において、コードがよりシンプルで予測(cè)可能になります。

1. デフォルトで不変である変數(shù) (val)

Kotlin では、val キーワードを使用して宣言された変數(shù)はデフォルトで不変です。これは Java での最終変數(shù)の宣言に非常に似ていますが、いくつかの重要な違いがあります。

    Kotlin の val 変數(shù)は実際には読み取り専用であり、それに割り當(dāng)てられた値は初期化後に変更できません。
  • ただし、値がオブジェクトの場(chǎng)合、プロパティ自體が val として宣言されていない限り、オブジェクトのプロパティは変更できます。

例:

val name: String = "John" // 不可空
name = null // 編譯錯(cuò)誤!
Java との違い: Java では、変數(shù)が再割り當(dāng)てできないようにするために、final キーワードを使用しますが、変數(shù)が指すオブジェクトは引き続き変更可能です。 Kotlin の主な違いは、不変性がデフォルトで変數(shù)にまで拡張され、アプリケーション全體のより予測(cè)可能で安全な設(shè)計(jì)が促進(jìn)されることです。

<變>変數(shù)変數(shù)の例:kotlinでvarキーワードを使用して、変數(shù)を再起動(dòng)できるようにします。

public class Person {
  private String name;
  private int age;

  public Person(String name, int age) {
    this.name = name;
    this.age = age;
  }
  // Getters, setters, ...
}
ヒント: Kotlinは、非債務(wù)を確保するために、VARの代わりにできるだけ多くを奨勵(lì)しています。

2。不変のコレクション

デフォルトでは、uncralacteriaを使用することも奨勵(lì)されています。特徴的なセットは、作成後の変更を防ぎます。listof()を使用してリストを作成することはできません。要素を追加、削除、または変更することはできません。

public record Person(
    String name,
    int age
) {
}
コレクションを変更する必要がある場(chǎng)合は、MutableListof()またはその他の変數(shù)コレクションタイプを使用できます。

data class Person(val name: String, var age: Int)
Javaの違い:Javaでは、コレクション(ArrayListなど)はデフォルトで変動(dòng)します。つまり、要素を自由に変更できます。

3。変數(shù)データカテゴリの不可能

Kotlinのデータクラスはデフォルトで不可能です。データクラスを定義するとき、屬性は通常VALとして宣言され、クラスを変更しません。これにより、特にAPI、データベースレコード、または作成後に変更されるべきではないその他のオブジェクトステータスを扱う場(chǎng)合、クラスは値オブジェクトに非常に適しています。

Person p2 = new Person(p1.getName(), p1.getAge());
val p2 = p1.copy(age = 42)
4。シーリングクラスの不満足

Kotlinのシーリングクラスも不変であり、持続していないデータモデルとよく一致しています。シーリングクラスは通常、ステータスや応答などの限られたクラス構(gòu)造を表すために使用され、その不道徳は狀態(tài)または結(jié)果が誤って変更されないことを保証します。

以上がJava 開(kāi)発者のための Kotlin (パート 1)の詳細(xì)內(nèi)容です。詳細(xì)については、PHP 中國(guó)語(yǔ) Web サイトの他の関連記事を參照してください。

このウェブサイトの聲明
この記事の內(nèi)容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰屬します。このサイトは、それに相當(dāng)する法的責(zé)任を負(fù)いません。盜作または侵害の疑いのあるコンテンツを見(jiàn)つけた場(chǎng)合は、admin@php.cn までご連絡(luò)ください。

ホットAIツール

Undress AI Tool

Undress AI Tool

脫衣畫(huà)像を無(wú)料で

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード寫(xiě)真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

寫(xiě)真から衣服を削除するオンライン AI ツール。

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無(wú)料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡(jiǎn)単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無(wú)料のコードエディター

SublimeText3 中國(guó)語(yǔ)版

SublimeText3 中國(guó)語(yǔ)版

中國(guó)語(yǔ)版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強(qiáng)力な PHP 統(tǒng)合開(kāi)発環(huán)境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開(kāi)発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

現(xiàn)代のジャワの非同期プログラミング技術(shù) 現(xiàn)代のジャワの非同期プログラミング技術(shù) Jul 07, 2025 am 02:24 AM

Javaは、Java19での完了可能なストリーム(ProjectReactorなど)、仮想スレッドの使用など、非同期プログラミングをサポートしています。 1.CompletableFutureチェーンコールを通じてコードの読みやすさとメンテナンスを改善し、タスクオーケストレーションと例外処理をサポートします。 2。ProjectReactorは、バックプレッシャーメカニズムとリッチ演算子を備えた応答性プログラミングを?qū)g裝するためのモノとフラックスタイプを提供します。 3.仮想スレッドは、同時(shí)性コストを削減し、I/O集約型タスクに適しており、従來(lái)のプラットフォームスレッドよりも軽量で拡張が容易です。各方法には適用可能なシナリオがあり、適切なツールをお客様のニーズに応じて選択する必要があり、混合モデルはシンプルさを維持するために避ける必要があります

Javaで酵素を使用するためのベストプラクティス Javaで酵素を使用するためのベストプラクティス Jul 07, 2025 am 02:35 AM

Javaでは、列挙は固定定數(shù)セットを表すのに適しています。ベストプラクティスには以下が含まれます。1。列挙を使用して固定狀態(tài)またはオプションを表して、タイプの安全性と読みやすさを改善します。 2.フィールド、コンストラクター、ヘルパーメソッドなどの定義など、柔軟性を高めるために、酵素にプロパティとメソッドを追加します。 3. enummapとEnumsetを使用して、パフォーマンスとタイプの安全性を向上させ、配列に??基づいてより効率的であるためです。 4.動(dòng)的値、頻繁な変更、複雑なロジックシナリオなどの列挙の悪用を避けてください。これらは他の方法に置き換える必要があります。列挙の正しい使用は、コードの品質(zhì)を改善し、エラーを減らすことができますが、適用される境界に注意を払う必要があります。

Java Nioとその利點(diǎn)を理解する Java Nioとその利點(diǎn)を理解する Jul 08, 2025 am 02:55 AM

Javanioは、Java 1.4によって導(dǎo)入された新しいIoapiです。 1)バッファとチャネルを?qū)澫螭趣筏皮い蓼埂?)バッファ、チャネル、セレクターのコアコンポーネント、3)ノンブロッキングモードをサポートし、4)従來(lái)のIOよりも効率的に並行接続を処理します。その利點(diǎn)は、次のことに反映されます。1)非ブロッキングIOはスレッドオーバーヘッドを減らし、2)データ送信効率を改善し、3)セレクターがマルチプレックスを?qū)g現(xiàn)し、4)メモリマッピングはファイルの読み取りと書(shū)き込みを速めます。注:1)バッファのフリップ/クリア操作は混亂しやすく、2)不完全なデータをブロックせずに手動(dòng)で処理する必要があります。3)セレクター登録は時(shí)間內(nèi)にキャンセルする必要があります。4)NIOはすべてのシナリオに適していません。

ハッシュマップはJavaで內(nèi)部的にどのように機(jī)能しますか? ハッシュマップはJavaで內(nèi)部的にどのように機(jī)能しますか? Jul 15, 2025 am 03:10 AM

HashMapは、Javaのハッシュテーブルを介してキーと値のペアストレージを?qū)g裝し、そのコアはデータの位置をすばやく配置することにあります。 1.最初にキーのHashCode()メソッドを使用して、ハッシュ値を生成し、ビット操作を介して配列インデックスに変換します。 2。異なるオブジェクトは、同じハッシュ値を生成し、競(jìng)合をもたらす場(chǎng)合があります。この時(shí)點(diǎn)で、ノードはリンクされたリストの形式で取り付けられています。 JDK8の後、リンクされたリストが長(zhǎng)すぎ(デフォルトの長(zhǎng)さ8)、効率を改善するために赤と黒の木に変換されます。 3.カスタムクラスをキーとして使用する場(chǎng)合、equals()およびhashcode()メソッドを書(shū)き直す必要があります。 4。ハッシュマップは容量を動(dòng)的に拡大します。要素の數(shù)が容量を超え、負(fù)荷係數(shù)(デフォルト0.75)を掛けた場(chǎng)合、拡張して再ハッシュします。 5。ハッシュマップはスレッドセーフではなく、マルチスレッドでconcuを使用する必要があります

Java EnumsとBest Practicesの効果的な使用 Java EnumsとBest Practicesの効果的な使用 Jul 07, 2025 am 02:43 AM

Javaの列挙は、定數(shù)を表すだけでなく、動(dòng)作をカプセル化し、データをキャリーし、インターフェイスを?qū)g裝することもできます。 1.列挙は、週や狀態(tài)などの固定インスタンスを定義するために使用されるクラスであり、文字列や整數(shù)よりも安全です。 2。コンストラクターに値を渡すことやアクセス方法の提供など、データとメソッドを運(yùn)ぶことができます。 3.スイッチを使用して、明確な構(gòu)造を持つさまざまなロジックを処理できます。 4.さまざまな列挙値の差別化された動(dòng)作を作成するためのインターフェイスまたは抽象的なメソッドを?qū)g裝できます。 5.虐待、ハードコードの比較、順序の値への依存、合理的に命名とシリアル化を避けるために注意してください。

JavaのSingletonデザインパターンとは何ですか? JavaのSingletonデザインパターンとは何ですか? Jul 09, 2025 am 01:32 AM

JavaのSingleton Design Patternは、クラスに1つのインスタンスしかないことを保証し、プライベートコンストラクターと靜的方法を介したグローバルアクセスポイントを提供することを保証します。これは、共有リソースへのアクセスを制御するのに適しています。実裝方法には以下が含まれます。1。レイジーロード、つまり、インスタンスは最初のリクエストが要求されたときにのみ作成されます。これは、リソースの消費(fèi)が高く、必ずしも必要ではない狀況に適しています。 2。スレッドセーフ処理。同期方法または再確認(rèn)ロックを介して、マルチスレッド環(huán)境で1つのインスタンスのみが作成され、パフォーマンスへの影響が低下するようにします。 3.クラスの読み込み中にインスタンスを直接初期化するHungry Loadingは、事前に初期化できる軽量オブジェクトまたはシナリオに適しています。 4.列挙の実裝は、Java列挙を使用してシリアル化、スレッドの安全性をサポートし、反射攻撃を防止することは、推奨される簡(jiǎn)潔で信頼できる方法です。特定のニーズに応じて、さまざまな実裝方法を選択できます

Javaオプションの例 Javaオプションの例 Jul 12, 2025 am 02:55 AM

オプションは、意図を明確に表現(xiàn)し、ヌルの判斷のコードノイズを減らすことができます。 1. optional.ofnullableは、nullオブジェクトに対処する一般的な方法です。たとえば、マップから値を取得する場(chǎng)合、Orelseを使用してデフォルト値を提供できるため、ロジックはより明確かつ簡(jiǎn)潔になります。 2.チェーンコールマップを使用してネストされた値を達(dá)成してNPEを安全に回避し、リンクが無(wú)効である場(chǎng)合はデフォルト値を返す場(chǎng)合は自動(dòng)的に終了します。 3.フィルターは條件付きフィルタリングに使用でき、その後の操作は條件が満たされた場(chǎng)合にのみ実行され続けます。そうしないと、軽量のビジネス判斷に適したOrelseに直接ジャンプします。 4.基本的なタイプや単純なロジックなど、複雑さを高めるなど、オプションを過(guò)剰使用することはお?jiǎng)幛幛筏蓼护?。一部のシナリオはNUに直接戻ります。

java.io.notserializableExceptionを修正する方法は? java.io.notserializableExceptionを修正する方法は? Jul 12, 2025 am 03:07 AM

java.io.notserializableExceptionに遭遇するためのコアワークアウンドは、シリアル化する必要があるすべてのクラスがシリアル化可能なインターフェイスを?qū)g裝し、ネストされたオブジェクトのシリアル化サポートを確認(rèn)することです。 1.メインクラスに機(jī)器を追加する可能性のあるものを追加します。 2.クラス內(nèi)の対応するカスタムフィールドのクラスも、シリアル化可能なものを?qū)g裝していることを確認(rèn)します。 3.一時(shí)的に使用して、シリアル化する必要のないフィールドをマークする。 4.コレクションまたはネストされたオブジェクトの非シリアル化されたタイプを確認(rèn)します。 5.どのクラスがインターフェイスを?qū)g裝していないかを確認(rèn)します。 6.キーデータの保存やシリアル化可能な中間構(gòu)造の使用など、変更できないクラスの交換設(shè)計(jì)を検討します。 7.変更を検討してください

See all articles