X



ふらっと C#,C♯,C#(初心者用) Part137
■ このスレッドは過去ログ倉庫に格納されています
0001デフォルトの名無しさん (ドコグロ MM07-2FKJ)
垢版 |
2018/04/06(金) 17:40:19.48ID:oKXVP34zM
「どんなにくだらないC#プログラミングやVisual C#の使い方に関する質問でも誰かが優しくレスをしてくれるスレッド」です。
他のスレッドでは書き込めないような低レベルな質問、
質問者自身なんだか意味がよく分からない質問、
ググろうにもキーワードが分からないなど、勇気をもって書き込んでください。
内容に応じて他スレ・他板へ行くことを勧められることがあります。ご了承下さい。
なお、テンプレが読めない回答者、議論をしたいだけの人は邪魔なので後述のC#相談室に移動して下さい。
C#に関係の無い話題や荒らしの相手や罵倒レスはやめてください

>>980を踏んだ人は新スレを建てて下さい。
>>980が無理な場合、話し合って新スレを建てる人を決めて下さい。

■関連スレ
C#, C♯, C#相談室 Part95
http://mevius.5ch.net/test/read.cgi/tech/1508180530/
C#, C♯, C#相談室 Part93
https://mevius.5ch.net/test/read.cgi/tech/1492818720/
■前スレ
ふらっと C#,C♯,C#(初心者用) Part136
http://mevius.5ch.net/test/read.cgi/tech/1520057345/

■コードを貼る場合は↓を使いましょう。
http://ideone.com/
https://dotnetfiddle.net/

■情報源
https://msdn.microsoft.com/ja-jp/library/gg145045.aspx
https://docs.microsoft.com/ja-jp/dotnet/csharp/language-reference/index
https://msdn.microsoft.com/en-us/library/gg145045.aspx
http://referencesource.microsoft.com/
VIPQ2_EXTDAT: checked:vvvvv:1000:512:----: EXT was configured
0210デフォルトの名無しさん (ワッチョイ 1aa6-wlRc)
垢版 |
2018/04/24(火) 21:49:35.82ID:UZOTbxqf0
>>208
それなら納得
existsの宣言の位置を移動するとif(!exists)がスコープから外れちゃうもんね

>>209
>>204の方法で解決したんなら>>204の指摘が正しかったんでしょうよ
で、それに気づかなかったんならやっぱり例外が握りつぶされてたんでしょ
なら今後のためにも原因は分からずで片付けず例外の名前くらい確認しといたほうが良いと思うよ
0211デフォルトの名無しさん (ワッチョイ 9a98-9jjH)
垢版 |
2018/04/25(水) 15:12:14.28ID:lzwohvOS0
オブジェクト指向のプログラミングでは
変数じゃなくてプロパティにアクセスさせるべき
みたいな事をよく聞くんだけど
・プログラムの開始時にあるフラグ(true/false)を決めて、その後一切変更されることがない
・そのフラグには、コード中の様々な所からアクセスがある
って場合は、プロパティじゃなくてpublicな変数でフラグを定義してもいいんですか?

オブジェクト指向がよくわかってないせいか
プロパティを経由するのがどうしても遠回りというか
一つ余分な作業を挟んでるように感じてしまう・・・
0212デフォルトの名無しさん (ワッチョイ 4e80-c0HJ)
垢版 |
2018/04/25(水) 15:30:51.28ID:eqJJBtIM0
変数は、公開しちゃダメ

その変数に、誰かが代入するかも知れないと考えると、
その変数に代入しているか、すべての場所を確かめないといけなくなるから、
プログラミングできなくなる

だから、プロパティで代入禁止に設定する

ただし、絶対に代入できない定数なら、公開してもよい
0213デフォルトの名無しさん (ワッチョイ 9a98-9jjH)
垢版 |
2018/04/25(水) 16:03:36.81ID:lzwohvOS0
>>212
後から書き換えられるのを確実に防止するために
プロパティを使うってことか なるほど
1人でコード書いてるからそういう発想が無かったけど
自分も後から絶対変な値を代入しない保証ないもんな

てことは、>>211の例だと
・引数付きのコンストラクタを使って、フラグの状態をインスタンス化
・そのフラグのプロパティはgetのみ設定
ってすればいいのか?

