実現したいこと
javaで、gradleを利用したオセロのプログラムを作っています。Eclipseのコンソールに日本語を出力できるようにしたいです。
発生している問題・分からないこと
実行結果が文字化けします。
エラーメッセージ
error
1Working Directory: C:\Users\ryu20\eclipse-workspace_java\othero 2Gradle user home: C:\Users\ryu20\.gradle 3Gradle Distribution: Gradle wrapper from target build 4Gradle Version: 8.10.2 5Java Home: C:\Program Files\Java\jdk-21 6JVM Arguments: None 7Program Arguments: None 8Build Scans Enabled: false 9Offline Mode Enabled: false 10Gradle Tasks: run 11 12> Task :app:compileJava UP-TO-DATE 13> Task :app:processResources NO-SOURCE 14> Task :app:classes UP-TO-DATE 15 16> Task :app:run 17Java Runtime version :21.0.2+13-LTS-58 18Charset.defaultCharset() :UTF-8 19---------------------------------------------- 20"file.encoding" = UTF-8 21"native.encoding" = MS932 22"sun.jnu.encoding" = MS932 23"sun.stdout.encoding" = UTF-8 24"sun.stderr.encoding" = UTF-8 25---------------------------------------------- 26縺ゅ>縺�縺医♀ 27UTF-8 28 0 1 2 3 4 5 6 7 290: E E E E E E E E 301: E E E E E E E E 312: E E E E E E E E 323: E E E B W E E E 334: E E E W B E E E 345: E E E E E E E E 356: E E E E E E E E 367: E E E E E E E E 37p1縺ョ繧ソ繝シ繝ウ 384 39 40W: 32 41B: 32 42蠑輔″蛻�縺� 43 44BUILD SUCCESSFUL in 2s 452 actionable tasks: 1 executed, 1 up-to-date 46
該当のソースコード
Java
1package org.example; 2 3import static org.example.Board.*; 4 5import java.nio.charset.Charset; 6 7public class Main{ 8 9 10 public static void main(String[] args) { 11 System.out.println("Java Runtime version :" + System.getProperty("java.runtime.version")); 12 System.out.println("Charset.defaultCharset() :" + Charset.defaultCharset()); 13 System.out.println("----------------------------------------------"); 14 System.out.println("\"file.encoding\" = " + System.getProperty("file.encoding")); 15 System.out.println("\"native.encoding\" = " + System.getProperty("native.encoding")); 16 System.out.println("\"sun.jnu.encoding\" = " + System.getProperty("sun.jnu.encoding")); 17 System.out.println("\"sun.stdout.encoding\" = " + System.getProperty("sun.stdout.encoding")); 18 System.out.println("\"sun.stderr.encoding\" = " + System.getProperty("sun.stderr.encoding")); 19 System.out.println("----------------------------------------------"); 20 System.out.println("あいうえお"); 21 22 var board = new Board(); 23 var p1 = new NPC_random_Player(W); 24 var p2 = new NPC_random_Player(B); 25 26 27 System.out.println(System.getProperty("file.encoding")); 28 29 board.show_board(); 30 31 while(board.num_of_stone(E)!=0 && board.num_of_stone(B)!=0 && board.num_of_stone(W)!=0) { 32 33 System.out.println("p1のターン"); 34 if(!board.turnable_pos_list(p1.get_color()).isEmpty()) { 35 p1.put_on(board); 36 board.show_board(); 37 }else { 38 System.out.println("パス。"); 39 } 40 41 42 if(board.num_of_stone(E)==0 && board.num_of_stone(B)==0 && board.num_of_stone(W)==0) { 43 break; 44 } 45 46 System.out.println("p2のターン"); 47 if(!board.turnable_pos_list(p2.get_color()).isEmpty()) { 48 p2.put_on(board); 49 board.show_board(); 50 }else { 51 System.out.println("パス。"); 52 } 53 54 System.out.println("ターン終了。"); 55 } 56 57 System.out.println("ゲーム終了。"); 58 board.show_board(); 59 System.out.println(p1.get_color()+": "+board.num_of_stone(p1.get_color())); 60 System.out.println(p2.get_color()+": "+board.num_of_stone(p2.get_color())); 61 if(board.num_of_stone(p1.get_color())>board.num_of_stone(p2.get_color())) { 62 System.out.println("p1の勝ち"); 63 }else if(board.num_of_stone(p1.get_color())<board.num_of_stone(p2.get_color())){ 64 System.out.println("p2の勝ち"); 65 }else { 66 System.out.println("引き分け"); 67 } 68 } 69}
build.gradle
1/* 2 * This file was generated by the Gradle 'init' task. 3 * 4 * This generated file contains a sample Java application project to get you started. 5 * For more details on building Java & JVM projects, please refer to https://docs.gradle.org/8.10.2/userguide/building_java_projects.html in the Gradle documentation. 6 */ 7 8plugins { 9 // Apply the application plugin to add support for building a CLI application in Java. 10 id 'eclipse' 11 id 'application' 12} 13 14repositories { 15 // Use Maven Central for resolving dependencies. 16 mavenCentral() 17} 18 19dependencies { 20 // Use JUnit Jupiter for testing. 21 testImplementation libs.junit.jupiter 22 23 testRuntimeOnly 'org.junit.platform:junit-platform-launcher' 24 25 // This dependency is used by the application. 26 implementation libs.guava 27} 28 29// Apply a specific Java toolchain to ease working on different environments. 30java { 31 toolchain { 32 languageVersion = JavaLanguageVersion.of(21) 33 } 34} 35 36 37application { 38 // Define the main class for the application. 39 mainClass = 'org.example.Main' 40 41 applicationDefaultJvmArgs = ["-Dsun.stdout.encoding=UTF-8", "-Dsun.stderr.encoding=UTF-8"] 42} 43 44tasks.named('test') { 45 // Use JUnit Platform for unit tests. 46 useJUnitPlatform() 47} 48
gradle.properties
1org.gradle.jvmargs=-Dfile.encoding=UTF-8
試したこと・調べたこと
- teratailやGoogle等で検索した
- ソースコードを自分なりに変更した
- 知人に聞いた
- その他
上記の詳細・結果
1.javaのエンコーディング設定をUTF-8にするため、gradle.propertiesを変更
2."sun.stdout.encoding" = UTF-8 "sun.stderr.encoding" = UTF-8 にするため(なぜ変更するとよいかは分からないが、サイトに書いてあったため。)、build.gradleを変更
3.Eclipseのエンコーディング設定を確認し、UTF-8に明示的に変更
4.プロジェクト内のファイルのエンコーディングがUTF-8であることを確認
5.コマンドプロンプトで実行しても文字化けすることを確認(文字コードを変えても同様)
6.gradleを使わずに、ローカルにあるjdkを使ってプログラムを実行すれば文字化けしない事を確認
補足
実行環境は、
Windows11, Eclipse , JAVA_VERSION=21.0.2, Gradle 8.10.2
です。
※gradle run --infoを実行したところ、下記のように注意書きがされていたのですが、関係ありますでしょうか?
Wanted: DaemonRequestContext{jvmCriteria=C:\Program Files\Java\jdk-21 (no JDK specified, using current Java home), daemonOpts=[--add-opens=java.base/java.util=ALL-UNNAMED, --add-opens=java.base/java.lang=ALL-UNNAMED, --add-opens=java.base/java.lang.invoke=ALL-UNNAMED, --add-opens=java.prefs/java.util.prefs=ALL-UNNAMED, --add-exports=jdk.compiler/com.sun.tools.javac.api=ALL-UNNAMED, --add-exports=jdk.compiler/com.sun.tools.javac.util=ALL-UNNAMED, --add-opens=java.base/java.nio.charset=ALL-UNNAMED, --add-opens=java.base/java.net=ALL-UNNAMED, --add-opens=java.base/java.util.concurrent.atomic=ALL-UNNAMED, -Dfile.encoding=UTF-8, -Duser.country=JP, -Duser.language=ja, -Duser.variant], applyInstrumentationAgent=true, nativeServicesMode=ENABLED, priority=NORMAL}
Actual: DefaultDaemonContext[uid=ca13f10a-3e04-4dba-98e2-39549775ed3a,javaHome=C:\Users\ryu20.vscode\extensions\redhat.java-1.35.1-win32-x64\jre\17.0.12-win32-x86_64,javaVersion=17,javaVendor=Eclipse Adoptium,daemonRegistryDir=C:\Users\ryu20.gradle\daemon,pid=1412,idleTimeout=10800000,priority=NORMAL,applyInstrumentationAgent=true,nativeServicesMode=ENABLED,daemonOpts=--add-opens=java.base/java.util=ALL-UNNAMED,--add-opens=java.base/java.lang=ALL-UNNAMED,--add-opens=java.base/java.lang.invoke=ALL-UNNAMED,--add-opens=java.prefs/java.util.prefs=ALL-UNNAMED,--add-exports=jdk.compiler/com.sun.tools.javac.api=ALL-UNNAMED,--add-exports=jdk.compiler/com.sun.tools.javac.util=ALL-UNNAMED,--add-opens=java.base/java.nio.charset=ALL-UNNAMED,--add-opens=java.base/java.net=ALL-UNNAMED,--add-opens=java.base/java.util.concurrent.atomic=ALL-UNNAMED,-XX:MaxMetaspaceSize=384m,-XX:+HeapDumpOnOutOfMemoryError,-Xms256m,-Xmx512m,-Dfile.encoding=UTF-8,-Duser.country=JP,-Duser.language=ja,-Duser.variant]
回答2件
あなたの回答
tips
プレビュー