ふらっとVisual C#,C♯,C#(初心者用)
このスレッドは
「どんなにくだらないC#プログラミングやVisual C#の使い方に関する質問でも誰かが優しくレスをしてくれるスレッド」です。
ほかのスレッドでは恐ろしくて書き込めないような低レベル、もしくは質問者自身なんだか意味がよく分からない質問、
ググろうにもキーワードが分からない場合など、勇気をもって書き込んでください。
内容に応じて、他スレ・他板へ行くことを勧められる、あるいは誘導される場合がありますがご了承下さい。
なお、テンプレ2行目が読めない回答者は邪魔なので後述のC#相談室に移動して下さい。
>>980を踏んだ人は新スレを建てて下さい。
>>980が無理な場合、話し合って新スレを建てる人を決めて下さい。
関連スレ
ふらっとC#,C♯,C#(初心者用) Part91
http://toro.2ch.net/test/read.cgi/tech/1335089085/
C#, C♯, C#相談室 Part71
http://toro.2ch.net/test/read.cgi/tech/1332575004/
こんな感じでソフトウェア板に立てたらどうかな
探検
ふらっとC#,C♯,C#(初心者用) Part92
■ このスレッドは過去ログ倉庫に格納されています
2012/04/26(木) 21:32:32.95ID:RzRn9VkL0
2名無しさん@お腹いっぱい。
2012/04/26(木) 21:41:40.86ID:O5VqGHkR0 ─ここは、プログラム板における同名スレにおいて、
IDが付与されないがため生じる定期的な荒れ進行を度々経験し、
疲れてしまった同スレの住人が、透明あぼーんの活用でまったりと
本来のスレの目的を果たし続けるために設けられた、
一種の避難所です。
IDが付与されないがため生じる定期的な荒れ進行を度々経験し、
疲れてしまった同スレの住人が、透明あぼーんの活用でまったりと
本来のスレの目的を果たし続けるために設けられた、
一種の避難所です。
2012/04/26(木) 21:48:33.25ID:k6WQuHfJ0
ム板開いたのかと思ったわ
避難所part1で良かったんじゃね?
避難所part1で良かったんじゃね?
4名無しさん@お腹いっぱい。
2012/04/26(木) 21:56:27.84ID:O5VqGHkR02012/04/26(木) 22:02:59.89ID:4B8P7eLr0
荒れ気味の板がIDなしだと大抵ろくな事にならないのは分かるが、この板でする話なのか
6名無しさん@お腹いっぱい。
2012/04/26(木) 22:08:52.32ID:O5VqGHkR0 ム板から逃れる先として、ソフトウェア板以外に何かあるかな?
2012/04/26(木) 22:45:50.27ID:ztuW7M4rO
ム板でやれ
8名無しさん@お腹いっぱい。
2012/04/26(木) 22:49:38.04ID:O5VqGHkR02012/04/26(木) 22:55:41.61ID:bO5QxnlI0
荒れてる時はこっちに誘導したらいいんじゃないかな
10名無しさん@お腹いっぱい。
2012/04/26(木) 22:57:29.91ID:O5VqGHkR0 まあ、あっちに来た質問を無理にこっちに誘導する気はあんまり無いんだ。
向こうでも書いたけど、あっちのスレが回答不能なレベルに達してるってわけじゃないし。
むしろ、「IDがあった方が議論しやすい」と感じた人間だけが、こっちで議論すれば良いと思ってる。
向こうでも書いたけど、あっちのスレが回答不能なレベルに達してるってわけじゃないし。
むしろ、「IDがあった方が議論しやすい」と感じた人間だけが、こっちで議論すれば良いと思ってる。
11名無しさん@お腹いっぱい。
2012/04/26(木) 23:07:50.71ID:O5VqGHkR0 こっちを擁護しておいてなんだが、これで本スレのテンプレに
こっちのスレを追加すべき/すべきでない議論とか巻き起こるのは嫌だなあ。
テンプレ周りの変更議論はもめるし。
もめるくらいなら追加したくない。
こっちのスレを追加すべき/すべきでない議論とか巻き起こるのは嫌だなあ。
テンプレ周りの変更議論はもめるし。
もめるくらいなら追加したくない。
2012/04/26(木) 23:10:39.92ID:8roaiKjI0
問題は回答者がここにくるかだな
2012/04/26(木) 23:11:12.03ID:bO5QxnlI0
俺が一番回答してるから俺がいれば大概大丈夫だろう
14名無しさん@お腹いっぱい。
2012/04/26(木) 23:17:43.49ID:O5VqGHkR0 >>12
俺も一応回答者。どんくらい回答したかまでは覚えてないけど。
俺も一応回答者。どんくらい回答したかまでは覚えてないけど。
2012/04/26(木) 23:34:02.35ID:8roaiKjI0
じゃあ、ちょっと質問
インターフェイス使うと改変に強いっていうけどプロパティとどう違うの?
プロパティも内部の構造変えても他のクラスに影響がない
影響が出るとしたら、プロパティの型を変更した場合
インターフェイスも引数の型変更したら結局使いものにならないし
改変に強いって説明の仕方おかしくない?
内部の違うクラスを同じようにアクセスできるのを明示するということならわかるけどね
インターフェイス使うと改変に強いっていうけどプロパティとどう違うの?
プロパティも内部の構造変えても他のクラスに影響がない
影響が出るとしたら、プロパティの型を変更した場合
インターフェイスも引数の型変更したら結局使いものにならないし
改変に強いって説明の仕方おかしくない?
内部の違うクラスを同じようにアクセスできるのを明示するということならわかるけどね
2012/04/26(木) 23:43:32.60ID:LlORaYbR0
クラスというのは、実体を作れる型。
インターフェースとしいうのは、実体を作れない型。
インターフェースとしいうのは、実体を作れない型。
17名無しさん@お腹いっぱい。
2012/04/26(木) 23:45:23.62ID:O5VqGHkR0 「改変に強い」のは、インターフェイス自体の改変ではないよ。
改変に強い、って説明自体確かに誤解を招く表現で、
実際は「内部実装を気にしなくて良い」が正解だと思う。
インターフェイスとはちと違うけど、Streamなんかその最たるものじゃない。
Stream自体が何をソースにどうやって実現されているかは気にしなくてよくて、
処理する側はStreamクラスのオブジェクトに対して必要な処理(メッセージ)を要求すればいい。
インターフェイスを定義する、ってのはそれだけのことでしかない。
「Hoge(FileStream stream)」って定義したメソッドより、「Hoge(Stream stream)」って定義されたメソッドの方が、
汎用的に使えるじゃない。
改変に強い、って説明自体確かに誤解を招く表現で、
実際は「内部実装を気にしなくて良い」が正解だと思う。
インターフェイスとはちと違うけど、Streamなんかその最たるものじゃない。
Stream自体が何をソースにどうやって実現されているかは気にしなくてよくて、
処理する側はStreamクラスのオブジェクトに対して必要な処理(メッセージ)を要求すればいい。
インターフェイスを定義する、ってのはそれだけのことでしかない。
「Hoge(FileStream stream)」って定義したメソッドより、「Hoge(Stream stream)」って定義されたメソッドの方が、
汎用的に使えるじゃない。
2012/04/26(木) 23:54:34.76ID:bO5QxnlI0
改変に強いっていうのはどうなんだろうな
個人的には別に強くないと思うが
interfaceごしだと実装クラスを入れ替えられるけど
改変前と改変後の2つの似たようなクラスを両方保持して
interface越しにどっちを使ってるか分からなくするなんて考えただけでゾッとする
一つの具体クラスをただ書き換えるほうがずっといい
だから改変に強いと言うよりは
ライブラリを作る側が使う側に処理を実装してもらう時に使うものだと思うよ
IComparableを実装してもらってSortメソッドで使う比較関数に利用したり
まあC#3.0からラムダ式が使えるからそういう用途はもうほとんどお役御免だけどね
interface自体ほとんどお役御免といっていいと思う
ライブラリに残ってれば使うけど自作する意味は殆ど無い
個人的には別に強くないと思うが
interfaceごしだと実装クラスを入れ替えられるけど
改変前と改変後の2つの似たようなクラスを両方保持して
interface越しにどっちを使ってるか分からなくするなんて考えただけでゾッとする
一つの具体クラスをただ書き換えるほうがずっといい
だから改変に強いと言うよりは
ライブラリを作る側が使う側に処理を実装してもらう時に使うものだと思うよ
IComparableを実装してもらってSortメソッドで使う比較関数に利用したり
まあC#3.0からラムダ式が使えるからそういう用途はもうほとんどお役御免だけどね
interface自体ほとんどお役御免といっていいと思う
ライブラリに残ってれば使うけど自作する意味は殆ど無い
2012/04/26(木) 23:57:08.75ID:65sWvc4W0
ム板って取扱いと人種的に宗教戦争余裕なのに未だにIDないのか
2012/04/26(木) 23:57:13.32ID:LlORaYbR0
インターフェースは、お役御免には、ならないと思うがな。
2012/04/27(金) 00:04:32.27ID:Op9+MQob0
interface I{ int Hoge(); string Hoge2(); }
こんなのを作るより
class C{ public Action Hoge; public Func<string> Hoge2; } こんなのを作って
new C{ Hoge = () =>{ ... }, Hoge2 = () => "hogehoge" }
こうしたほうが早いしわかりやすいし個別に設定できて汎用性も上だから
もうinterfaceを作る意味は無いはず
こんなのを作るより
class C{ public Action Hoge; public Func<string> Hoge2; } こんなのを作って
new C{ Hoge = () =>{ ... }, Hoge2 = () => "hogehoge" }
こうしたほうが早いしわかりやすいし個別に設定できて汎用性も上だから
もうinterfaceを作る意味は無いはず
2012/04/27(金) 00:04:33.82ID:M9E7Y8z10
例えば、UnityやXNAやDxLibなどを同じように扱えるようにするにはどうするべき?
ゲーム本体部分とライブラリとの丁度境界線上にあるクラスはどのように定義すべき?
ゲーム本体部分とライブラリとの丁度境界線上にあるクラスはどのように定義すべき?
23名無しさん@お腹いっぱい。
2012/04/27(金) 00:06:06.52ID:adJRSpDB0 お役ご免ってのは言い過ぎでしょう。後々機能追加が考えられる場合、
その機能追加に耐える様Interfaceを定義するコトなんて、(自分は)ザラにありますよ。
たとえば、画像ファイルに対して順次いろんな処理をするようなソフトを作ったとき、
最初はjpgとbmpしか対応しないでおいて、いずれpngとかtiffもやりたいなあ、と思った場合、
interface ImageProcessor { ... }
class JpegImageProcessor { ... }
class BmpImageProcessor { ... }
なんて。
処理自体が短ければ>>18の言うとおり、ラムダ式で十分なんだけど、
色んな段階を踏む処理の場合、処理自体をクラス化しちゃう方が後々追加し易い。
>2つの似たようなクラスを両方保持して〜一つの具体クラスをただ書き換えるほうがずっといい
っていうような懸念がある場合は、interfaceじゃなくて抽象クラスでやればいいし。
共通部分は抽象クラスで処理して、後々追加したい機能毎に変わりうる部分は具象クラスに任せて抽象メソッドを定義だけしておく、とか。
その機能追加に耐える様Interfaceを定義するコトなんて、(自分は)ザラにありますよ。
たとえば、画像ファイルに対して順次いろんな処理をするようなソフトを作ったとき、
最初はjpgとbmpしか対応しないでおいて、いずれpngとかtiffもやりたいなあ、と思った場合、
interface ImageProcessor { ... }
class JpegImageProcessor { ... }
class BmpImageProcessor { ... }
なんて。
処理自体が短ければ>>18の言うとおり、ラムダ式で十分なんだけど、
色んな段階を踏む処理の場合、処理自体をクラス化しちゃう方が後々追加し易い。
>2つの似たようなクラスを両方保持して〜一つの具体クラスをただ書き換えるほうがずっといい
っていうような懸念がある場合は、interfaceじゃなくて抽象クラスでやればいいし。
共通部分は抽象クラスで処理して、後々追加したい機能毎に変わりうる部分は具象クラスに任せて抽象メソッドを定義だけしておく、とか。
2012/04/27(金) 00:10:18.02ID:M9E7Y8z10
>>23
もっともですねぇ
もっともですねぇ
2012/04/27(金) 00:13:36.43ID:Op9+MQob0
>>23
これだと違いはファイル読み込んでビットマップ作る
ビットマップをファイルに書き出す
ところが違うだけじゃないの
具体的なクラス一個作って
public Image(Pixel[][] bitmap)
こんなコンストラクタにして
new Image(JpegLoader.Load(file))
new Image(BmpLoader.Load(file))
書きだす時は
JpegWriter.Write(image.Pixels);
BmpWriter.Write(image.Pixels);
こんなもんでよくね
これだと違いはファイル読み込んでビットマップ作る
ビットマップをファイルに書き出す
ところが違うだけじゃないの
具体的なクラス一個作って
public Image(Pixel[][] bitmap)
こんなコンストラクタにして
new Image(JpegLoader.Load(file))
new Image(BmpLoader.Load(file))
書きだす時は
JpegWriter.Write(image.Pixels);
BmpWriter.Write(image.Pixels);
こんなもんでよくね
26名無しさん@お腹いっぱい。
2012/04/27(金) 00:15:00.08ID:adJRSpDB0 まあ、オブジェクト指向を完全に理解して常に完璧な形で実現出来てる、
なんて境地には到底達せないと思うので、今の自分の実装が正しいとも言い切れないんですけど。
Rxとか見てると、ラムダ式で全部・・・なんてのも決して非現実的ではないと感じるし、
「一つ一つの処理は短く」という基礎的なことを突き詰めていけば、
そういうこともきっとできるんだろうなあ、とは思う。
ただ、それでもinterface自体が無くなる可能性は低いだろうな。
俺は逆に、Rxが駆逐しようとしているのは開発者がclassを定義する、
という行為じゃないかと感じる。
なんて境地には到底達せないと思うので、今の自分の実装が正しいとも言い切れないんですけど。
Rxとか見てると、ラムダ式で全部・・・なんてのも決して非現実的ではないと感じるし、
「一つ一つの処理は短く」という基礎的なことを突き詰めていけば、
そういうこともきっとできるんだろうなあ、とは思う。
ただ、それでもinterface自体が無くなる可能性は低いだろうな。
俺は逆に、Rxが駆逐しようとしているのは開発者がclassを定義する、
という行為じゃないかと感じる。
2012/04/27(金) 00:17:24.64ID:nbH+qoH50
変数名につける英単語がわからなくて悩みまくる
28名無しさん@お腹いっぱい。
2012/04/27(金) 00:17:43.59ID:adJRSpDB0 >>25
それだと、あっちこっちで処理対象がJpegなのかBmpなのか判定しなきゃいけなくなるでしょう。
処理が読み込みと保存だけでいいなら、2箇所ぽっきりだしそれもありだと思いますけど。
Classとインターフェース作っちゃえば、インターフェースを介して処理してる本体側は大きな変更することなく、
一番アタマで対象の判定だけやって、クラスの実態をnewした後は同じ処理を続けるだけ、で行ける。
それだと、あっちこっちで処理対象がJpegなのかBmpなのか判定しなきゃいけなくなるでしょう。
処理が読み込みと保存だけでいいなら、2箇所ぽっきりだしそれもありだと思いますけど。
Classとインターフェース作っちゃえば、インターフェースを介して処理してる本体側は大きな変更することなく、
一番アタマで対象の判定だけやって、クラスの実態をnewした後は同じ処理を続けるだけ、で行ける。
29名無しさん@お腹いっぱい。
2012/04/27(金) 00:35:15.50ID:adJRSpDB0 極端に汎化するなら、こういうインターフェースを作るかな
interface ImageProcessor {
/// <summary>指定されたファイルがサポートされているかどうかを判定します。</summary>
bool Supported(string fileName);
/// <summary>指定されたファイルを読み込んで、オブジェクトを初期化します。</summary>
void Load(string fileName);
〜
}
本体側は
AssemblyからImageProcessorを継承してるクラスを全部引っ張ってきておいて、
private static readonl List<T> processors;
private ImageProcessor processor=null;
private Load (string fileName){
foreach (var p in processors){
if (p.Supported(fileName)){
processor=p;
break;
}
}
if (processor==null) throw new NotSupportedException(string.Format("{0}は未対応のファイル形式です", fileName));
processor.Load(fileName);
}
みたいな。こうすれば、処理本体側は変更なしで対応形式の追加が出来るだろうし。
interface ImageProcessor {
/// <summary>指定されたファイルがサポートされているかどうかを判定します。</summary>
bool Supported(string fileName);
/// <summary>指定されたファイルを読み込んで、オブジェクトを初期化します。</summary>
void Load(string fileName);
〜
}
本体側は
AssemblyからImageProcessorを継承してるクラスを全部引っ張ってきておいて、
private static readonl List<T> processors;
private ImageProcessor processor=null;
private Load (string fileName){
foreach (var p in processors){
if (p.Supported(fileName)){
processor=p;
break;
}
}
if (processor==null) throw new NotSupportedException(string.Format("{0}は未対応のファイル形式です", fileName));
processor.Load(fileName);
}
みたいな。こうすれば、処理本体側は変更なしで対応形式の追加が出来るだろうし。
2012/04/27(金) 00:35:54.03ID:Op9+MQob0
まあ別にいいんだけどねこれでも
public Image(Func<Pixel[][]> reader, Action<Pixel[][]> writer)
public void Load()
{
Pixels = reader();
}
public void Save()
{
writer(Pixels);
}
これでinterfaceと大体同等だけど最初に入れてから入れ替えができなくて無意味に汎用性が下がるし
呼び出し側もメソッドの中で何が起こるのか分からなくなってソースがわかりにくくなるんで
必要がなければ避けるべき形だよね
public void Save(Action<Pixel[][]> writer)
{
...
}
処理の汎用化が必要でも、こんな風にライブラリ側だって必要なときに必要な物だけ渡してくれた方がわかりやすいし使う側も使いやすい
interfaceを使うと呼び出す場所(たとえばSaveを実際に呼び出すところ)とそれが定義されてる場所(Save処理を実装したクラス)が離れちゃうからわかりにくくなる
なにより「interfaceにそのメソッドが必要かどうか」という難しい判断をする必要がなくなるから問題がすごく簡単になる
public Image(Func<Pixel[][]> reader, Action<Pixel[][]> writer)
public void Load()
{
Pixels = reader();
}
public void Save()
{
writer(Pixels);
}
これでinterfaceと大体同等だけど最初に入れてから入れ替えができなくて無意味に汎用性が下がるし
呼び出し側もメソッドの中で何が起こるのか分からなくなってソースがわかりにくくなるんで
必要がなければ避けるべき形だよね
public void Save(Action<Pixel[][]> writer)
{
...
}
処理の汎用化が必要でも、こんな風にライブラリ側だって必要なときに必要な物だけ渡してくれた方がわかりやすいし使う側も使いやすい
interfaceを使うと呼び出す場所(たとえばSaveを実際に呼び出すところ)とそれが定義されてる場所(Save処理を実装したクラス)が離れちゃうからわかりにくくなる
なにより「interfaceにそのメソッドが必要かどうか」という難しい判断をする必要がなくなるから問題がすごく簡単になる
31名無しさん@お腹いっぱい。
2012/04/27(金) 00:40:53.37ID:adJRSpDB0 まあ、やりたいことにあった方を選べば良いんじゃないかな。
実際、その二つの方法を提供しているライブラリも多いよ。
俺もそういうやり方することあるし。処理が端的に済む場合なんかは特に。
で、じゃあどっちかしか使わないか、っていうと、時と場合に依った。
どっちでも実現できる場合もあれば、どっちかじゃないとどうにもならん、とか
一方のやり方だとやたら遠回りなやり方になる、とか色々あったさ。
ライブラリを公開する、って観点で言うと、>>30みたいなやり方の方が使いやすいだろうな。多分。
実際、interfaceを定義する、っていう手間はあれで結構大変だし、ホントやりやすい方でやればいいと思うよ。
実際、その二つの方法を提供しているライブラリも多いよ。
俺もそういうやり方することあるし。処理が端的に済む場合なんかは特に。
で、じゃあどっちかしか使わないか、っていうと、時と場合に依った。
どっちでも実現できる場合もあれば、どっちかじゃないとどうにもならん、とか
一方のやり方だとやたら遠回りなやり方になる、とか色々あったさ。
ライブラリを公開する、って観点で言うと、>>30みたいなやり方の方が使いやすいだろうな。多分。
実際、interfaceを定義する、っていう手間はあれで結構大変だし、ホントやりやすい方でやればいいと思うよ。
32名無しさん@お腹いっぱい。
2012/04/27(金) 01:33:59.48ID:psMmyTva0 ただ、制限がクリアできるならabstractの方が便利だけどね
interfaceで同一視したいクラスって、共通の処理がある程度有るし
interfaceで同一視したいクラスって、共通の処理がある程度有るし
2012/04/27(金) 01:37:13.24ID:3wpgqpvv0
( ・ω・)y─┛〜〜
34名無しさん@お腹いっぱい。
2012/04/27(金) 02:38:49.18ID:adJRSpDB0 まあ実際、interfaceとabstract classどっちが多いかっつったら、
今まで書いてきたような目的下だと、abstract classの方が多いな。
今まで書いてきたような目的下だと、abstract classの方が多いな。
2012/04/27(金) 10:42:30.93ID:cReG2fZ90
36名無しさん@お腹いっぱい。
2012/04/28(土) 18:00:55.53ID:dHnGlI/10 落ちた?
2012/04/28(土) 21:16:46.38ID:uBDtGHBV0
そんな早くdat落ちするのかこの板
38名無しさん@お腹いっぱい。
2012/04/28(土) 22:23:13.82ID:qRaW9tis0 しないね。サーセン誤爆だ。
2012/04/28(土) 22:24:15.68ID:uBDtGHBV0
基本プログラミングっていうのは自分でライブラリを書いて自分で使うことの繰り返しだからな
汎用性が高く使いやすいライブラリを書いていくと良いプログラムになる
使いにくく汎用性が低いライブラリを作るとソースがなんだかわからなくなったり仕様変更できなくなったりする
汎用性が高く使いやすいライブラリを書いていくと良いプログラムになる
使いにくく汎用性が低いライブラリを作るとソースがなんだかわからなくなったり仕様変更できなくなったりする
40名無しさん@お腹いっぱい。
2012/04/28(土) 22:33:08.75ID:qRaW9tis0 最初はそれも上手く行かなくて辛いけどな。試行錯誤を繰り返していく内に、
どうすれば汎用性が上がるかが分かってきて楽しい。
どうすれば汎用性が上がるかが分かってきて楽しい。
2012/04/29(日) 09:55:22.97ID:LSFzkJi50
さんざ苦労してライブラリ作っても、意外と使わなかったりするな
使わずに温存してるうちに陳腐化したり、もっといいライブラリが登場したり…
使わずに温存してるうちに陳腐化したり、もっといいライブラリが登場したり…
2012/04/29(日) 13:38:00.37ID:91lLWKe20
今必要じゃないライブラリ作ってもしょうがないよな
テストもろくに出来ないだろうし
テストもろくに出来ないだろうし
2012/04/29(日) 19:13:44.11ID:hNVwJi4l0
それあるよな。必要な物書いていったらいつのまにかライブラリになってたってのが理想的。
2012/04/29(日) 19:16:01.56ID:15BXN5vX0
もはやライブラリを作るほうが本来の目的になってる時、あるよねw
2012/04/29(日) 19:20:20.22ID:TJFFSLOz0
作りたいツールを思いつく→ツールに必要なパーツを作る
→そこで満足する、または飽きる
→そこで満足する、または飽きる
2012/04/29(日) 19:24:44.61ID:DeCDbekJ0
そこが楽しさだからなぁ
完成が見えた時点でやる気が無くなる
完成が見えた時点でやる気が無くなる
2012/04/29(日) 19:45:24.02ID:91lLWKe20
デバッグが一番大変だわ
コード書いてる時は楽しいんだけど
バグを出すために色々やってみるとかキツい
自分が使うツールじゃなかったらまず無理
コード書いてる時は楽しいんだけど
バグを出すために色々やってみるとかキツい
自分が使うツールじゃなかったらまず無理
48名無しさん@お腹いっぱい。
2012/04/29(日) 21:39:37.48ID:5gSo7RFr0 >>44-47
よう、おれ
よう、おれ
2012/04/29(日) 21:42:49.73ID:91lLWKe20
前スレ埋まったw
ここに移動すんのか?
ここに移動すんのか?
2012/04/29(日) 21:45:58.44ID:91lLWKe20
おかしい・・・みんなどこに行ったんだ
2012/04/29(日) 21:47:48.20ID:91lLWKe20
まあム板には相談室があるからふらっとがこっちにあっても
最悪質問者が誰もここまでこれなくて潰れても大して問題はないんだよな
最悪質問者が誰もここまでこれなくて潰れても大して問題はないんだよな
52名無しさん@お腹いっぱい。
2012/04/29(日) 21:47:52.52ID:5gSo7RFr0 じゃちっと立てれるか試してくるわ
53名無しさん@お腹いっぱい。
2012/04/29(日) 21:51:38.15ID:5gSo7RFr0 あっ・・・ソフトウェア板様に、って貼られたテンプレをつかっちまった
スレタイ・・・すまない。
スレタイ・・・すまない。
54名無しさん@お腹いっぱい。
2012/04/29(日) 21:52:29.22ID:5gSo7RFr0 ふらっとVisual C#,C♯,C#(初心者用) Part92
http://toro.2ch.net/test/read.cgi/tech/1335703825/
http://toro.2ch.net/test/read.cgi/tech/1335703825/
2012/04/29(日) 22:04:03.98ID:91lLWKe20
なんだかよくわからないことになってきたな・・・
どっちに来ても質問が来たら答えるだけだけど
どっちに来ても質問が来たら答えるだけだけど
2012/04/29(日) 22:09:46.37ID:sYMu1fUT0
VC#のデザインでコピーして貼り付けた時、Nameプロパティをコピー元に似せる方法ってないですか?
input_data_Box1ならinput_data_Box2とかinput_data_Box1(1)とかになってほしいです・・・
input_data_Box1ならinput_data_Box2とかinput_data_Box1(1)とかになってほしいです・・・
2012/04/29(日) 22:18:35.45ID:91lLWKe20
継承するかユーザーコントロールにしてInput_data_Boxっていうクラス名にしたらいいんじゃないの
2012/04/29(日) 22:27:06.67ID:sYMu1fUT0
ありがとうございます
特に付加する機能のない継承をやるくらいしかないんですね
特に付加する機能のない継承をやるくらいしかないんですね
2012/04/29(日) 22:29:44.31ID:sYMu1fUT0
多少手間だからユーザーコントロール作るか・・・!
2012/04/29(日) 22:32:06.71ID:91lLWKe20
俺はなにもかもユーザーコントロールにしてる
1クラスに配置するコントロールは4つぐらいまで
超えたらユーザーコントロールにまとめる
1クラスに配置するコントロールは4つぐらいまで
超えたらユーザーコントロールにまとめる
2012/04/29(日) 22:36:51.13ID:DeCDbekJ0
ユーザーコントロールって再利用性が全くないよね
2012/04/29(日) 22:41:21.18ID:91lLWKe20
>>61
んなことないでしょ
よく出てくる複数のコントロールの組もあるし(追加、削除ボタンの付いたリストとか)
WinFormは継承しなくても基本全部いじれるようになってるから
単一のコントロールでもDock.Fillしてユーザーコントロールのなかで機能追加したりも出来るし
んなことないでしょ
よく出てくる複数のコントロールの組もあるし(追加、削除ボタンの付いたリストとか)
WinFormは継承しなくても基本全部いじれるようになってるから
単一のコントロールでもDock.Fillしてユーザーコントロールのなかで機能追加したりも出来るし
2012/04/29(日) 22:48:34.11ID:15BXN5vX0
>>62
俺は、コントロールのプロパティをバインドさせたりすることがよくあるから、
INotifyPropertyChangedインターフェースを実装したUserControlの派生クラスを作ってる。
他にも共通機能とかをまとめておけば、いちいち実装し直す必要ないし、便利。
俺は、コントロールのプロパティをバインドさせたりすることがよくあるから、
INotifyPropertyChangedインターフェースを実装したUserControlの派生クラスを作ってる。
他にも共通機能とかをまとめておけば、いちいち実装し直す必要ないし、便利。
64名無しさん@お腹いっぱい。
2012/04/29(日) 22:53:51.89ID:5gSo7RFr065名無しさん@お腹いっぱい。
2012/04/29(日) 22:54:42.98ID:5gSo7RFr0 ×パネル
○コンテナ
○コンテナ
2012/04/30(月) 00:30:14.37ID:ItxvOLfT0
荒らしの人は相談室に行ったみたいだな
■ このスレッドは過去ログ倉庫に格納されています
ニュース
- 「もうキモくてキモくて…」29歳女性が語る“おぢアタック”の実態。「俺ならイケるかも」年下女性を狙う勘違い中年男性には共通点が [Hitzeschleier★]
- テレビ朝日 本社から男性が転落し死亡。関連会社社員か 当たった通行人が左肩軽傷 [阿弥陀ヶ峰★]
- 中国軍機がレーダー照射 小泉防衛大臣の説明に「矛盾している」中国外務省報道官が批判 [♪♪♪★]
- テレビ朝日本社から20~30代の関連会社社員とみられる男性が転落し死亡 六本木けやき坂通りの通行人にはけが人なし [少考さん★]
- 「これいいじゃん!!!」 セブン-イレブンの1620円で買える“1人用クリスマスケーキ”🎂に注目殺到「天才すぎる」 [パンナ・コッタ★]
- 高市早苗首相が天理教系企業に“巨額発注” 総額5000万円 本人は「政治団体の活動に必要な支出」と回答 ★2 [Hitzeschleier★]
- 千晴|ちはる
- 【実況】博衣こよりのえちえちスーパーダンガンロンパ7🧪
- 自認トトロなんだが
- 【乞食速報】プロクオリティ ビーフカレー 96食 4262円 [268244553]
- enaga(´・Ǎ・`) ◆99xH8ena32 ってコテわろたwwwwwwwwwww
- 年末のvip芋煮会って何日だっけ?