でもこれだと、そういうフラグを立てるタイミングがたくさんあったら
その分だけクラスを準備しとくことになると思うんだけど
そういうもんなの?
0214デフォルトの名無しさん (ワッチョイ 9a98-9jjH)
垢版 |
2018/04/25(水) 16:12:23.29ID:lzwohvOS0
あ、いや
クラスを複数準備する必要はないな

>>213の後半の話は無しで
0215デフォルトの名無しさん (ワッチョイ 4bbb-txNp)
垢版 |
2018/04/25(水) 16:13:38.42ID:VelEInRI0
>>211
212は読まなくていい
フィールドだってreadonly修飾子で代入禁止できるが、212はそんなことも分かってないから

プロパティがフィールドと違う点は大ざっぱに
* 派生クラスでオーバーライドできる
* プロパティから構造体を返すとコピーされる
の2点
この2つの特性が必要ない(または避けたい)場合にフィールドを選択してよい
判断できないならプロパティを選択する
0217デフォルトの名無しさん (ワッチョイ 1aa6-wlRc)
垢版 |
2018/04/25(水) 16:51:44.20ID:I8kFq/qw0
>>211
>>215はどこかのコピペじゃないならすごい分かりやすくて尊敬
一つだけ補足すると、↓のようなこともあるからクラスがpublicの場合は
現状だけでなく将来の変更の可能性も考えてフィールドかプロパティか判断したほうが良い

public フィールドをプロパティに変える (2016/05/16追記)
https://qiita.com/chocolamint/items/f04665ce2db211abb2d2#public-%E3%83%95%E3%82%A3%E3%83%BC%E3%83%AB%E3%83%89%E3%82%92%E3%83%97%E3%83%AD%E3%83%91%E3%83%86%E3%82%A3%E3%81%AB%E5%A4%89%E3%81%88%E3%82%8B-20160516%E8%BF%BD%E8%A8%98

あと>>212も善意で答えてるのは分かるんだけど
代入できるかどうかだけを判断基準にしてる時点でズレてて
定数の説明も参考にならない気がするから割と真面目に>>212は読まないほうが良いと思う
すまぬ>>212
0218デフォルトの名無しさん (ワッチョイ 9a98-9jjH)
垢版 |
2018/04/25(水) 17:43:22.74ID:lzwohvOS0
>>215
>* プロパティから構造体を返すとコピーされる
これが、全然分からんのだけど
classの代わりにstructを使った場合の話であってる?
今の自分が考えたところで、どうせちゃんと理解出来ない気もするけど
0219デフォルトの名無しさん (ワッチョイ 1a1e-fvqh)
垢版 |
2018/04/25(水) 17:44:09.08ID:EO6K8yEq0
>>212は別に全く問題ないだろ。

>>211の要はカプセル化の質問に対して、>>212はカプセル化の話として一般論として答えただけじゃん。

それに対して>>215>>217はここはC#のスレだからC#特有のreadonlyなフィールドあるよとか言語依存の情報
つけ足してるだけじゃん。
0220212 (ワッチョイ 4e80-c0HJ)
垢版 |
2018/04/25(水) 17:48:51.21ID:eqJJBtIM0
オブジェクト指向では、変数は公開しない。
公開できるのは、処理(関数)だけ

クラス内を開発する人と、そのクラスを使う人は、別の会社・人を想定しているから、
変数にアクセスさせたら、絶対にダメ

クラス内を作っている開発者は、後で付け加えられる処理を予想できないから。
クラス内を開発した後に、別人が変数にアクセスして、動きを変えたらバグる

異なる会社間での開発を可能にする、
オブジェクト指向の大原則・カプセル化
0221デフォルトの名無しさん (アウアウエー Sa52-PKj8)
垢版 |
2018/04/25(水) 17:50:35.02ID:ClmIY1xNa
プロパティから構造体を返すとコピーってのは意味わかんないね
コピーされるのは右辺がプロパティだろうがフィルドだろうが同じだよw

>>211
少なくともパブリックなメンバーに関しては、あえてフィールドを使う理由はないって
理解でいいと思うよ。例外はアンマネージドコードの呼び出しで使う型を定義する場合ぐらい。

フォールドのプロパティーに対して優位な点は

(1) 軽量である
(2) 簡潔に書ける

