C#, C♯, C#相談室 Pa ..
[2ch|▼Menu]
321:デフォルトの名無しさん
09/02/17 23:49:26
おまいらの理想はよくわかった
だが全部スレ違いだ

322:デフォルトの名無しさん
09/02/17 23:55:20
理想ぐらいかたらせてやれよ

323:デフォルトの名無しさん
09/02/18 00:16:57
>>302
>色盲って黄色人種男性の5%
>日本人男女40人のクラスの1人くらいは色盲
ってことは女性に色盲はいないの?

324:デフォルトの名無しさん
09/02/18 00:19:19
>>323
男性に比べて非常に稀なだけでいることはいる

325:デフォルトの名無しさん
09/02/18 00:30:31
>>323
色盲と色弱がいるからな
完全な色盲だともっと低い

そんなの考えなくていいレベル
もちろんあれば便利だが

326:200
09/02/18 00:38:43
>>289
素人用のツールはそうかもね
>>290
ありがとう、マジ助かりました

327:デフォルトの名無しさん
09/02/18 00:44:11
URLリンク(www.microsoft.com)

このリンクのMSDN Library for Visual Studio 2005がダウンロードできなくなってるんだけど、
どこに引っ越したか知ってる人いる?
Windwos2000の再インストール後に見つからなくて困ってるのでよろしくお願いします

328:デフォルトの名無しさん
09/02/18 00:48:38
お前ら何で大騒ぎしてんの?

>>323
色覚異常はX染色体で遺伝する。
だからX染色体を1つしか持たない男性(XY)に多く、2つ持ってる女性(XX)に少ない。
500人に1人ぐらいの割合

329:323
09/02/18 01:01:01
>>324-325、>>328
そうなんだ。知らなかった。

  ┏┳┳┓   ハイ      ┏┳┳┓
┏┫┃┃┃   スレ違いは  ┃┃┃┣┓
┃┃┃┃┣┓  ここまで ┏┫┃┃┃┃
┃      ┃┃┏━━┓┃┃      ┃
┃スレ違い ┣┫*・∀・*┣┫. STOP!┃
┗━━┛┗┳━┳┛┗━━┛
            ┏┻┓┃
        ┏━┛  ┣┻┓
        ┗━━┫  ┗━┓
                ┗━━┛

330:デフォルトの名無しさん
09/02/18 01:03:58
素人用のツール(笑)

331:デフォルトの名無しさん
09/02/18 01:04:22
>>327
Visual Studio 2005 は既に販売が終了している製品なので
それに連動して公開停止になったのかも

今は以下が最新版
MSDN Library for Visual Studio 2008 SP1 (2008年12月更新版)

あと、MSDN Subscription に加入すれば過去のバージョンは
一通り入手できるハズ

332:デフォルトの名無しさん
09/02/18 01:05:39
>>328
劣性遺伝なの?

333:デフォルトの名無しさん
09/02/18 01:07:04
伴性劣性遺伝ってやつだな

334:デフォルトの名無しさん
09/02/18 01:08:26
なんで色盲・色弱にそんなにこだわるんだ?

普通に考えて、カスタマイズの余地皆無だったら
誰にとっても使いにくくなる可能性はあるだろ。
ユーザ=制作者のみってのでも無い限り

335:デフォルトの名無しさん
09/02/18 01:17:24
>普通に考えて、カスタマイズの余地皆無だったら
>誰にとっても使いにくくなる可能性はあるだろ。
んなこといったら、あらゆるすべての設定値を備えなければならないじゃん。
毎晩24時にbeep音を鳴らして寝ることを促す設定がないと、
それを必要とする人には使いにくいってーことになる。

そもそも万人向けにオプションの設定項目を多くするということは、
設定項目が多すぎて煩雑になるという点において万人向けでなくなる。

336:デフォルトの名無しさん
09/02/18 01:22:11
>>335
どうせ分かってて言ってんだろ?
アホか

337:デフォルトの名無しさん
09/02/18 01:38:18
韓国語表示がないのはウリナラへの差別ニダ!

338:デフォルトの名無しさん
09/02/18 02:05:00
設定なんて無くても
赤と緑じゃなく赤紫と緑にするだけで解決する問題なのに
なんでそんなに抵抗あるのかね?

339:デフォルトの名無しさん
09/02/18 02:05:54
サイケデリックはプロ用ツールの証ですw

340:デフォルトの名無しさん
09/02/18 02:35:21
>>338
それをする必要があるのかっていう問題じゃないの?

341:デフォルトの名無しさん
09/02/18 02:43:41
もともとの指摘も、色盲の人にとって、ではなくセンスがない色遣いだという点が主だったはず。
おそらく、赤紫と緑にしても、センスのなさそうなデザインであることは変わらないだろうから、
変えるのは無意味だと思う。

342:デフォルトの名無しさん
09/02/18 02:57:51
お前らが超ハイセンスなのは分かったからそろそろ黙って下さいませんかねこのやろう

343:デフォルトの名無しさん
09/02/18 03:00:36
センスとか以前に株とかで儲けやすいようなプログラムを作ってる奴に嫉妬してるだけじゃねえの
うひょひょ

344:デフォルトの名無しさん
09/02/18 03:06:45
おおかた343で図星ってところだろう

345:デフォルトの名無しさん
09/02/18 04:33:34
>>627
このあたりかな
URLリンク(support.microsoft.com)

ファイル以外のストリームには言及がないのでなんともいえないけど
少なくともファイルは特別に意識していて、ファイルから生成した
ストリームについてはそれを破棄するとイメージにアクセスできなくなるのが
仕様みたい

346:345
09/02/18 04:34:50
すみません
>>345は誤爆です

347:デフォルトの名無しさん
09/02/18 07:12:31
>>340
お前が思っているより色盲の人は遥かに多いから必要だ。

348:デフォルトの名無しさん
09/02/18 07:18:48
あほみたいに、いつまで青い議論を続けてるんだ。
単なる証券屋店頭の電光掲示板へのオマージュだろあれは。
俺的には文字の真ん中に切れ目のあるパネルがパタパタ音を立てて
回転するタイプのコントロールが欲しいな。

