[過去ログ] Visual Studio 2017 Part6 (1002レス)
前次1-
抽出解除 必死チェッカー(本家) (べ) 自ID レス栞 あぼーん

このスレッドは過去ログ倉庫に格納されています。
次スレ検索 歴削→次スレ 栞削→次スレ 過去ログメニュー
リロード規制です。10分ほどで解除するので、他のブラウザへ避難してください。
423
(2): デフォルトの名無しさん (ササクッテロ Spf1-FcBl) [sage] 2019/01/28(月) 21:12:48.48 ID:ANcyv2bqp(1/5) AAS
>>421
421(2): デフォルトの名無しさん (ワッチョイ 4de3-cDLG) [sage] 2019/01/28(月) 20:55:57.66 ID:yOibm1qy0(1) AAS
>>420
log という名前は、数学的名「対数関数」 double log(double a); として、
既に定義されている。

だから例えば、log_to_console のような名前に変えると問題は解決する
と思う。
いやでも、てことはstdio.h (およびそこからインクルードされるヘッダ) に
log のプロトが宣言されてることになるな
本来、C、C++ には「組み込み」の関数なんてものは無いはずで
もしそうならあまりに気持ち悪い仕様だ
426
(1): デフォルトの名無しさん (ササクッテロ Spf1-FcBl) [sage] 2019/01/28(月) 22:10:34.73 ID:ANcyv2bqp(2/5) AAS
>>424
424(1): デフォルトの名無しさん (ワッチョイ 4d61-cDLG) [sage] 2019/01/28(月) 21:48:07.75 ID:jKaiFfBH0(1/2) AAS
>>423
VC++ の場合、高速化のために、log() 関数を、inline 関数のように、その場に
x87 FPU や SSE 命令を書き込む。だから「組み込み関数」。

ある意味では、inline 関数と inline アセンブラを両方組み合わせたようなもので、
最適化まで考えると、コンパイラが内部的に処理しないと難しいので、
「組み込み」にしてあるんだと思ってる。

昔から、VC++ inline アセンブラは、破壊レジスタや、入力レジスタなどを指定するのが
貧弱なので、コンパイラがレジスタの退避や、Cレベルの引数からの
アセンブラレベルのレジスタへの代入を余り自動的には行ってくれない。
それも関係有る。
どうもです
そうなのか〜〜げろげろ
せめて後ろの方の処理にしてlogが double log(double) と確定してから
オプティマイズして欲しいもんだ
429: デフォルトの名無しさん (ササクッテロ Spf1-FcBl) [sage] 2019/01/28(月) 23:08:01.60 ID:ANcyv2bqp(3/5) AAS
>>428
428(3): デフォルトの名無しさん (ワッチョイ e598-wD8z) [sage] 2019/01/28(月) 23:04:25.49 ID:2dkLEIpY0(1) AAS
>>420試してみたけど.cでは再現するのに.cppで再現しないのが不思議
これVSのバグとは違うん?
バグかどうかはともかく、C++ではマングルがされるせいだろうな
430: デフォルトの名無しさん (ササクッテロ Spf1-FcBl) [sage] 2019/01/28(月) 23:19:57.35 ID:ANcyv2bqp(4/5) AAS
>>428
補足するとC++では関数のオーバーロードを許してるので
同じ関数名でも引数の型や数が異なれば違う関数と判断されなければならない
433
(1): デフォルトの名無しさん (ササクッテロ Spf1-FcBl) [sage] 2019/01/28(月) 23:41:42.17 ID:ANcyv2bqp(5/5) AAS
ひょっとするとCでもstaticな関数にすれば通るかもね
前次1-
スレ情報 赤レス抽出 画像レス抽出 歴の未読スレ AAサムネイル

ぬこの手 ぬこTOP 0.036s