このぐらいしかない。

(1)が重要なケースなんかまずない。
(2)については、古いC#はともかく今のC#は儒分簡潔に書けるようになって来てる。
0222デフォルトの名無しさん (アウアウエー Sa52-PKj8)
垢版 |
2018/04/25(水) 17:59:38.62ID:ClmIY1xNa
>>220
カプセル化っていのは、触る必要がないもの、触られては困るものを隠すこと。
この質問にはほとんど関係ない話w

フィールドをプロパティにしようが、触る必要がない文脈で触られることを防げるわけじゃないw
せいぜいセッターで値が適切かどうかチェックできる程度
0224デフォルトの名無しさん (ワッチョイ 1a1e-fvqh)
垢版 |
2018/04/25(水) 18:04:12.14ID:EO6K8yEq0
>>222
質問者は
>オブジェクト指向のプログラミングでは
>変数じゃなくてプロパティにアクセスさせるべき
>みたいな事をよく聞くんだけど
で書いて始めてんじゃん。だから、カプセル化の説明した方がまずいいんじゃねぇか??
0225デフォルトの名無しさん (アウアウエー Sa52-PKj8)
垢版 |
2018/04/25(水) 18:09:53.61ID:ClmIY1xNa
>>224
何が「だから」なのかよくわかりませんw

質問は外部に見せるデータをプロパティとして実装すべきかフィールドでもよいのか。
カプセル化(余分なものを外に見せるな)は何も関係ないってw
0226デフォルトの名無しさん (ワッチョイ 1a1e-fvqh)
垢版 |
2018/04/25(水) 18:14:14.76ID:EO6K8yEq0
>>224
>オブジェクト指向のプログラミングでは
>変数じゃなくてプロパティにアクセスさせるべき
>みたいな事をよく聞くんだけど
を質問者が引き合いに出した以上、質問者はここからはしっかりわかってなくて、色々ごちゃ混ぜになってると
思われる。だから、そっから説明しなきゃ、おそらく習得できない。
0227デフォルトの名無しさん (ワッチョイ 9a98-9jjH)
垢版 |
2018/04/25(水) 18:17:11.69ID:lzwohvOS0
自分はオブジェクト指向じゃない言語をちょっとだけやってたんだけど
そういう言語では、コードの最初の方に
public bool JudgFlag = true
って1行書いて、それにどこからでもアクセスするみたいな感じだと思うんだ
(全部独学だからこれも正解なのか知らんけど)
でも、オブジェクト指向ではこれやったらダメなんだよね?
ってのが知りたい

後、俺マジで初心者だから
質問文で聞きたいことが正確に表現できてる保証ないwすまん
0229デフォルトの名無しさん (アウアウエー Sa52-PKj8)
垢版 |
2018/04/25(水) 18:22:03.13ID:ClmIY1xNa
>>227
別にダメじゃないよw
何度も言うけど、あえてフィールドを使う理由があんまりないだけw

フィールドをプロパティにしたらバグが減らせるとか可読性が上がるとか、
ほとんどの場合そんなことはない
0230212 (ワッチョイ 4e80-c0HJ)
垢版 |
2018/04/25(水) 18:26:03.04ID:eqJJBtIM0
>変数じゃなくてプロパティにアクセスさせるべき

これが異なる会社間での開発を可能にする、
オブジェクト指向の大原則・カプセル化

どの教科書にも書いてある

その理由は、クラス内を開発している会社・人と、
そのクラスを使う会社・人は、異なっているから

オブジェクト指向では、これらの2つの立場からの見方が大切。
君はどちらの開発者ですか?
クラスを作る方・使う方?

クラス内を開発しているのは、過去だから、
そこから未来の、クラスを使う人の動きを予測できない

だから、変数に直接触らせたらダメ。
そこまで予測して、クラス内を作れないから
0231デフォルトの名無しさん (ワッチョイ 9a98-9jjH)
垢版 |
2018/04/25(水) 18:31:21.63ID:lzwohvOS0
>>229
そうなのか・・・
でも、解説サイト見てると
「ダメ」的な雰囲気で書いてあるとこばっかりじゃない?
俺の理解が間違ってるのかもしれないが
俺的には現状>>229に書いてある事が正解に思えちゃうんだよな