349:デフォルトの名無しさん
09/02/18 07:26:44
WPFのViewport3Dとストーリーボードアニメーションの出番だな。さあリッチインタフェースを
追求するんだ。

350:デフォルトの名無しさん
09/02/18 07:39:43
注文すると、発注内容書いた手紙が取引所まで3Dで飛んでいって届いたら実際に発注されるってどうよ。

351:デフォルトの名無しさん
09/02/18 10:58:31
>>348
俺も欲しい・・・


352:デフォルトの名無しさん
09/02/18 13:30:06
>>350
間違えて疑似嫁のデータを送ってしまうわけですね、わかります。

353:デフォルトの名無しさん
09/02/18 13:33:01
デシリアライズされるときコンストラク呼び出されないけれど同じようにユーザーコードからコンストラク呼び出しなしで生成すること可能?

354:デフォルトの名無しさん
09/02/18 13:35:43
>>353
エスパーしてみるけど
デシリアライズされた時点でオブジェクトのインスタンスは生成されてるんじゃないのか?

355:デフォルトの名無しさん
09/02/18 15:29:45
すまん、説明が悪かった。インスタンスは生成されるんだがコンストラクタは呼び出されないてない。
同じようにコンストラクタ通さずインスタンスだけ生成したいんです。

356:デフォルトの名無しさん
09/02/18 15:36:28
シリアライズされたオブジェクトファイルを自分で記述してデシリアライズすればいいんじゃね?

