前スレ
C++相談室 part157
https://mevius.5ch.net/test/read.cgi/tech/1628474251/
C++相談室 part158
■ このスレッドは過去ログ倉庫に格納されています
2021/11/15(月) 18:49:18.44ID:I69rZ/Of
442はちみつ餃子 ◆8X2XSCHEME
2021/12/20(月) 11:34:47.56ID:GbIoN43K >>441
GCC の資料によれば Itanium C++ ABI に従う。 (Itanium 以外でも ABI は Itanium ということらしい。)
https://gcc.gnu.org/onlinedocs/libstdc++/manual/abi.html#abi.cxx_interface
で、 ABI のほうでの定義では引数・返却値における参照の実態はポインタだし、
POD のレイアウトとしても参照はポインタのように扱われる。
https://itanium-cxx-abi.github.io/cxx-abi/abi.html#reference-parameters
https://itanium-cxx-abi.github.io/cxx-abi/abi.html#reference-return-values
https://itanium-cxx-abi.github.io/cxx-abi/abi.html#pod
内部的には参照はほぼポインタだと思っていいんでないの。
自動でデリファレンスするポインタって感じ。
ちなみに言語仕様的には参照はオブジェクトではなく参照先のオブジェクトの別名のように扱われるので、
sizeof に渡したときには参照先の型の大きさが返ってくることになってる。
sizeof(int&) みたいにしたら sizeof(int) と同じ意味になるってことね。
GCC の資料によれば Itanium C++ ABI に従う。 (Itanium 以外でも ABI は Itanium ということらしい。)
https://gcc.gnu.org/onlinedocs/libstdc++/manual/abi.html#abi.cxx_interface
で、 ABI のほうでの定義では引数・返却値における参照の実態はポインタだし、
POD のレイアウトとしても参照はポインタのように扱われる。
https://itanium-cxx-abi.github.io/cxx-abi/abi.html#reference-parameters
https://itanium-cxx-abi.github.io/cxx-abi/abi.html#reference-return-values
https://itanium-cxx-abi.github.io/cxx-abi/abi.html#pod
内部的には参照はほぼポインタだと思っていいんでないの。
自動でデリファレンスするポインタって感じ。
ちなみに言語仕様的には参照はオブジェクトではなく参照先のオブジェクトの別名のように扱われるので、
sizeof に渡したときには参照先の型の大きさが返ってくることになってる。
sizeof(int&) みたいにしたら sizeof(int) と同じ意味になるってことね。
443デフォルトの名無しさん
2021/12/20(月) 11:49:32.57ID:LVF1I4ij 確認してみた。
$ gcc -x c++ -S - -o - <<EOF | sed -n '/^main:/,$p;/\$2/q'
int main() {
int a = 1;
int& r = a;
r = 2;
return a;
}
EOF
main:
.LFB0:
.cfi_startproc
endbr64
pushq %rbp
.cfi_def_cfa_offset 16
.cfi_offset 6, -16
movq %rsp, %rbp
.cfi_def_cfa_register 6
subq $32, %rsp
movq %fs:40, %rax
movq %rax, -8(%rbp)
xorl %eax, %eax
movl $1, -20(%rbp)
leaq -20(%rbp), %rax
movq %rax, -16(%rbp)
movq -16(%rbp), %rax
movl $2, (%rax)
$ gcc -x c++ -S - -o - <<EOF | sed -n '/^main:/,$p;/\$2/q'
int main() {
int a = 1;
int& r = a;
r = 2;
return a;
}
EOF
main:
.LFB0:
.cfi_startproc
endbr64
pushq %rbp
.cfi_def_cfa_offset 16
.cfi_offset 6, -16
movq %rsp, %rbp
.cfi_def_cfa_register 6
subq $32, %rsp
movq %fs:40, %rax
movq %rax, -8(%rbp)
xorl %eax, %eax
movl $1, -20(%rbp)
leaq -20(%rbp), %rax
movq %rax, -16(%rbp)
movq -16(%rbp), %rax
movl $2, (%rax)
444デフォルトの名無しさん
2021/12/20(月) 12:07:37.09ID:IpG9nRdD 参照先が見えてるところでは
参照先へ直にアクセスしてコストゼロだったり
参照引数をとる関数でもインライン化された場合はゼロ
てなことがなければポインタ1個分
参照先へ直にアクセスしてコストゼロだったり
参照引数をとる関数でもインライン化された場合はゼロ
てなことがなければポインタ1個分
445デフォルトの名無しさん
2021/12/20(月) 12:13:52.79ID:LVF1I4ij そういうのは最適化なので無関係
$ gcc -O3 -x c++ -S - -o - <<EOF | sed -n '/^main:/,$p;/ret/q'
int main() {
int a = 1;
int& r = a;
r = 2;
return a;
}
EOF
main:
.LFB0:
.cfi_startproc
endbr64
movl $2, %eax
ret
$ gcc -O3 -x c++ -S - -o - <<EOF | sed -n '/^main:/,$p;/ret/q'
int main() {
int a = 1;
int& r = a;
r = 2;
return a;
}
EOF
main:
.LFB0:
.cfi_startproc
endbr64
movl $2, %eax
ret
446デフォルトの名無しさん
2021/12/20(月) 21:41:58.49ID:c8hM8/Kk 最適化する前の意味合いとして
ポインタ1個分のコストを必ず発生するという規定なんかあったか?
ポインタ1個分のコストを必ず発生するという規定なんかあったか?
447デフォルトの名無しさん
2021/12/20(月) 21:44:15.52ID:LVF1I4ij 誰もそんな話はしてないので、お前が調べて貼れ
448デフォルトの名無しさん
2021/12/20(月) 22:11:35.36ID:c8hM8/Kk 444へのレスで最適化がどうたらぬかしといて
そんな話はしてない、かよ
アセンブラ貼ってた威勢はどこへ吹っ飛んだんだかw
いいよ、逃げたきゃ逃がしてやるよヘタレ野郎
そんな話はしてない、かよ
アセンブラ貼ってた威勢はどこへ吹っ飛んだんだかw
いいよ、逃げたきゃ逃がしてやるよヘタレ野郎
449デフォルトの名無しさん
2021/12/20(月) 22:16:05.29ID:LVF1I4ij 最初から処理系(gcc)の話しかしてない。規定の話をしてるのはお前だけだ。早く貼れ。逃げるな。
450デフォルトの名無しさん
2021/12/20(月) 23:16:36.18ID:TszysAyf unique_ptrオブジェクトとその実体を参照する参照型を使えば、
スタック消費を抑えつつスタック変数を使っているかのようなソースコードが書けそうだけど
スタック消費を抑えつつスタック変数を使っているかのようなソースコードが書けそうだけど
451デフォルトの名無しさん
2021/12/21(火) 00:06:02.44ID:Ug1txKhz それは全くレイヤーの違う話
アプリのコンテキストを構造体/クラスにしてヒープかスタティックに置くだけで実現できる
実現手段としてunique_ptrを使いたいなら使えばいいというだけ
アプリのコンテキストを構造体/クラスにしてヒープかスタティックに置くだけで実現できる
実現手段としてunique_ptrを使いたいなら使えばいいというだけ
452デフォルトの名無しさん
2021/12/21(火) 00:10:51.14ID:QziEyx5H453デフォルトの名無しさん
2021/12/21(火) 00:20:05.56ID:Ug1txKhz 煽りではないんだが、俺はID:LVF1I4ij
454デフォルトの名無しさん
2021/12/21(火) 00:33:36.24ID:QziEyx5H >>453
レイヤーが違うとか、勝手に仕切るな
レイヤーが違うとか、勝手に仕切るな
455デフォルトの名無しさん
2021/12/21(火) 00:42:51.31ID:QziEyx5H 構造体/クラスをヒープに置いたところで、その構造体/クラスのメンバー関数でスタック変数を使ってたら意味がないだろ
何が問題提起されているのか理解してから書き込んでくれ
何が問題提起されているのか理解してから書き込んでくれ
456デフォルトの名無しさん
2021/12/21(火) 01:02:00.74ID:Ug1txKhz スタック消費を抑えたいなら静的に確保するかヒープを使えばいいというだけの話でしょ。
struct app_context {int x;};
void func_old() {
int x = 0;
}
void func_new(app_context* ctx) {
ctx->x = 0;
}
int main() {
auto ctx = new app_context();
func_old();
func_new(ctx);
delete ctx;
return 0;
}
各関数/メソッド単位で細かくしたいなら、try〜catchでやってもいいし、スマートポインタを実装・流用してもいい。その際にunique_ptrを使いたいなら使えばいいというだけ。
伝わらないようなので少し細かく書いた。伝わるんだろうか・・・。
struct app_context {int x;};
void func_old() {
int x = 0;
}
void func_new(app_context* ctx) {
ctx->x = 0;
}
int main() {
auto ctx = new app_context();
func_old();
func_new(ctx);
delete ctx;
return 0;
}
各関数/メソッド単位で細かくしたいなら、try〜catchでやってもいいし、スマートポインタを実装・流用してもいい。その際にunique_ptrを使いたいなら使えばいいというだけ。
伝わらないようなので少し細かく書いた。伝わるんだろうか・・・。
457デフォルトの名無しさん
2021/12/21(火) 01:16:14.39ID:QziEyx5H >>456
君は回答者に向いてない
君は回答者に向いてない
458デフォルトの名無しさん
2021/12/21(火) 01:18:02.55ID:QziEyx5H アムロの父親みたいな変な書き込み、リアルに遭遇するとやはり引く
459デフォルトの名無しさん
2021/12/21(火) 01:18:43.76ID:Ug1txKhz >>457
質問したいレイヤと解決策のレイヤが合ってないだけw
質問したいレイヤと解決策のレイヤが合ってないだけw
460デフォルトの名無しさん
2021/12/21(火) 01:27:03.87ID:QziEyx5H 自覚なさそうなところがますますテム・レイ感あるわ
お大事に
お大事に
461デフォルトの名無しさん
2021/12/21(火) 01:46:16.28ID:Ug1txKhz 質問して複数人に回答してもらってるのに、ただ煽るだけの人に「自覚」とやらを問われてもねw
大好きなガンダムのたとえに勝手に満足して病んでてくれ
君にプログラミングは向いてない
大好きなガンダムのたとえに勝手に満足して病んでてくれ
君にプログラミングは向いてない
462デフォルトの名無しさん
2021/12/21(火) 01:50:07.69ID:QziEyx5H 今時特別な理由もなくnew演算子を使うC++プログラマは間違いなく無能だよ
463デフォルトの名無しさん
2021/12/21(火) 01:53:35.52ID:Ug1txKhz 理由はC++標準ライブラリを使用しない言語/処理系レベルの話をしていたから
464デフォルトの名無しさん
2021/12/21(火) 02:05:33.42ID:QziEyx5H ガンダムの記憶回路にとりつけるやつ好きなだけ作ってていいぞ
465デフォルトの名無しさん
2021/12/21(火) 02:17:40.01ID:Ug1txKhz 妄想の中でもニュータイプじゃない君にプログラミングは無理w
ガンダムに辿り着けずコロニー内で果てる
ガンダムに辿り着けずコロニー内で果てる
466デフォルトの名無しさん
2021/12/21(火) 14:30:10.99ID:bvwR7M/G テンプレートを引数に取る関数で、
その入力として、vectorと配列を取るような関数で、いい書き方ってないですかね?
// vector向け
template<class T>int sum(const T& v, int size)
{
int acc = 0;
for(int i = 0 ; i < size ; i++){acc+=v[i];}
return acc;
}
内容同じなのに配列向けに
template<class T>int sum(const T* v, int size)
を作ってるけど一緒に表記できないかな、みたいな
その入力として、vectorと配列を取るような関数で、いい書き方ってないですかね?
// vector向け
template<class T>int sum(const T& v, int size)
{
int acc = 0;
for(int i = 0 ; i < size ; i++){acc+=v[i];}
return acc;
}
内容同じなのに配列向けに
template<class T>int sum(const T* v, int size)
を作ってるけど一緒に表記できないかな、みたいな
467はちみつ餃子 ◆8X2XSCHEME
2021/12/21(火) 15:12:48.55ID:f1yxmqA1 >>466
???
その定義で配列も受け取れるけど。
int main(void) {
int x[] = {1, 2, 3};
std::cout << sum(x, 3) << std::endl;
}
???
その定義で配列も受け取れるけど。
int main(void) {
int x[] = {1, 2, 3};
std::cout << sum(x, 3) << std::endl;
}
468デフォルトの名無しさん
2021/12/21(火) 15:20:59.50ID:Ug1txKhz vectorならiteratorにしてもいいと思う
#include <vector>
#include <iostream>
using namespace std;
template<class T>int sum(const T begin, const T end) {
int acc = 0;
for(T i = begin; i != end; ++i){acc+=*i;}
return acc;
}
int main() {
int a[] = {1,2,3};
const size_t s = sizeof(a)/sizeof(a[0]);
vector<int> v(a, a + s);
cout << sum(a, a + s - 1) << endl;
cout << sum(v.begin(), v.begin() + (v.size() - 1)) << endl;
return 0;
}
#include <vector>
#include <iostream>
using namespace std;
template<class T>int sum(const T begin, const T end) {
int acc = 0;
for(T i = begin; i != end; ++i){acc+=*i;}
return acc;
}
int main() {
int a[] = {1,2,3};
const size_t s = sizeof(a)/sizeof(a[0]);
vector<int> v(a, a + s);
cout << sum(a, a + s - 1) << endl;
cout << sum(v.begin(), v.begin() + (v.size() - 1)) << endl;
return 0;
}
469デフォルトの名無しさん
2021/12/21(火) 15:35:03.48ID:bvwR7M/G470デフォルトの名無しさん
2021/12/21(火) 15:39:21.19ID:sStr75A4471デフォルトの名無しさん
2021/12/21(火) 15:47:15.24ID:msz2/cZB 本来はrangeの出番なんだがな
導入が遅れたばかりに……
導入が遅れたばかりに……
472デフォルトの名無しさん
2021/12/21(火) 16:45:50.91ID:fi3Z01x+ #include <iostream>
#include <vector>
#include <array>
#include <string>
using namespace std;
template<typename Iter>
auto sum(Iter a, Iter b) {
using value_type = remove_const_t<remove_reference_t<decltype(*a)>>;
value_type acc {};
while (a != b) acc += *a++;
return acc;
}
int main() {
const int a[] { 1, 2, 3 };
vector<int> v { 4, 5, 6 };
array<double, 3> d { 3.5, 1.2, 0.9 };
const string s[] { "u", "n" "k", "o" };
cout << sum(begin(a), end(a)) << endl;
cout << sum(begin(v), end(v)) << endl;
cout << sum(begin(d), end(d)) << endl;
cout << sum(begin(s), end(s)) << endl;
return 0;
}
#include <vector>
#include <array>
#include <string>
using namespace std;
template<typename Iter>
auto sum(Iter a, Iter b) {
using value_type = remove_const_t<remove_reference_t<decltype(*a)>>;
value_type acc {};
while (a != b) acc += *a++;
return acc;
}
int main() {
const int a[] { 1, 2, 3 };
vector<int> v { 4, 5, 6 };
array<double, 3> d { 3.5, 1.2, 0.9 };
const string s[] { "u", "n" "k", "o" };
cout << sum(begin(a), end(a)) << endl;
cout << sum(begin(v), end(v)) << endl;
cout << sum(begin(d), end(d)) << endl;
cout << sum(begin(s), end(s)) << endl;
return 0;
}
473デフォルトの名無しさん
2021/12/21(火) 16:51:06.96ID:msz2/cZB std::iterator_traits使おうよ
474デフォルトの名無しさん
2021/12/21(火) 16:56:11.01ID:fi3Z01x+ #include <iostream>
#include <vector>
#include <array>
#include <string>
#include <iterator>
using namespace std;
template<typename Iter>
auto sum(Iter a, Iter b) {
using value_type = typename iterator_traits<Iter>::value_type;
value_type acc {};
while (a != b) acc += *a++;
return acc;
}
int main() {
const int a[] { 1, 2, 3 };
vector<int> v { 4, 5, 6 };
array<double, 3> d { 3.5, 1.2, 0.9 };
const string s[] { "u", "n" "k", "o" };
cout << sum(begin(a), end(a)) << endl;
cout << sum(begin(v), end(v)) << endl;
cout << sum(begin(d), end(d)) << endl;
cout << sum(begin(s), end(s)) << endl;
return 0;
}
#include <vector>
#include <array>
#include <string>
#include <iterator>
using namespace std;
template<typename Iter>
auto sum(Iter a, Iter b) {
using value_type = typename iterator_traits<Iter>::value_type;
value_type acc {};
while (a != b) acc += *a++;
return acc;
}
int main() {
const int a[] { 1, 2, 3 };
vector<int> v { 4, 5, 6 };
array<double, 3> d { 3.5, 1.2, 0.9 };
const string s[] { "u", "n" "k", "o" };
cout << sum(begin(a), end(a)) << endl;
cout << sum(begin(v), end(v)) << endl;
cout << sum(begin(d), end(d)) << endl;
cout << sum(begin(s), end(s)) << endl;
return 0;
}
475デフォルトの名無しさん
2021/12/21(火) 17:32:40.16ID:Ug1txKhz sumがunkoは独創的だと思うけど、戻り値の型はテンプレート引数でいいかもね
476sage
2021/12/21(火) 18:15:52.03ID:qDHWQ1/Y ↓こんなコード書いてるんですが,もっとエレガントに代入できませんか?
a[0]=*ptr;
a[1]=*(ptr+1);
a[2]=*(ptr+2);
a[0]=*ptr;
a[1]=*(ptr+1);
a[2]=*(ptr+2);
477蟻人間 ◆T6xkBnTXz7B0
2021/12/21(火) 18:28:20.41ID:NT9maPPc ptr[1]
478デフォルトの名無しさん
2021/12/21(火) 19:09:14.75ID:qDHWQ1/Y479デフォルトの名無しさん
2021/12/21(火) 20:23:30.29ID:iHW7b2cO std::copy(ptr, ptr + 3, a);
僕はfor文のほうが好きです
僕はfor文のほうが好きです
480デフォルトの名無しさん
2021/12/21(火) 20:25:38.21ID:UPYLxpzi C++98以前の化石
481デフォルトの名無しさん
2021/12/21(火) 21:03:47.64ID:msz2/cZB std::copy_nもあるぞ
482デフォルトの名無しさん
2021/12/22(水) 18:49:46.59ID:ycAkB2VB483デフォルトの名無しさん
2021/12/22(水) 19:44:38.16ID:VkqlmauA 何に使いたいのか知らないけど、C++やめてRustの方がいいんじゃないの?
484デフォルトの名無しさん
2021/12/22(水) 20:00:31.77ID:j6Uulo2p 高速grepツールとして有名なripgrepはRustで作られてるからRustは優れた言語なのだろう、ぐらいなことは察せられるが
485デフォルトの名無しさん
2021/12/23(木) 08:08:59.49ID:zbE03cOE >>483
rustなんてプログラム初級者に勧めるなよ。
あんなの習熟した上級者向けの言語だわ。c++以上に初級者向け解説が無いのは致命的。
あと、Rustはスレ違いだからな。このコメにもレスするなよ。
rustなんてプログラム初級者に勧めるなよ。
あんなの習熟した上級者向けの言語だわ。c++以上に初級者向け解説が無いのは致命的。
あと、Rustはスレ違いだからな。このコメにもレスするなよ。
486デフォルトの名無しさん
2021/12/23(木) 09:13:28.05ID:cFIeneRn487デフォルトの名無しさん
2021/12/23(木) 09:43:11.86ID:TuHGjVDJ Rust は良いアプローチだがどうしても記述量が多くなるから敬遠してる
488デフォルトの名無しさん
2021/12/23(木) 11:51:22.33ID:Gjq2t2pD >>486
ポインタは名札のメタファーを使った説明が確立しているけど、所有権、譲渡、借用、ライフタイムの初心者向け説明はクソみたいのしか無いだろ。そんなもん初級者に紹介するなよ。
スレ違いでわざわざ役立たずを紹介するやつは何を考えているんだろうかね?
ポインタは名札のメタファーを使った説明が確立しているけど、所有権、譲渡、借用、ライフタイムの初心者向け説明はクソみたいのしか無いだろ。そんなもん初級者に紹介するなよ。
スレ違いでわざわざ役立たずを紹介するやつは何を考えているんだろうかね?
489デフォルトの名無しさん
2021/12/23(木) 12:29:11.30ID:cFIeneRn490デフォルトの名無しさん
2021/12/23(木) 12:33:21.82ID:lsirm1I0 .hや.cpp以外からいじられたくない変数に対するインライン関数をパブリックに公開したいのですが、classを利用する以外にこのような事はできないのでしょうか?
staticや無名名前空間を利用するとcppファイルで利用できなくなりますしやはりclassを使えということでしょうか?
extern int value; //これは隠蔽したい
inline bool IsZero() { return value == 0; } //これはグローバルに利用してもらいたい
staticや無名名前空間を利用するとcppファイルで利用できなくなりますしやはりclassを使えということでしょうか?
extern int value; //これは隠蔽したい
inline bool IsZero() { return value == 0; } //これはグローバルに利用してもらいたい
491デフォルトの名無しさん
2021/12/23(木) 12:43:43.47ID:N07J633j namespace {
extern int value; //これは隠蔽したい
}
inline bool IsZero() { return value == 0; } //これはグローバルに利用してもらいたい
extern int value; //これは隠蔽したい
}
inline bool IsZero() { return value == 0; } //これはグローバルに利用してもらいたい
492デフォルトの名無しさん
2021/12/23(木) 12:44:08.09ID:IRDqWaPI493デフォルトの名無しさん
2021/12/23(木) 12:44:27.15ID:N07J633j もとい
namespace {
int value; //これは隠蔽したい
}
inline bool IsZero() { return value == 0; } //これはグローバルに利用してもらいたい
namespace {
int value; //これは隠蔽したい
}
inline bool IsZero() { return value == 0; } //これはグローバルに利用してもらいたい
494デフォルトの名無しさん
2021/12/23(木) 12:47:57.55ID:IRDqWaPI >>493
関数内にstatic変数持てなかったっけ?
関数内にstatic変数持てなかったっけ?
495デフォルトの名無しさん
2021/12/23(木) 12:52:37.53ID:IRDqWaPI496デフォルトの名無しさん
2021/12/23(木) 12:58:20.57ID:cFIeneRn497デフォルトの名無しさん
2021/12/23(木) 12:59:07.12ID:6GqfEn2+ valueの立ち位置が気になるが
extern(実行ファイル内で全部共通)するならinline関数のIsZeroが見えた時点でvalueも見えてないといけない
extern(実行ファイル内で全部共通)するならinline関数のIsZeroが見えた時点でvalueも見えてないといけない
498デフォルトの名無しさん
2021/12/23(木) 13:03:49.15ID:cFIeneRn class hoge {
static int value;
public:
static bool IsZero() { return value == 0; }
};
inline bool IsZero() { hoge::IsZero(); }
int main() {
return IsZero();
}
static int value;
public:
static bool IsZero() { return value == 0; }
};
inline bool IsZero() { hoge::IsZero(); }
int main() {
return IsZero();
}
499デフォルトの名無しさん
2021/12/23(木) 13:07:02.43ID:lsirm1I0500デフォルトの名無しさん
2021/12/23(木) 13:20:56.47ID:cFIeneRn JavaやC#でもそんなところに可視性の定義はない。
501デフォルトの名無しさん
2021/12/23(木) 17:32:16.18ID:SEEFcByD >>496
相手がなんでc++を使っているのかのニーズすら確認しないで何を独りよがりなことを言っているんだよ。
相手の目的を無視してスレ違いのツールを薦めるのはアホのやること。
Rustの伝道師はこんな低レベルなのかね。
相手がなんでc++を使っているのかのニーズすら確認しないで何を独りよがりなことを言っているんだよ。
相手の目的を無視してスレ違いのツールを薦めるのはアホのやること。
Rustの伝道師はこんな低レベルなのかね。
502デフォルトの名無しさん
2021/12/23(木) 17:36:54.99ID:N07J633j あーうるせえ
C++スレでRust Rust連呼すんな
寒すぎんだよ
C++スレでRust Rust連呼すんな
寒すぎんだよ
503デフォルトの名無しさん
2021/12/23(木) 18:02:45.75ID:cFIeneRn504デフォルトの名無しさん
2021/12/23(木) 19:12:55.62ID:AUfS9hAV >>493
試してないけどこんなのはどうかね。
#include <iostream>
#include <cstdlib>
class Accesser;
class Wall {
static int & val(){ static int v; return v; };
friend Accesser;
};
class Accesser {
public:
Accesser(){
int &v=Wall::val();
v=1;
}
~Accesser(){
std::cout << Wall::val()<< std::endl;
}
};
int main()
{
Accesser a;
std::cout << "Hello, Wandbox!" << std::endl;
}
試してないけどこんなのはどうかね。
#include <iostream>
#include <cstdlib>
class Accesser;
class Wall {
static int & val(){ static int v; return v; };
friend Accesser;
};
class Accesser {
public:
Accesser(){
int &v=Wall::val();
v=1;
}
~Accesser(){
std::cout << Wall::val()<< std::endl;
}
};
int main()
{
Accesser a;
std::cout << "Hello, Wandbox!" << std::endl;
}
505デフォルトの名無しさん
2021/12/23(木) 19:32:24.95ID:3yOXD4ws inlineで書きたいらしいので、それだとコンパイル単位で値が変わっちゃうのでは?
506デフォルトの名無しさん
2021/12/23(木) 19:55:38.05ID:CLdJLYY1507デフォルトの名無しさん
2021/12/23(木) 20:02:52.87ID:cFIeneRn クラス内に実装を書くなどヘッダにあればどの道インラインだと思う
508デフォルトの名無しさん
2021/12/23(木) 20:05:51.29ID:cFIeneRn staticは静的に確保されるので、インライン展開されても同じシンボルを参照する
509デフォルトの名無しさん
2021/12/23(木) 20:30:35.89ID:cFIeneRn510デフォルトの名無しさん
2021/12/23(木) 21:54:27.28ID:4lOSoN0i メモリ確保用途でvectorやstringつかい
ポインタアクセスすれば、new で確保するのと速度に大差ないとおもうんですが
実測すると10%〜くらいSTLつかうほうが速度低下するみたいなんですが
直メモリアクセスでも落ちるのはなぜなんでしょうか
ポインタアクセスすれば、new で確保するのと速度に大差ないとおもうんですが
実測すると10%〜くらいSTLつかうほうが速度低下するみたいなんですが
直メモリアクセスでも落ちるのはなぜなんでしょうか
511デフォルトの名無しさん
2021/12/23(木) 22:14:02.53ID:6YhOrdG1 その計測コード貼ってみ
多分メモリアクセスとは関係ない所で時間食ってる
多分メモリアクセスとは関係ない所で時間食ってる
512デフォルトの名無しさん
2021/12/23(木) 22:16:19.47ID:lsirm1I0513510
2021/12/23(木) 22:21:06.77ID:4lOSoN0i514デフォルトの名無しさん
2021/12/23(木) 22:38:03.27ID:MjSWMWRR 1秒もかかる?
515510
2021/12/23(木) 22:49:58.53ID:4lOSoN0i こっちだと大差がついてるんですが
家のPCでもideone.comよりも差が付きます vector確保のほうが遅い
https://paiza.io/projects/9wWo36-bjTCL_S0WcGbaWA
vector : 459.154 ms
new char : 184.758 ms
new int32 : 167.899 ms
家のPCでもideone.comよりも差が付きます vector確保のほうが遅い
https://paiza.io/projects/9wWo36-bjTCL_S0WcGbaWA
vector : 459.154 ms
new char : 184.758 ms
new int32 : 167.899 ms
516510
2021/12/23(木) 22:55:16.12ID:4lOSoN0i 自己解決しました
メモリ確保と解放部分を含めて計測してたのを
コピー部分のみの測定にしたらほぼ一緒になりました
https://paiza.io/projects/ge5iOWrzGu2E2PjogsRlUw
vector : 219.947 ms
new char : 204.565 ms
new int32 : 214.644 ms
メモリ確保と解放部分を含めて計測してたのを
コピー部分のみの測定にしたらほぼ一緒になりました
https://paiza.io/projects/ge5iOWrzGu2E2PjogsRlUw
vector : 219.947 ms
new char : 204.565 ms
new int32 : 214.644 ms
517デフォルトの名無しさん
2021/12/23(木) 22:55:24.77ID:6YhOrdG1 ほとんどメルセンヌツイスタの実行時間じゃね
518デフォルトの名無しさん
2021/12/23(木) 22:56:40.08ID:MjSWMWRR 確保にかかってると思う?
一秒はさすがにないと思う。
何かおかしいな。
一秒はさすがにないと思う。
何かおかしいな。
519デフォルトの名無しさん
2021/12/23(木) 22:58:15.18ID:MjSWMWRR vector云々以前に、newバージョンも遅すぎると思う。
話にならないくらい。
i8008とかじゃないよね?
話にならないくらい。
i8008とかじゃないよね?
520デフォルトの名無しさん
2021/12/23(木) 23:00:56.66ID:6GqfEn2+ C++/CLIでstd::mutex使えないのなんでなん?
頑張ってWin32APIで代用する気力はあるけどわざわざ無効化されてる理由が知りたい
頑張ってWin32APIで代用する気力はあるけどわざわざ無効化されてる理由が知りたい
521510
2021/12/23(木) 23:05:52.89ID:4lOSoN0i メモリ確保・解放と、メルセンヌツイスタを外して計測したら
今度はvectorのほうが圧倒的に早いんですが
https://ideone.com/rKv4qv
vector : 237.55 ms
new int32 : 713.82 ms
今度はvectorのほうが圧倒的に早いんですが
https://ideone.com/rKv4qv
vector : 237.55 ms
new int32 : 713.82 ms
522デフォルトの名無しさん
2021/12/23(木) 23:26:56.25ID:4lOSoN0i 計測時間は、ある程度の長さで、オンライン実行環境のタイムアウトにならないように
ループ回数を変更してるので
ループ回数を変更してるので
523デフォルトの名無しさん
2021/12/23(木) 23:54:08.59ID:58w1xOUi 生ポインタにしたら同じ感じにならない?
unique_ptr<int32_t[]> p(new int32_t[2*size]);
int32_t* A = p.get();
mmcpy(A, size);
unique_ptr<int32_t[]> p(new int32_t[2*size]);
int32_t* A = p.get();
mmcpy(A, size);
524デフォルトの名無しさん
2021/12/24(金) 01:54:49.07ID:T9e6TA98 手動でループ回数変更とか馬鹿らしいからquick-bench.comとか使うのオススメ
525デフォルトの名無しさん
2021/12/24(金) 09:00:08.27ID:opQHMY4K overrunがある
std::make_uniqueを使え
std::make_uniqueを使え
526デフォルトの名無しさん
2021/12/24(金) 09:04:03.38ID:opQHMY4K527デフォルトの名無しさん
2021/12/24(金) 09:05:00.82ID:6d0f054m サンプルコードだからと安易にnew演算子使う風潮やめたほうがいい
コールバックや別スレッドに渡すインスタンスの生成にのみnew演算子を使うべき
コールバックや別スレッドに渡すインスタンスの生成にのみnew演算子を使うべき
528デフォルトの名無しさん
2021/12/24(金) 09:08:39.52ID:opQHMY4K そういうことではなくunique_ptrを理解してから使えというだけ
529デフォルトの名無しさん
2021/12/24(金) 09:09:02.65ID:6d0f054m バッドノウハウがいつまでたってもなくならない原因は入門者向けのサンプルコード
530デフォルトの名無しさん
2021/12/24(金) 09:09:36.51ID:opQHMY4K そもそもサンプルコードの質が悪すぎる
531デフォルトの名無しさん
2021/12/24(金) 09:10:57.45ID:opQHMY4K 今回のね(>>526)
532デフォルトの名無しさん
2021/12/24(金) 09:11:48.94ID:6d0f054m533デフォルトの名無しさん
2021/12/24(金) 09:12:11.50ID:opQHMY4K >>462は壮大な勘違い
534デフォルトの名無しさん
2021/12/24(金) 09:13:48.09ID:opQHMY4K535デフォルトの名無しさん
2021/12/24(金) 09:21:12.05ID:6d0f054m536デフォルトの名無しさん
2021/12/24(金) 09:22:45.08ID:opQHMY4K537デフォルトの名無しさん
2021/12/24(金) 09:25:48.61ID:ZnDQBfvC 練習と本番を一緒くたにしてるな
まさに現場の癌だったと自白してるようなものだ
まさに現場の癌だったと自白してるようなものだ
538デフォルトの名無しさん
2021/12/24(金) 09:28:20.47ID:opQHMY4K まさにお前がな
539デフォルトの名無しさん
2021/12/24(金) 09:30:24.34ID:opQHMY4K コロコロID変わる質問者兼劣悪回答者の荒らしで、そもそも勤務経験なさそう、と思ってるよ
540デフォルトの名無しさん
2021/12/24(金) 09:31:16.13ID:6d0f054m >>536
現役離れてずいぶん経つの?
実務やってれば仕様書の文章があいまいで実際に動かさないと理解できないってことがいくらでもあるでしょ
「仕様書はない、ソースのみ(キリッ」という状況なんて普通なはずだが
現役離れてずいぶん経つの?
実務やってれば仕様書の文章があいまいで実際に動かさないと理解できないってことがいくらでもあるでしょ
「仕様書はない、ソースのみ(キリッ」という状況なんて普通なはずだが
541デフォルトの名無しさん
2021/12/24(金) 09:32:13.38ID:6d0f054m 教わるとか受け身かよ、アホかと
学ぶんだろ
学ぶんだろ
■ このスレッドは過去ログ倉庫に格納されています
ニュース
- 【速報】中国外務省報道官 高市首相発言撤回なければ「断固たる対抗措置」 ★2 [蚤の市★]
- 高市首相答弁を“引き出した”立民・岡田克也氏が改めて説明「なぜ慎重な答弁をされなかったのか。非常に残念に思っている」 ★4 [ぐれ★]
- 【次の一手】台湾問題で小林よしのり氏が私見「まさに戦争前夜」「ただちに徴兵制を敷いて、高市支持者を最前線へ」… ★3 [BFU★]
- 中国、日本行き“50万人”キャンセル 渡航自粛でコロナ禍以来最大 [お断り★]
- 高市首相答弁を“引き出した”立民・岡田克也氏が改めて説明「なぜ慎重な答弁をされなかったのか。非常に残念に思っている」 ★5 [ぐれ★]
- 【速報】日本産牛肉の対中国輸出再開協議が中止 ★2 [おっさん友の会★]
- 貧民アニオタ向けdアニメ、値上げへ [175344491]
- 【高市変質者】 お尻を出している 小太りTシャツの自転車乗りが発生 😱 [485983549]
- 【速報】中国政府、ゲームを禁輸。原神やブルアカ、荒野行動が日本で影響 [347751896]
- 中国「私達が怒ってるのは日本の政治家に対してで、日本の観光客や日本企業はこれまで通り歓迎する。これこそが大国としての余裕」 [377482965]
- 高市早苗ショック直撃のホテルホテル業界 次のホ◯ショックは何だ? [695089791]
- 高市コイン、ガチで156円突入へwwwwwwwwww [246620176]