俺が1人で小規模な開発してるだけだから
いまいちオブジェクト指向のメリットを感じる場面が少ないのかな
0233デフォルトの名無しさん (ワッチョイ 0bb3-x/V4)
垢版 |
2018/04/25(水) 18:36:43.91ID:Y4/R4Zt40
>俺が1人で小規模な開発してるだけだから
>いまいちオブジェクト指向のメリットを感じる場面が少ないのかな
まあこれだな

>>212の言ってる事は、OOPの「思想」としては間違いなく正しい
但し、単独での小規模開発という状況を前提にするなら「現実的なメリット」は無いに等しい
0234デフォルトの名無しさん (ワッチョイ 1a1e-fvqh)
垢版 |
2018/04/25(水) 18:37:15.31ID:EO6K8yEq0
>>227
うん。君のケースだとダメだね。それだと、クラスの内部状態JudgFlagが誰でも自由に書き換えられちゃう。
だから、まずは君は基本、>>220のようなC#とか言語関係ない一般的なカプセル化について勉強しよう。

で、君のケースだと自分で書いてるが
>・引数付きのコンストラクタを使って、フラグの状態をインスタンス化
>・そのフラグのプロパティはgetのみ設定
ってやるか、
getプロパティ書くの嫌なら>>215が書いたようにC#にはreadonlyフィールドというのがあるのでそれで代用できる。
0235デフォルトの名無しさん (ワッチョイ 4703-AlOi)
垢版 |
2018/04/25(水) 18:47:02.51ID:yqUO4I2d0
おまえら変数は公開しちゃだめだけど、プロパティやgetter/setterなら公開してもいいって思っとるやろw
0236デフォルトの名無しさん (アウアウエー Sa52-PKj8)
垢版 |
2018/04/25(水) 18:48:12.94ID:ClmIY1xNa
>>231
どこの世界でも教条的(思い込みが激しいともいう)人はいるからねw

外部から取得/設定してもらう必要がある値をフィールドではなくプロパティにしたからって
ヒューマンエラーを減らす効果なんかないのは事実

ただ機能がより少ないフィールドをあえて使うことないでしょってだけの話

オブジェクトの公開するデータは必ずしもいつも変数に入っているわけではなく、
何らかの処理の結果を返す場合もあって、その場合はプロパティになるから、
だったら全部プロパティの方が統一感があるという考え方はあるかもしれない
0238デフォルトの名無しさん (ワッチョイ 9a98-9jjH)
垢版 |
2018/04/25(水) 19:04:09.02ID:lzwohvOS0
まとめると
「1人で小規模なコード書いてるだけなら
public bool JudgFlag = true
を書き換えたらダメなことぐらい自明だから、フィールドに1行書いて終わりでいい
若干雑だけど楽」
って考え方と
「いや、自分で決めたルールを自分で忘れることもあるから
ちゃんとプロパティにして触れない様にすべき
多少面倒でもコストを払うメリットがある」
って考えの対立なのかな

get;set;とか全く意味がわからなかった頃の嫌なイメージのせいで
プロパティを書く事が、「面倒・難しい」って体が拒否反応しちゃうんだよね
自動プロパティとか実装されてる今の時代に
何言ってんだって笑われそうだけど

まあ、でも色々モヤモヤしてた所がスッキリしました
ありがとう
0241デフォルトの名無しさん (ワッチョイ 3bc3-9jjH)
垢版 |
2018/04/25(水) 20:30:49.45ID:XWOG1WtT0
フォーム間のデータ受け渡しのやり方について教えてください

プログラムを起動して、最初にForm1でパラメータなどを設定、次にForm2で設定した
パラメータを元にデータを編集したいとします
(Form1で編集済みのデータをForm2に表示する、でもいいです)

このときにデータを受け渡すのは、program.cs で Application.Run(new Form1()); と
呼び出す前に

1. Form2 のインスタンスを作っておいて、それを Form1 の引数として与えてやる
2. 必要なデータのインスタンスを Main() 内に用意しておいて、そのインスタンスを
 Form1 と Form2 のそれぞれに送る
3. どっちもダメで他の方法がある

