Java入門・初心者質問スレ Part.6
レス数が900を超えています。1000を超えると表示できなくなるよ。
>>818
OpenJDKの改変はライセンス違反。
OpenJDKのソースはGPLだが、特許の利用許諾はJCPを通っていることが条件。
改変したらJCPの認定から外れるので、その瞬間にオラクルに特許侵害で巨額の賠償金を請求されることになる。 これってKotlinならセフセフなのか?
Javaはもうやめたほうが安全そうだな >>819
あ、そうなの? GPLは改変再配布を許すライセンスじゃなかったっけ? >>821
GPLv2による利用許諾はあくまで著作権の利用許諾
配布者が利用者を特許侵害で訴えることの可能な欠陥ライセンスだ
オラクルにとっては極めて好都合なライセンスでもある >>820
今流行ってるのは Java VM 上で動く Kotlin だが、それ使い続ける限り何か影響はあるかも知れない。
しかし kotlin は JavaScript で動くようにするやつやネイティブも作っているのでそちらは影響を受けない筈。 >>822
なるほど。
でも特許部分をくり抜いた版って出せるんじゃないかな?
まあそれだともはやJavaではなくなるのかも知れないが。 >>824
さすがにそんなことをするくらいなら.NET Core向けにJavaコンパイラとJava APIを実装したほうが遥かに建設的で手っ取り早いだろうな
オラクルに言わせれば、APIには著作権が及ぶらしいからどのみち訴訟は避けられないわけだが、
海賊版JVMを作るのに比べたら裁判の勝ち目はあるだろう 実行スピードは落ちても構わないのでCPUにかかる負担を減らしたい場合
簡単な方法は無いでしょうか 全部手動でやればいいんじゃね? CPUにかかる負担ゼロになるし。 >>829-830
分からないなら黙っていてください。(NGしました)
>>831
ありがとうございます。 文字列str1から文字列"str2"を検索する方法はこうですが
str1.indexOf("str2",0)
両方の文字を数値のbyte配列化してこれより高速に検索する方法ないですか?
地道に配列内を上からチェックしていけばいいですが
それよりスマートで高速な方法ないでしょうか?
文字処理は一般に遅いですが
結局str1.indexOfが一番はやい? 正規表現使えば?
速度だけならどういう実装が一番速いのかは知らんけど 気に入らないならソースの String.java を参考にして自作してみれば?
もっと高速化する楽な方法はJNIで作ったり外部コマンド動かしたりする方法かな。 >>834
電文処理など、文字列とBYTE列が交わるポイントは確かにあるけど、
可能な限り、文字列は文字列、BYTE列はBYTE列の世界で取り扱うほうが
いいと思うよ。 indexOfの実装にもよるんじゃねえの?
単なる文字列じゃなくなっても大手術しなくて済むように無理しないのが一番良いと思うけど。
バイト列だと思いもよらない文字の切れ目でヒットしたり地獄見ると思う。
入ってるかどうかだけが知りたいならcontainsにするか、それでも遅いならCharSequenceにしてからトライ木にするか。 >>834
ボトルネックでないのに無駄に高速化しようとするのは愚策だから止めた方が。
ボトルネックになってるのであれば同じ文書内を複数の単語で何度も検索するとか
同じ単語で大量の文書を検索するとか具体的なシチュエーションが出てくるだろうし、
そのシチュエーションに適した高速化すりゃいいだけ。
どんなシチュエーションでもindexOfを上回る
(苦労してコード書く意味があるようなレベルで)ってのはかなり難しい。
例えばbyte[]に変換ってのも検索と比較すれば十分重い処理だし。 了解しました
結局str1.indexOfでやるのがよさそうですね >>831
sleep入れても負担は増えるだけだろ
総計算量は同じでsleepを処理する計算が増える
手で処理するしかない
具体的なプログラムが提示されれば改善の余地はあるかも知れないが
時間あたりの負荷が高く他の処理の邪魔をしたくないという話ならプロセスのプライオリティを下げろ >>834
レベルと用途が不明だが
事前にindexを作っておいてそこから探すのが速い >>841
sleepを処理する計算?sleepの前処理のこと?それ以上にsleepすればいいのでは?
JavaVM内だとどうやってるのかは知らないが、sleepはVM内で指定の時間後に割り込み掛かるようにしてからスレッド停止してるだけじゃないの?
スレッド停止するならその分だけCPUタイムは食わなくなるよ。 windowsならこういうのあるよ。
Windows10 - プロセス(アプリ)の優先度を指定(変更)する方法
https://pc-karuma.net/windows-10-process-priority/ Linux だと nice とか renice とか ionice ってコマンドがある。 >>846
負担と言ったら普通そうなのでは?
それに元の質問は「実行スピードは落ちても構わないのでCPUにかかる負担を減らしたい」だから
JavaVMのOSでのプライオリティそのままでやるとしたらプログラム中の sleep ぐらいしか方法
ないと思うが? >>848>>849
時間当たりのCPU使用率は減って負荷は下がるだろ?
sleep してもそうならない環境なんかないと思うがなあ。 × 普通に考えると
○ 説明できないし実はよく考えていない >>850
なんで負荷とか自分の思い込んだ質問に置き換えてんだよ
プログラマに向いてない > 負担と言ったら普通そうなのでは?
考えてなかったのか この回答のプログラムなんですけど、
https://stackoverflow.com/questions/39530446/google-spread-sheets-appending-data-using-java
BatchUpdateSpreadsheetRequest batchRequests = new BatchUpdateSpreadsheetRequest();
と宣言時にオブジェクトを new して代入してますが、その後でまた
batchRequests = new BatchUpdateSpreadsheetRequest();
というコードが出てきます。 requests という変数でも同じことをしています。
これって何か意味があるんでしょうか、それとも無駄なことなんでしょうか? >>856
その実装がどうだかは知らないけど
コンストラクタに副作用があれば意味ある
ただし1回目の代入は無駄
副作用とは、どっかと通信するとか、ファイルに出力するとか >>857>>858
ありがとうございました。別に意味はないようですね。実際コードを削除しても動作は変わりませんでした。 もう無理だろう。sleepで負担が増えるとか書いてる時点で触れてはならない人と気づくべきだったということ。 詭弁のガイドラインから推測すると、次はbusywaitの出番だな。 負担だから命令投げた時点で発生するものということだろ
CPUタイムで課金とかいうシステムならありえる グーグルスプレッドシートのurlから、シートのIDを抽出するコートはどう書いたらいいですか?例えば、
https://docs.google.com/spreadsheets/d/1IS5WSNxSVSPYseqr0T4LJHU80paHR4vQqB8Cm4GAbiw/edit#gid=0
/d/ の後から次の / まで、 1IS5WSNxSVSPYseqr0T4LJHU80paHR4vQqB8Cm4GAbiw がIDになるのですが、
https://developers.google.com/sheets/guides/concepts
>スプレッドシート ID は、文字、数字、いくつかの特殊文字で構成される文字列です。 次の正規表現を使用すると、
>Google スプレッドシートの URL からスプレッドシート ID を抽出できます。
/spreadsheets/d/([a-zA-Z0-9-_]+)
と公式にあるんですが、具体的に java のコードで、IDを抽出するにはどうしたらいいですか? >>868
どうしても正規表現でやってみたいなら別として、そうでないなら普通に文字列切り出せばいいのでは? javaの入門サイトでググってみて自分で書いたコードがこれなんですけど、もっと簡単なやり方があれば有り難いんですが。
String url = "https://docs.google.com/spreadsheets/d/1IS5WSNxSVSPYseqr0T4LJHU80paHR4vQqB8Cm4GAbiw/edit#gid=0" ;
Pattern p = Pattern.compile("/spreadsheets/d/([a-zA-Z0-9-_]+)");
Matcher m = p.matcher(url);
m.find() ;
System.out.println("IDは : " + m.group().replace("/spreadsheets/d/", "")); >>870
正規表現使うならreplaceはいらないよ
m.group(1)でおk こんなので性器表現w
IDの前のURLが完全に固定なら次のスラッシュのインデックスまで切り出せば良いだけやん
アホなのか? >>873
0が全体の文字列で、1からが()で囲んだグループってことでいいんでしょうか?なんか難しい。 ブラウザの自動操作なら、iMacros とか、Selenium WebDriver を使えば?
Ruby のSelenium WebDriverでは、その要素に、id が付いていれば、
以下で、その要素を取得できる
element = driver.find_element(:id => "何々")
ブラウザの右クリックメニューから、要素を検査で、その要素のHTMLタグ表記を見れる 頼むから数値リテラル直接使うような糞みたいなコードをドヤ顔で貼るのやめてくれ
これだから初心者スレは嫌なんだよ >>882
COBOLのコード見たら発狂しそう
数値リテラルベタ書きよりVBとかの全パターンIF文ひたすら書くあれの方が辛いけど >>882
素敵なコードをお待ちしております
まさか批判するだけしてダンマリなんて真似しないよなぁ サンプルプログラムみたいなやつに一々反応するのもなんだかなー 1回しか出現しない数値をわざわざ定数とか面倒じゃね? 定数であることすら意識したくないのでこう書く
public int getSomeDomainValue() {
return 100;
} ここで気の利いたワンライナーを書けないのが悲しい… getIdメソッドの中に閉じ込めるべきであって
定数と言ってるやつはSIerのJava土方丸出し ああ。そうだな。id取り出すメソッドあった方がいいな。 こういうのをINT_THREEみたいに書いて定数にしたつもりのやついるよな >>870
Stringの正規表現メソッドを使う
url.replaceAll(pattern, "$1");
Matcher受け取ってfind()してgroup()してって面倒くさすぎだわな
さすがJava 昔は スタティック ボイド メイン て言ってたけど
今は スタティック ボイド メーン て言うの? 昔も今も関係なく main の日本での読みは大雑把にその二つがあるってだけのこと。 まあここは日本だし
「マインでもいいよね、だってマインスイーパーってあるだろ?」
とか言っても大丈夫。笑われるだけだから。 新宿のALTAはアルタだがキーボードのALTはオルト cocoa なんか米語ではコウコウで英語ならケウケウだしな
英語おカタカナ表記に今更突っ込んでも仕方がない 前に借りてきたDVDを再生したら最初のコピーはダメとか出す画面で「ワーニング」と上に書いてあって驚いた。 pingをピングと読むのも許す。
でもHong-Kongをホングコングと読むのは許さない。 >>905
そうそう、ALT キーの ALT は alternative の ALT だからね AltとShiftはどっちも「変わる」だがその違いは?
ちなみに俺は忘れた >>913
shiftはタイプライターのやつを見るとなんとなくわかると思うが横にずらすんた。ずらして変わるのがシフト。
altは別のものを選択するみたいなやつ。 そういえばテレビの録画でタイムシフトなんていう言葉もあるな シフト勤務
日本語でも訛りはわからない場合あるけど
英語の発音は訛りで通じないって言うからな
あと語源が同じ他の言語の発音を比較してる時がある
日本語と中国語もなんで同じ文字にのに発音違うんだよとか言われてそう レス数が900を超えています。1000を超えると表示できなくなるよ。