357:デフォルトの名無しさん
09/02/18 15:40:43
コンストラクタのオーバーロードでも作ってみるとか?
こんなん逃げじゃアカンかな・・・?(;´∀`)

public AAA()
{
 初期化();
}

public AAA(bool isIniti)
{
 if(isIniti == true)
  {
   初期化();
  }
}

private void 初期化()
{ほげ}

というか、コンストラクタに何も書かずに
コンストラクタみたいな感じの処理が
必要な時にSetInitializeみたいな関数作って呼ぶようにしたらダメなんだろうか…

358:デフォルトの名無しさん
09/02/18 15:41:46
いや、すでに独自のシリアライズのような仕組みがを実装していて、コンストラクタを呼ばないですむならそうしたいなと。

359:デフォルトの名無しさん
09/02/18 16:12:59
コピーコンストラクタの一種と思えば

360:デフォルトの名無しさん
09/02/18 17:05:59
>>347
なんで個人用ソフトでそんな対策する必要あるの?

361:デフォルトの名無しさん
09/02/18 18:38:57
あちらの素人馴れ合いスレで聞いても誰も答えてくれなかったのでこちらで質問させていただきます。

Microsoft.Samles名前空間以下のモジュールって自作アプリに組み込んで配布してもライセンス違反にならないでしょうか?

362:デフォルトの名無しさん
09/02/18 18:46:54
>>348
たまに裏返ったら擬似嫁が出てきて、
あわてるアニメーション後、また裏返って正しい表示に変わるやつが欲しいぜ!

363:デフォルトの名無しさん
09/02/18 19:09:26
>>362
自分で作れ

364:デフォルトの名無しさん
09/02/18 19:47:00
>>361
なりま

365:デフォルトの名無しさん
09/02/18 20:35:06
>>364

ありがとう。知らんなら黙っててください。

366:デフォルトの名無しさん
09/02/18 20:37:36
>>361
あー大丈夫だいじょーぶホント―にだいじょーぶw

367:デフォルトの名無しさん
09/02/18 20:43:44
>>361 こんなところに聞きにくるくらいなら自分で調べろ

368:デフォルトの名無しさん
09/02/18 20:54:53
>>365
黙りま

369:デフォルトの名無しさん
09/02/18 21:33:36
ここも素人ばかりですね
無駄口きいてないで少しは勉強したらどうですか?

370:デフォルトの名無しさん
09/02/18 21:37:21
匿名性の弊害

371:デフォルトの名無しさん
09/02/18 21:42:49
そもそもそんな大事なことをここで聞くな。
嘘だったらどうするんだ。
本家本元マイクロソフトさんに聞けばいいだろうに。

372:マイクロソフト
09/02/18 21:48:31
漏れも(゚听)ワカンネ

373:デフォルトの名無しさん
09/02/18 21:51:34
Microsoft.Samples 名前空間すべてを対象にした EULA、なんてものはない。
ということで、各サンプルの EULA に従う必要がある。

374:デフォルトの名無しさん
09/02/18 23:36:34
ぶつからないようにわざわざ名前付けてるのに
同じ名前付けてどうすんだよ

375:デフォルトの名無しさん
09/02/18 23:41:30
>>367
それ言い出したらム板の存在価値が・・

376:デフォルトの名無しさん
09/02/18 23:47:59
まぁでも、ライセンス関係は配布元に直接聞くほうが確実だしな。

377:デフォルトの名無しさん
09/02/18 23:54:43
訴えられた後だと遅いしね

378:デフォルトの名無しさん
09/02/19 00:11:45
すいません、ジェネリックに関しての質問です。

    public struct V2<T>{
        public T x;
        public T y;

        public V2( T x_, T y_ ){
            x = x_;
            y = y_;
        }

        public void Add( V2<T> v_){
            x += v_.x;
            y += v_.y;
        }
    }

このような構造体を作りたいのですが、Addメソッド内の
x、yそれぞれ加算しているところでコンパイルエラーとなってしまいます。

エラーの文言としては下記のものが出力されました。
「演算子 '+=' を 'T' と 'T' 型のオペランドに適用することはできません。」

これはTにどのようなものが指定されるか不明なので、
+=演算子が必ずしも使えない、よってこれをエラーとする。

このような理由でエラーが出ているのでしょうか?

また、宜しければ解決方法がございましたらお教えいただけたらうれしいです。

379:デフォルトの名無しさん
09/02/19 00:13:58
現スレの過去レスくらいは読め
>>145-177あたり参照


380:378
09/02/19 00:19:42
すいませんでした、早速読んできます。

381:デフォルトの名無しさん
09/02/19 00:27:14
その辺F#は華麗に実現できるのでまじお勧め

382:デフォルトの名無しさん
09/02/19 00:34:10
F#知らないんだけどどうやって実現してるの?
結局のところ,CLRで動かす以上は
・DynamicMethodを使ったコード動的生成やリフレクションなどによって動的に
・C++みたいにテキスト的に
の二つしか方法はないはずだけどどちらも華麗とは思えない

383:デフォルトの名無しさん
09/02/19 00:42:26
動的言語向けにCLRを拡張するんだよ。

384:デフォルトの名無しさん
09/02/19 00:47:14
DLRのことを言ってるなら,あれはCLRを拡張してるんじゃなくて
CLRの既存の機能を使用した単なるクラスライブラリにすぎないよ
>>382の上の方法に帰着する

385:デフォルトの名無しさん
09/02/19 08:05:50
今、F# をちょっと試してみたけど、型推論してるだけだな。

コマンドラインの方は触ってないけど、Visual F# で試したら、
全然動的なことしてなかった。


386:デフォルトの名無しさん
09/02/19 08:08:14
F#はちゃんとTに足し算させられるの?

387:デフォルトの名無しさん
09/02/19 08:15:32
手元にある F# の本の、ContentsとIndexをざっと眺めてみたけど、
ジェネリックス自体どこにもない。

>>381 に詳細聞きたい。

388:デフォルトの名無しさん
09/02/19 10:51:25
基本的にはOCamlだから文法上の静的型付けで解決するのでって話だと思ってたけど
それともF#はILのジェネリクスを使うように拡張されてる?
だとしたら同じくエラーになる気がする

389:デフォルトの名無しさん
09/02/19 14:23:06
System.Windows.Controls.TextBoxを160個並べて0.2秒に一回、Textに文字列を入れてるんですが
ときどきアプリ全体が劇重になってしまいます
Textに文字列を入れる部分だけコメントアウトすると重くなりません
これを回避する方法はあるでしょうか?
TextBoxを使ってると諦めるしかないのでしょうか?

390:デフォルトの名無しさん
09/02/19 14:32:53
非同期でぐぐれ

391:デフォルトの名無しさん
09/02/19 14:36:50
非同期処理してます

392:デフォルトの名無しさん
09/02/19 14:46:11
GCの影響?

393:デフォルトの名無しさん
09/02/19 16:00:15
InvokeではなくBeginInvoke使ってみるといいんじゃね?


394:デフォルトの名無しさん
09/02/19 16:29:43
TextBoxは重量級のコントロールだから160も並べたらそういうこともあるだろうな。
Labelじゃだめなん?

395:デフォルトの名無しさん
09/02/19 16:59:09
上のほうでも出てるけど、文字の出力だけでいいなら
LabelかGDIでいんじゃない?

396:デフォルトの名無しさん
09/02/19 17:28:35
Labelに変えたらスムースに動作するようになりました
ありがとうございました

でも右寄せ表示する方法が分からない
困った

397:デフォルトの名無しさん
09/02/19 17:41:09
AutoSizeをfalseにしてTextAlignでいけない?

398:デフォルトの名無しさん
09/02/19 17:47:12
右寄せの方法みつかった
Style style = new Style(typeof(ListBoxItem));
style.Setters.Add(new Setter(ListBoxItem.HorizontalContentAlignmentProperty,
HorizontalAlignment.Stretch));

ほんとWPFわけわからん
みなさん、ありがとうございました〜

399:デフォルトの名無しさん
09/02/19 17:56:58
WPFかよ
プロパティでデザイン時にも指定できるからそこからわかるべ。

400:デフォルトの名無しさん
09/02/19 18:13:17
そもそもItemsControlとか使ってバインディング
コードからコントロール生成しない
データソースを変更すれば勝手に表示が変わる

ってのがWPFの方向性

401:デフォルトの名無しさん
09/02/19 19:58:01
ADOとベタベタ

402:デフォルトの名無しさん
09/02/19 22:30:16
WPFで文字表示するだけならLabelよりもTextBlockのほうが軽いよ

403:デフォルトの名無しさん
09/02/19 23:06:40
ありがとうございます
さっそく修正しました

404:デフォルトの名無しさん
09/02/20 08:59:24
結構みんなWPF使ってるものなの?

405:デフォルトの名無しさん
09/02/20 09:10:51
使われてないよ

406:デフォルトの名無しさん
09/02/20 09:39:04
デフォルトのスタックサイズを変更するにはどうすればいいですか?

407:デフォルトの名無しさん
09/02/20 09:58:52
変更しなくていいよ

408:デフォルトの名無しさん
09/02/20 12:08:48
わろたww

409:デフォルトの名無しさん
09/02/20 12:15:21
わらわなくていいよ

410:デフォルトの名無しさん
09/02/20 12:25:07
吹いたw

411:デフォルトの名無しさん
09/02/20 13:06:39
汚いから拭いとけよ

412:デフォルトの名無しさん
09/02/20 13:08:07
いっぱい釣れたぜ
ショボン

413:デフォルトの名無しさん
09/02/20 16:35:13
キャッチしたらリリースしとけよ

414:デフォルトの名無しさん
09/02/20 20:20:11
海外の掲示板で質問したらすぐに答えがもらえました
ここの馬鹿な人たちとは大違いですね^^;
もう2度と来ません
ノシ

415:デフォルトの名無しさん
09/02/20 20:21:40
おまえだれ?

416:デフォルトの名無しさん
09/02/20 20:45:20
おれおれ

417:デフォルトの名無しさん
09/02/20 20:46:23
>>406
とりあえず、リンカで。

418:デフォルトの名無しさん
09/02/20 21:57:44
シェイラのそっくりさん?

419:デフォルトの名無しさん
09/02/20 22:09:09
>>417
根中 千恵子?

420:デフォルトの名無しさん
09/02/20 22:54:17
海外の掲示板に質問書き込むスキルはあるのにググるスキルはなかったのか・・・

421:デフォルトの名無しさん
09/02/21 00:52:53
この国の人ではないのかもしれん罠

422:デフォルトの名無しさん
09/02/21 01:30:42
つまり海外って日本のことか

423:デフォルトの名無しさん
09/02/21 01:32:33
2chを一つの国と考えてるかも試練

424:デフォルトの名無しさん
09/02/21 18:22:55
C#で省略可能引数の既定値を指定する方法はありますか?
[opt]属性はOptionalAttributeを付けることで付けられるようですが

425:デフォルトの名無しさん
09/02/21 18:27:51
引数のないメソッドでオーバーロードすればいいんでないの?

426:デフォルトの名無しさん
09/02/21 18:29:44
>>424
(1) 素直にオーバーロードを使う
(2) 引数をNullableにする

427:デフォルトの名無しさん
09/02/21 18:35:19
C#4.0をじっと待つ

428:424
09/02/21 18:43:53
省略可能引数をC#で使いたいわけではなくて,
VBで省略可能引数にしたときの既定値のメタデータを付けたいだけなんです
リフレクションで既定値の取得もできるみたいですがやっぱり設定するのは無理なんですかね

429:デフォルトの名無しさん
09/02/21 18:53:19
いや言ってる意味が。。

430:423
09/02/21 18:58:41
ごめんなさい
VBで省略可能引数の既定値を設定した場合,
既定値の情報はメタデータとしてメソッドに付加されます。
それと同じ形式のメタデータをC#で付けたいということです。
具体的にはこういうILです
.param [1] = "既定値"

431:デフォルトの名無しさん
09/02/21 19:08:08
リフレクタで言語をC#にして見てみたらどんな属性を付与しているのか分かるのでは?

432:デフォルトの名無しさん
09/02/21 19:12:59
URLリンク(msdn.microsoft.com)
これとか違うの?

433:424
09/02/21 19:18:01
>>432
[Optional, DefaultParameterValue("既定値")]でうまくいきました
ありがとうございます

434:432
09/02/21 19:19:19
URLリンク(stackoverflow.com)
正解っぽい。

435:デフォルトの名無しさん
09/02/21 19:21:30
あ、解決済みか。
これやってもC#で省略可能引数が使えるわけじゃないみたいね。
でも、アセンブリをVBから呼び出す時には省略可能になる引数を持つメソッドを
C#で定義できるのは興味深い。

436:デフォルトの名無しさん
09/02/21 23:35:48
逆の例もあるよ。
outはVBにないけど、Out属性付きのByRef引数はC#からout引数として扱われるというもの。

437:435
09/02/21 23:40:52
あーなるほど、ByRefだけだとref引数扱いになるのか。

438:デフォルトの名無しさん
09/02/22 01:49:55
4.0の動的型付け変数と、3.0の暗黙的型付けって、どういうときべんりなの?
大幅に労力が削減されるような利用法が思い浮かばないんだけど。

439:デフォルトの名無しさん
09/02/22 02:02:04
>>438
リフレクションやComInterop、やDLR対応の動的言語と相互運用する場合かな。
いろいろdymamicに期待してる人が要るけど、
dynamic型同士で + - * / などの演算はサポートされていないから、
プリミティブ型をdynamicにするのはナンセンス。


440:デフォルトの名無しさん
09/02/22 02:12:30
>>439
多言語との相互運用という趣旨ならわかるけど、
静的言語として、こういうのを許容しちゃうのって、どうなんだろう
コンパイル時にはエラーにならなくて、実行時にしかエラーにならないんでしょ?

暗黙型付けも、自分で型をしっかり宣言して、それで使うということで、
ユーザの思い込みの余地を減らすことが大事ということで
静的言語のメリットがあると思ってたんだけど、
なんか曖昧的なものを受け入れるような気がしていやな感じがする。

441:デフォルトの名無しさん
09/02/22 02:18:27
いやなのは使わなきゃいいだけ。


442:デフォルトの名無しさん
09/02/22 02:23:28
使わなきゃいいって言われても、
自分だけで成り立つ世界じゃないからなぁ
嫌でも他人のソースを見ることになるわけで

443:デフォルトの名無しさん
09/02/22 02:32:26
ヘジの言葉送ってやるよ。
「静的な型として動的な型を導入するんだ」

機能的には相互運用、さらに相互運用。プレゼンも基本それしか
出てこない。動的型前提な言語との相互運用、ライブラリを使う
ときに死ぬるんだよ現状。
しかも JavaScript だの IronPython だの DLR だの利用ケースが
増えていってやがる。

そういや雑談な話になるんだが、コンポーネントモデル周りは
ほとんど動的な要素で構成されてるよな。
なんでいまさら動的だからどうこうとかなるんだろうな

444:デフォルトの名無しさん
09/02/22 02:34:54
今までだって動的なことできたわけでそれが楽になるだけ
C#はそんなに強い静的型付け言語じゃない

445:デフォルトの名無しさん
09/02/22 02:49:43
そもそも相互運用するのが間違ってないか?
他方の言語は相互運用のために拡張して、他方の制限はない?
C#のいいところが失われているような気がするよ。

446:デフォルトの名無しさん
09/02/22 02:58:36
糊言語に何をいまさら。
あとせっかく DLR で「汎用的な」動的型システムつくってくれる
んだから乗らん手はないし


447:デフォルトの名無しさん
09/02/22 03:02:18
.NET使っておきながら動的はよくないやら相互運用が間違ってるやら

448:デフォルトの名無しさん
09/02/22 03:08:32
それ結果論でしょ
動的言語をnetで使うためのものがDLRなんだから

449:デフォルトの名無しさん
09/02/22 03:17:38
C#やjavaが複雑になって、新しい言語のダージリンdarjeelingができるわけですね
んで、それに対抗してC♭が開発されるわけです

それらの言語は多言語(特にC#)との相互運用性のために、
動的型型付けが導入されていきました。

そしてその間、ロシアはc++を使い続けました。

450:デフォルトの名無しさん
09/02/22 03:27:31
var i = Class;
とかユーザ定義変換とかどうなるんだろ
あと、var j 、Class.Method(out j);とかあったらjは何型?

451:デフォルトの名無しさん
09/02/22 03:38:28
>>450
コンパイルエラー

452:デフォルトの名無しさん
09/02/22 03:40:34
>>449
個人的にヘジの言語設計者としてのすごいところは
ゴチャゴチャ要素を詰め込みまくって許容範囲内に
纏め上げる才能だと思う。

>>450
型システムとしては大きく変わらん。だからそれらはどれも
今までと同じように通らない。
簡単に言うと新しい dynamic 型という「静的型」が導入される
感じ。こいつはディスパッチ周りが特殊に扱われる。

453:デフォルトの名無しさん
09/02/22 03:48:47
んで、後世に残るのは彼の手を離れたObjectPascalなんだろうな

454:デフォルトの名無しさん
09/02/22 03:53:19
Option Explicit OFF Strict OFF/Infer OFFモードのVBも
dynamic対応してくれるのだろうか。
今は毎回律儀にリフレクション使ってるから遅くて遅くて。


455:デフォルトの名無しさん
09/02/22 03:57:59
vbならどうだっていいでしょ なにやったって


456:デフォルトの名無しさん
09/02/22 04:05:00
>>452
ごちゃごちゃ要素を詰めまくって、
複雑になった分の学習に必要な非生産性と、
複雑になった分の楽できるコーディングや設計による生産性の向上を比較したら、
どっちがどうなんだろう

学習はともかく、通常と比較したら生産性はどんだけあがんだろ

457:デフォルトの名無しさん
09/02/22 04:34:42
心配は分かるがvarにしろdynamicにしろ絶妙にコントロールされてて、
想定以外の使い方をされないような工夫はしっかり施されている。
もしdynamicで四則演算の演算子が使えたり、
varがメンバやプロパティで使えたらそういう心配するような状態になるだろう。

458:デフォルトの名無しさん
09/02/22 04:41:15
演算子のオーバーロードで崩壊してるじゃん
足し算なのに引き算とか可能だし (;゚д゚)ァ....

459:デフォルトの名無しさん
09/02/22 04:44:40
gotoと同じく演算子のオーバーロードの乱用などは文法的に抑制しなくても、
常識的なプログラマーなら分かってるよね?といった風に信用してくれてる部分もある。
実際乱用されてるかい?
そういった部分も含めて絶妙と評価している。

460:デフォルトの名無しさん
09/02/22 04:46:51
gotoはifだったりでけっこうできるけど
演算子は無いと面倒くさいJavaやってたからかな〜

461:デフォルトの名無しさん
09/02/22 04:53:45
信用、常識をプログラマーの運用に求めるなら、そもそも静的型付けである必要がないだろ
なにいってんだ?

462:デフォルトの名無しさん
09/02/22 04:59:06
何が常識かは人によって違うからな
そのための強制約と考えるのは普通たよな

463:デフォルトの名無しさん
09/02/22 05:06:19
だからさじ加減が絶妙といってるのさ

464:デフォルトの名無しさん
09/02/22 05:09:16
>>459
つかまぁ、3.0 の丁寧な仕事といい社内で使いまくって叩いた上
出てくるんだろうなって感じがするよな


465:デフォルトの名無しさん
09/02/22 05:33:38
そしてmultiple宣言をしたclassには多重継承が許可されます
c++との相互運用のために

その中では、ポインタの使用も可能です
c++との相互運用のために

代入演算子のオーバーロードも可能にし、
いまではc++と同じ実装になっていますが、問題は発生していません
なぜならみんなが常識的なプログラマなので乱用されてはいないからです。

めでたしめでたし

466:デフォルトの名無しさん
09/02/22 05:37:12
名文なので、さらしあげ

467:デフォルトの名無しさん
09/02/22 05:45:48
代入演算子はキャストで良いだろ

468:デフォルトの名無しさん
09/02/22 11:11:03
>>457
dynamicはインデクサも演算子もinvoke式もなんでもアリだよ

469:デフォルトの名無しさん
09/02/22 11:26:43
ソースきぼう

470:デフォルトの名無しさん
09/02/22 11:29:54
URLリンク(code.msdn.microsoft.com)
ここでダウンロードできるNew Features in C# 4.0

471:デフォルトの名無しさん
09/02/22 11:33:57
とりあえずC#にほしいもの。
・多重継承orMixin
・friend
・C++ばりの変態テンプレート
・Lispばりのマクロ

472:デフォルトの名無しさん
09/02/22 11:35:02
ありがとん、読んでみる


473:デフォルトの名無しさん
09/02/22 11:38:14
dynamic<IHoge> hoge =
 IHogeを実装してないけどHogeという名前のメソッドを実装してる型のオブジェクト;
hoge.Hoge();
どうせならこんな感じでダックタイピングできるようにしちゃえばよかったのに

474:デフォルトの名無しさん
09/02/22 11:52:17
>>468
これのことですな。
>dynamic d = GetDynamicObject(…);
>int i = d + 3; // calling operators

出来ないといったのは正確ではなかったので訂正する。
OKのパターン
dynamic d = "abc"; string i = d + "xxx"; // "xxx"のstringが+オペレータを持っている。

NGのパターン
dynamic d = 10; int i = d + 3; // integerはプリミティブなので+オペレータを持ってない
dynamic d = "abc"; dynamic d2 = "XYZ"; string i = d + d2; // dynamic同士の演算



475:デフォルトの名無しさん
09/02/22 11:59:20
>dynamic d = 10; int i = d + 3;
これがなんでNGなのかわからない
>>470のドキュメントによると,コンパイルは通るはずだよね
実行時にエラーになるってこと?
試せないけど,今のExpression Treeの仕様から類推すると大丈夫そうな気がするんだが
あとStringの+は演算子オーバーロードじゃなくて言語組み込みだよ

476:デフォルトの名無しさん
09/02/22 12:00:56
>>474
ちと保留、これだと下の説明が付かないですね。
>dynamic d = GetDynamicObject(…); 
>int i = d + 3; // calling operators 

DynamicObjectが+オペレータをサポートしていれば大丈夫なのか。
それともCTPではまだ未実装の機能なのか。
うむむ・・

477:デフォルトの名無しさん
09/02/22 12:03:32
スレチ

478:デフォルトの名無しさん
09/02/22 13:54:58
なんか、「善意の人間がミスを犯しにくいようなしくみを工夫すること」と、
「悪意の人間の犯罪行為を防止すること」の区別がつかない人が2人ぐらいいるなw

479:デフォルトの名無しさん
09/02/22 14:01:52
この辺は難しいよね。
馬鹿基準に合わせると天才の要求仕様に満たなくなる。自分としては自由度を高めて使う側のスキルアップを要求する方がいい時も多々あるけれど

480:デフォルトの名無しさん
09/02/22 16:24:50
そこで複雑になったC#に変わり、Darjeelingの登場ですよ
Sun様おながいします

481:デフォルトの名無しさん
09/02/22 16:38:39
javaはjava teaではなくてjava coffeeが由来とされてるから、名前を付けるならTorajaがいいと思う。

482:デフォルトの名無しさん
09/02/22 16:44:42
javaの場合はscalaがはっちゃけてるからそっち行く可能性はあるかも。
.NETはC#自身がはっちゃけてるからな。他の言語はニッチ狙いなのがおおいな。booとかF#とか。

483:デフォルトの名無しさん
09/02/22 19:26:02
>>475-476
その話、英語のフィードバックサイトで出てたけど、
現CTP版では “まだ” できないって話だったと思う。

484:デフォルトの名無しさん
09/02/23 01:41:29
>>482
まぁScalaは使ってみると「うーん」という感じが否めないけどな。
JavaやC#に比べると、細かい部分で文法に無理が出まくってる。

やっぱりなんだかんだ言っても言語設計者のセンスって大事だなと思う。

スレチすまん

485:デフォルトの名無しさん
09/02/23 16:22:55
ウイルスバスターみたいに1PC1ライセンスみたいな感じの
個別認証をやりたいんですけど、どんなふうに実装するのが
いいんでしょ…?


486:デフォルトの名無しさん
09/02/23 16:52:17
ネット使ってサーバにアクティベーションするしかないんじゃないの?

487:デフォルトの名無しさん
09/02/23 16:54:34
>>485
「みたい」の指すところが全然分からん。
まずは要件定義とは何かを知ることから始めよう。

488:デフォルトの名無しさん
09/02/23 23:05:45
MACアドレスに対して認証キーを発行とかすればいいんじゃない。

489:デフォルトの名無しさん
09/02/23 23:36:40
簡単なファイラーを作っていて
Windows Vistaなどの検索ボックスのように、
スペースで区切ったキーワードにヒットするファイルの一覧を取得したいのですが、
何かスマート(簡単な)方法はないでしょうか?

今のところ、ファイル名に対して、
スペースで区切られたキーワードの数だけstring.containsを行うくらいしか思いつかないんですが、
この方法だと大量のファイルがあった場合に処理が遅くなってしまうと思うので。
# どんな方法でもファイル数が多ければ多いほど時間は掛かると思いますが、もう少し高速に行える方法があればと考えています。

490:デフォルトの名無しさん
09/02/23 23:49:07
>>489
正規表現をコンパイルしたら速いんじゃないか?知らんけどな
Regex.Match(input, "AAA|BBB|CCC", RegexOptions.IgnoreCase | RegexOptions.Compiled);

491:デフォルトの名無しさん
09/02/23 23:52:32
入力内容は毎回変わるのにその正規表現をコンパイルしたら
検索のたびにメモリを食って解放されなくなるぞ

492:デフォルトの名無しさん
09/02/24 00:01:52
ファイル数なんてどんなに多めに見積もっても百万のオーダーとかじゃないのかな?
だとしたらベタにやっても抽出する処理そのものには1秒掛からないんじゃないか。
むしろボトルネックは言うまでもないんだろうけどディスクアクセスって気がする。

493:デフォルトの名無しさん
09/02/24 00:11:15
index seviceを使う。

494:デフォルトの名無しさん
09/02/24 00:23:49
>>490-493
皆様ありがとうございます。

>>492
なるほど。
一度試してみてパフォーマンスをみることにします。

>>493
そんな方法があったとは思いつきませんでした。
軽くググってみると
URLリンク(209.85.175.132)
確かに…、少し調べてみようと思います。

495:デフォルトの名無しさん
09/02/24 00:37:43
インデックスサービスってWindowsにある程度詳しいユーザはたいがい止めてるよ

496:デフォルトの名無しさん
09/02/24 00:51:30
api公開されてアプリケーションから使えるあまり素性が怪しくない無料のエンジンって言うと選択肢それぐらいしかないんじゃない?

497:デフォルトの名無しさん
09/02/24 07:31:14
ジェネリックコレクションの保存ってどうしたらいいんですか?

public class MyList<T> : List<T>
{
 public void Load(string fileName)
 {
  using (Stream stream = new FileStream(fileName, FileMode.Create))
  {
   using (BinaryWriter writer = new BinaryWriter(stream))
   {
    foreach (T item in this)
    {
     writer.Write(item);//コンパイルエラー
    }
   }
  }
 }
}

498:デフォルトの名無しさん
09/02/24 07:34:50
シリアライザ

499:デフォルトの名無しさん
09/02/24 07:34:52
>>497の補足
使いたいTはintやlongやdoubleなどの値型だけです。

500:デフォルトの名無しさん
09/02/24 07:40:15
typeidでわけるしかない。

501:デフォルトの名無しさん
09/02/24 07:56:44
おかげで道がひらけました
ありがとうございます

502:デフォルトの名無しさん
09/02/24 08:14:30
>>497
無理やりだけど、

var write = typeof(BinaryWriter).GetMethod("Write", new[] { typeof(T) });
write.Invoke(writer, new object[] { value });


503:デフォルトの名無しさん
09/02/24 08:24:47
LoadでWrite

504:デフォルトの名無しさん
09/02/24 11:45:19
XmlSerializer使えよ

public void Save<T>(List<T> list)
{
byte[] bytes;
using (MemoryStream ms = new MemoryStream(0x10000))
{
new XmlSerializer(typeof(List<T).Serialize(ms, list);
bytes = ms.ToArray();
}

using (Stream stream = new FileStream(fileName, FileMode.Create))
using (BinaryWriter writer = new BinaryWriter(stream))
{
writer.Write(bytes);
}
}

505:デフォルトの名無しさん
09/02/24 17:24:53
>>497
Loadで保存w

506:デフォルトの名無しさん
09/02/24 18:45:49
>>502が簡単でよさそうだがBinaryReaderでもやろうとすると面倒だな
なんでreadとwriteでこんなにも非対称なコードになるんだ

507:デフォルトの名無しさん
09/02/24 18:49:31
objectで返したらボックス化が発生するからな
標準のライブラリでRead<T>//(注)プリミティブ型のみ
なんて素人臭いことするわけにもいかないし

508:デフォルトの名無しさん
09/02/24 18:56:57
プリミティブ型じゃなくても、そんな大げさにならずに簡単にできるの?

509:デフォルトの名無しさん
09/02/24 19:11:28
参照型のフィールドを含まない構造体限定なら
Marshal.StructureToPtrみたいな外道な方法を用いれば簡単にできる

510:デフォルトの名無しさん
09/02/24 19:13:19
ふんじゃあ、素人臭くてもいいじゃんw


511:デフォルトの名無しさん
09/02/24 21:21:41
他のアプリケーションのアイコン上に、あるテキストファイルをドラッグする処理(と同じ事)を
自作アプリケーション内で行いたいのですが、どのような方法があるのでしょうか・・・?
ドラッグ対象となるアプリケーションはコンソールアプリケーションです。
てぃんこでかい人よろしくおねがいします。


512:デフォルトの名無しさん
09/02/24 21:23:31
Main() の String[] args から取れなかったっけ?

513:デフォルトの名無しさん
09/02/24 21:28:21
その「他のアプリケーション」をプログラムから起動したいってことなら
System.DiagnosticsのProcess
エクスプローラで実行ファイルに何かのファイルをドロップするのは
その何かのファイルを引数に実行ファイルを起動するのと同じ

514:デフォルトの名無しさん
09/02/24 21:32:53
>>513
とても有益なヒントありがとうございました。
ちんこもでかくてありがとうございました。
試行錯誤してみます。


515:デフォルトの名無しさん
09/02/24 21:42:24
ちんこ小さいから回答できなかった

516:511
09/02/24 21:49:03
うーーん。以下のようにしても
ファイルを指定せずに実行ファイルを起動したような動作になっちゃう・・・

proc.StartInfo.Arguments ="あるテキストファイルのパス";
proc.StartInfo.FileName ="受け取り側の実行ファイルのパス";
proc.Start();

517:デフォルトの名無しさん
09/02/24 21:51:11
ちんこついてないから答えられない

518:デフォルトの名無しさん
09/02/24 21:51:29
>>516
「あるテキストファイルのパス」に空白が含まれるなら、""で囲まないとダメ。
具体的には、
proc.StartInfo.Arguments = "\"あるテキストファイルのパス\"";

519:511
09/02/24 21:54:34
こんな感じでしょうか?
""ではかこんでいます。

proc.StartInfo.Arguments = @"C:\sample.xml";
proc.StartInfo.FileName = @"C:\Document and setting\APPLE.exe";
proc.Start();

520:511
09/02/24 22:05:58
>>518
あああいけました
いけました。ありがとうございました。
ちんこにもよろしくお伝えください。

521:sage
09/02/24 23:19:27
RichTextBoxのスクロールバーをつまみで移動させると
ピクセル単位で動くのですが、TextBoxのように行単位で動かせるような方法ないですか?

URLリンク(wawatete.ddo.jp)
にあるような別途スクロールバーを作りたくなくて
RichTextBox備え付けのスクロールバーで実現したいのですが。。。

RichTextBoxのWndProcでつまみスクロールのイベントが来たら
SendMessage(rich1.Handle, EM_SCROLL, SB_LINEDOWN, 0)
で独自で1行スクロールとか試みたんですが、微妙にずれてしまって。。。

ちなみに上記URLと同じ目的ですが、RichTextBoxの左に
行番号を作りたいのですが、テキストが中途半端な表示されると
困るために、行単位でスクロールさせたい次第です。

教えてエライ人!

522:デフォルトの名無しさん
09/02/24 23:37:28
>>521
ボクはGDI+を使って書いた

523:デフォルトの名無しさん
09/02/24 23:38:33
さすがに行番行表示までやるならはじめから自前で作るべきだな

524:521
09/02/24 23:48:13
>>522
kwsk・・・、じゃなくておさわりだけでもいいんで
どんな流れか教えてください。

因みに自分は、クライアント領域が表示されてる分だけ左側に
Labelを配置して、スクロールされたら配置されてる全Labelに
メッセージなげて、Label.Textを変えて行番号を表示する方式を
考えてました。

525:デフォルトの名無しさん
09/02/24 23:50:13
>>506
Reader 側はもっと無理やりだけど、↓でできる。

var read = typeof(BinaryReader).GetMethod("Read" + typeof(T).Name, new Type[0]);
return (T)read.Invoke(reader, new object[0]);


526:デフォルトの名無しさん
09/02/24 23:53:45
ググれ若人

527:デフォルトの名無しさん
09/02/25 00:49:32
VS2008EEのC#でwebBrowser使ってpdfを表示したまま終了すると必ずエラー出すんだけど、これってどうにかできないの?
AdobeReader8ならエラー出なくて9だと出るって事はしばらくしたら改善される?

Delphi2006なら大丈夫だけどあっちはunicodeのテキスト読むのめんどいし、いい方法はないものかね?

528:デフォルトの名無しさん
09/02/25 01:10:55
>527
別のページを表示してから終了とか頑張ってみたけどどうしようもなくて
終了時だけなのでエラーを握り潰して無視したよ。

529:デフォルトの名無しさん
09/02/25 10:04:22
>>497
こんなのはどうかね
public abstract class ReaderWriter<T> : IDisposable
{
protected FileStream stream;
protected BinaryWriter writer;
protected BinaryReader reader;
public abstract void Write(T item);
public abstract T Read();
public virtual void Seek(long offset, SeekOrigin origin) { this.stream.Seek(offset, origin); }
public void Dispose()
{
if (this.reader != null) this.reader.Close();
if (this.writer != null) this.writer.Close();
if (this.stream != null) this.stream.Close();
}
}
public class IntReaderWriter : ReaderWriter<int>
{
public IntReaderWriter(string fileName)
{
this.stream = new FileStream(fileName, FileMode.OpenOrCreate, FileAccess.ReadWrite);
this.reader = new BinaryReader(this.stream);
this.writer = new BinaryWriter(this.stream);
}
public override void Write(int item) { this.writer.Write(item); }
public override int Read() { return this.reader.ReadInt32(); }
}

530:デフォルトの名無しさん
09/02/25 10:05:22
>>529の続き
public class MyList<T> : List<T>
{
public void Save(ReaderWriter<T> writer)
{
if (writer == null) return;
foreach (T item in this) writer.Write(item);
}
public void Load(ReaderWriter<T> reader, int count)
{
if (reader == null) return;
for (int i = 0; i < count; i++) this.Add(reader.Read());
}
}

static void Main(string[] args)
{
MyList<int> list = new MyList<int>();
using (IntReaderWriter writer = new IntReaderWriter("test.bin"))
list.Save(writer);
using (IntReaderWriter reader = new IntReaderWriter("test.bin"))
list.Load(reader, 100);
}
終わり

531:デフォルトの名無しさん
09/02/25 12:51:34
型ごとにReaderWriter<T>実装しないといけないなら全く意味ないなそれ
普通にSaveInt32とか型ごとに保存・読み込みメソッドを定義するのと変わらん

532:デフォルトの名無しさん
09/02/25 13:53:57
generic<typename TSrc, typename TDst>
where TSrc : value class where TDst : value class
void BlockCopy(
 array<TSrc>^ src, int srcOffset, array<TDst>^ dst, int dstOffset, int count) {
 using namespace System;
 pin_ptr<TSrc> pSrc = &src[0];
 Byte* pSrcByte = reinterpret_cast<Byte*>(pSrc);
 pin_ptr<TDst> pDst = &dst[0];
 Byte* pDstByte = reinterpret_cast<Byte*>(pDst);
 for (int i = 0; i < count; i++) pDstByte[srcOffset + i] = pSrcByte[dstOffset + i];
}
こういうのをC++/CLIで用意しておけば解決w

533:デフォルトの名無しさん
09/02/25 14:35:22
Application.DoEvents();
と等価の処理を別コードで書きたいんだけど
なにかいい方法はないかなぁ…
PeekMessageとかコレ系つかうとたまに応答なし
になってしまう。

timerとかBackGroundworkerだとプログラムが
みにくくなってしまうし悩んでます。


534:デフォルトの名無しさん
09/02/25 14:42:03
AというクラスにAクラスを返す
例えば
public virtual A CreateA(){ return new A(); }
があります。
このAを継承した
BというクラスはこのCreateAをオーバーライドしてBを返すようにしたいのですが
こういう事はできますか?
CreateBを新たに作らないと駄目ですか?

535:デフォルトの名無しさん
09/02/25 14:46:45
>>533
timerやbackgroundworkerで見にくくなる理由も不明だが、
Application.DoEvents()ではだめな理由も謎だな。

536:デフォルトの名無しさん
09/02/25 14:48:25
>>534
class B : A {} だったら
public override A CreateA(){ return new B(); } でいいじゃね。
戻り値の型をBにしたいなら、CreateBを作ることになるだろうけど。

537:デフォルトの名無しさん
09/02/25 14:52:55
そうですか…有り難うございます

538:533
09/02/25 14:58:27
>>535
URLリンク(d.hatena.ne.jp)
DoEventsを使うとたまに応答なしになったりひどい挙動を起こすことが
あるんですよ。
これを完全に回避したいんです。


539:デフォルトの名無しさん
09/02/25 15:00:24
class Base{
  public virtual Base Create();
}
class Base<T>:Base where T:Base<T>, new(){
  public override Base Create(){
    return (Base)(new T());
  }
  public T Create(){return new T();}
}
こんな方法もあるかも。未テストかつ変態的なので動くか不明。

なお、使う時は
class B:Base<B>{
 ...
}
class C:Base<B>{
 ...
}
みたいにする。

540:デフォルトの名無しさん
09/02/25 15:00:40
もう一つ良いですか?
同じクラスAに
class A
{
public const int i = 100;
public void D()
{
Console.Write(i);
}
}

とこれを継承したクラスB,に
public const int i=10;
としてBからDを呼び出すとiは10として処理されますか?
100として処理されますか。

541:デフォルトの名無しさん
09/02/25 15:03:18
あ、間違った。
class Base{
  public virtual Base CreateBase();
}
class Base<T>:Base where T:Base<T>, new(){
  public override Base CreateBase(){
    return (Base)(new T());
  }
  public T Create(){return new T();}
}
みたいにメソッド名は変えなきゃ駄目だ。
後、使い方の方も(まあ気が付くと思うけど)
class B:Base<B>{
 ...
}
class C:Base<C>{
 ...
}
ね。

542:デフォルトの名無しさん
09/02/25 15:05:09
>>540
それくらいなら、やってみりゃいいじゃん。

543:デフォルトの名無しさん
09/02/25 15:09:50
>>538
等価のコードを書いたら結局Application.DoEventsと同じ作用をもたらすだろ
素直にイベント駆動の脳になれ

544:デフォルトの名無しさん
09/02/25 15:10:27
>>540
やってみました
継承元の100が入ってきますね

どうにかして10にすることは出来ませんか?
>>539
やってみます

545:デフォルトの名無しさん
09/02/25 15:11:18
virtualなプロパティにすればよろし

546:デフォルトの名無しさん
09/02/25 15:15:34
>>545
できました有り難うございます。

547:539,541
09/02/25 15:44:40
>>544
共通の基底クラスが必要なければ、

class Base<T> where T : Base<T>, new()
{
  public static T Create() { return new T(); }
}
class A : Base<A> { }
class B : Base<B> { }

でも可だと思う。A:Base<foo>と書く時のfooはAのみに制約されて、それ以外を書くとコンパイル
エラーではねられる。継承先のクラスのインスタンスをプロパティの設定などの処理とともに生成
するメソッドを持つクラスを作る(変態的だけど)わりと一般的なテクニック。

548:デフォルトの名無しさん
09/02/25 15:48:35
>>547
成る程
よく分かりました
ついでにやっと何となくwhereが分かりました

549:デフォルトの名無しさん
09/02/25 15:49:24
>>548
class B:Base<B>{}があると、class A:Base<B>はコンパイルエラーにならないので注意してね。

550:デフォルトの名無しさん
09/02/25 22:09:43
>538
タイマーにしておけ。
見やすくなるように整理して書くだけだろ。


次ページ
最新レス表示
スレッドの検索
類似スレ一覧
話題のニュース
おまかせリスト
▼オプションを表示
暇つぶし2ch

5382日前に更新/228 KB
担当:undef