のどれが良いのでしょうか。
Form1 の中で Form2 のインスタンスを作成して、Form2 に送るという方法も考えましたが、
そうすると Form1 が不要になったときに Dispose() すると Form2 も落ちてしまいます。
0242デフォルトの名無しさん (ワッチョイ 5bd2-8E8L)
垢版 |
2018/04/25(水) 20:44:39.30ID:3+niHUT+0
【マイトLーヤとPS4】 FFとDQの最新作、VR開発は危険、プレーヤーの日常感覚を損なうおそれ
http://rosie.5ch.net/test/read.cgi/liveplus/1524621704/l50
0246デフォルトの名無しさん (ワッチョイ 3bc3-9jjH)
垢版 |
2018/04/25(水) 21:17:11.34ID:XWOG1WtT0
>>244
ありがとうございます
この場合、もう二度と Form1 を使わないという状況であれば、Form2 の ShowDialog を
呼び出す前に this.Hide(); で隠しておいて、戻ってきたら this.Dispose(); でしょうか
Hide() だけで処理を抜けるコードを書き忘れて、いつまでもプログラムが残り続けるバグを
やったので、二度と戻ってこないフォームは Dispose() したいのです
0248デフォルトの名無しさん (アウアウエー Sa52-PKj8)
垢版 |
2018/04/25(水) 21:20:04.33ID:ClmIY1xNa
>>243
頭悪そうだけど、単にバッキングフィールドの値をそのまま返すのではないケースを
「何らかの処理の結果を返す」と言っている。

処理 = 高価な処理ではない。
重かろうが単なる足し算だろうが処理は処理だ
0253デフォルトの名無しさん (アウアウカー Sa43-AqIk)
垢版 |
2018/04/25(水) 23:38:15.43ID:8cfef6Y0a
もう親フォーム作れば?
0255デフォルトの名無しさん (ワントンキン MMd3-qfDI)
垢版 |
2018/04/26(木) 15:37:00.65ID:s8t3AsxEM
.netで簡単に実現できる機能(メールや圧縮、画像処理等)をネイティブCのアプリで利用したいです。VC++6.0の(C++ではなく)C言語で作るコンソールアプリでです。
C#で作っでdllを作って、C++のdllでそれをコールする関数を公開すれば実現可能ですが、もっといいやり方ないでしょうか?
0260241 (ワッチョイ 11c3-luqG)
垢版 |
2018/04/26(木) 20:39:08.13ID:8i3JVbEw0
皆様ありがとうございました
決まりきった定番の書き方はない、と理解すれば良さそうですね

自分で色々試してみます
0261デフォルトの名無しさん (ワッチョイ 11c3-luqG)
垢版 |
2018/04/26(木) 21:03:55.12ID:8i3JVbEw0
今度はインデクサについて教えてください

https://ideone.com/TlRwJS

例として上記のようなコードを書いてみました
これで、インデクサを使って例えば anml["whale"] とすれば1が返ってくるような、
そういうものを作りたいと思います
(classified, lifeの各プロパティはユニークではなく、specificのみユニークとします)

本を紐解きながら書こうとしたのですが、animalsクラスの中ではリストになっていないので
書く場所はなさそうです。でもMainメソッドでは利用したい側なので、ここに実装することも
できない気がします。

多分インデクサの考え方そのものがわかっていません。どなたか教えていただけると
嬉しいです。
0264デフォルトの名無しさん (ワッチョイ 19e3-Im5u)
垢版 |
2018/04/27(金) 03:52:18.55ID:3sBZO5RI0
インデクサてのは自作のクラスにつけるプロパティみたいなものだから、List<animals>を内蔵するクラス作って
public int this[string p]{
get{ /* ここに検索して結果を返すコード書く */ }
}
でおkなんじゃねか?知らんけど。
0265デフォルトの名無しさん (ワッチョイ 11c3-luqG)
垢版 |
2018/04/27(金) 07:42:26.78ID:vWqu6ayt0
>>262
すいません、理解のレベルが低いので、具体的にどう実装すればよいのかわかりませんでした
var anml = new Dictionary<animals, string>;
としてディクショナリは実装できたとして、要素追加の際 Add メソッドをどう書くのか、理解が
追いついていないようです

>>263
この書き方で、求めている操作は実現できそうです
ラムダ式の理解が怪しいのは勉強するとして、毎回これを書くと面倒&間違えそうなのですが、
これは「十分に簡潔な書き方」なのか、それとも「メソッド等でさらに簡潔に書ける」のか、どちら
でしょうか。

>>264
この場合、各プロパティにアクセスする際は anml[i].specific とかではなくて anml(i, specific)等
メソッドを介してアクセスすることになるのでしょうか?
0269デフォルトの名無しさん (ワッチョイ 93e3-cUH7)
垢版 |
2018/04/27(金) 23:13:48.06ID:9YiDAi7f0
Index番号が欲しいなら>>263で十分じゃないか?
見つからなかったとき例外吐くらしいから気をつけろい
0272デフォルトの名無しさん (ワッチョイ b3eb-cUH7)
垢版 |
2018/04/28(土) 01:50:20.46ID:fiFvLr6Y0
XAMLファイルからボタンを削除した場合、CSコードの方に呼び出されることのないコールバック関数の宣言が残ってしまます
こういうのを効率よく削除する方法ってないのでしょうか?
0276デフォルトの名無しさん (ワッチョイ 112d-c97c)
垢版 |
2018/04/28(土) 12:46:33.34ID:5pWODy2i0
ここでいいのかわかりませんが、質問させてください。
C#でフレームワーク ASP.Net MVCで作っています。

テーブルのフォームをPOSTしたいのですが、
動的に作成した行をどのようにサーバー側で受け取ればよいのかわかりません。

<td>
<input class="form-control" id="no1" name="no2" type="text" value="" />
</td>
<td>
<input class="form-control" id="no2" name="no2" type="text" value="" />
</td>


このように、複数行があって、noの後ろの数値は、行を追加したら増えるように
javascriptで制御しています。

サーバー側の処理として、引数を
(string no1, string no2, ・・・)と列挙してすべて書けば、
POSTデータを受け取れることは確認済みです。

ただ、ユーザーの操作で行を何行追加するかもわからず、あらかじめ想定する
最大数の引数を列挙するのも現実的ではありません。
すべてのフォームデータを一挙に受け取って、
サーバー内部のロジックで処理する方法はないでしょうか。
0280デフォルトの名無しさん (ワッチョイ 419f-YWv5)
垢版 |
2018/04/28(土) 22:36:40.95ID:vp8gWtwG0
Entity FrameworkでDBへのselectとかのリトライしたい場合ってどのようにすべきでしょうか
一時的なエラーだったりしたらもう一回トライとかしたいのです
例外全キャッチするのも無駄なのかなぁと思いまして
0289デフォルトの名無しさん (ワッチョイ bf9e-DJjQ)
垢版 |
2018/05/03(木) 13:26:57.92ID:YEWKmWCr0
winformの左辺や上辺をドラッグするとフォームのサイズが変わらずにフォームが移動してしまいますが
サイズを変更するように設定するプロパティなどはありますでしょうか
コードを書く必要がありますか?
0297デフォルトの名無しさん (ワッチョイ 53b3-EG9I)
垢版 |
2018/05/03(木) 16:06:28.64ID:+UDEH62l0
仮想マシンに焦点を絞るなら、ハードウェアの差異を吸収する為では
(.netはJavaVMほどあちこちに移植されてないというだけで)

ILに関して言えば、複数の言語(C#、VB.net、F#、他)を共通のフレームワーク上で動かせる様にする為
0299デフォルトの名無しさん (ワッチョイ 53b3-EG9I)
垢版 |
2018/05/03(木) 16:19:16.65ID:+UDEH62l0
>>298
不可能だろう
収斂進化により表面上似た様な機能を搭載する事はあっても、内部構造は特許なり権利なり絡んで来るから同じに出来ないし
JavaScript+CSS3ですらブラウザベンダ間で足並み揃えられないのに、言語の統一なんて出来る訳が無い
0304デフォルトの名無しさん (ワッチョイ bb65-f8tT)
垢版 |
2018/05/03(木) 19:15:49.37ID:OyWVOyw+0
>>302
コンパイラ開発者はとりあえずLLVM-IRに変換すればいいし最終段で機械語に変換するか直接実行するか他の言語のコードに変換するかは自由
というか最初と最後だけ作ればいいわけだから寧ろLLVM-IRが中心
■ このスレッドは過去ログ倉庫に格納されています

ニューススポーツなんでも実況