!extend:checked:vvvvv:1000:512
!extend:checked:vvvvv:1000:512
↑同じ内容を3行貼り付けること
次スレは>>980が立てること
無理なら細かく安価指定
※前スレ
C++相談室 part162
https://mevius.5ch.net/test/read.cgi/tech/1667194175/
VIPQ2_EXTDAT: checked:vvvvv:1000:512:: EXT was configured
C++相談室 part163
■ このスレッドは過去ログ倉庫に格納されています
1デフォルトの名無しさん (ワッチョイ bbda-Axul)
2022/12/30(金) 23:16:31.37ID:DPUEZfMS0249デフォルトの名無しさん (ワッチョイ d312-Pfi1)
2023/01/27(金) 14:40:15.09ID:7yNCo9mI0 >>240
ヘボなんだね
ヘボなんだね
250デフォルトの名無しさん (ワッチョイ 735f-Ymzw)
2023/01/27(金) 14:50:32.81ID:MqPTrKVr0 コードサイズは確かに増えるだろうが、性能は本当に測ったんか?
251デフォルトの名無しさん (スプッッ Sd1f-kZgD)
2023/01/27(金) 16:10:15.39ID:k7iFif1Jd チープな環境ではコードサイズが増えるのは致命的
252デフォルトの名無しさん (ワッチョイ c35f-j5s0)
2023/01/27(金) 16:17:02.37ID:a+0fKe/I0253はちみつ餃子 ◆8X2XSCHEME (ワッチョイ 6f3e-j5s0)
2023/01/27(金) 16:29:51.65ID:B8oMym/70 >>246
テンプレート自体が実行性能の足を引っ張るってことはないが
個々の場面でより性能よく書けるはずのときに汎用部品で済ましてしまうってことはあるんじゃない?
そういうときでも個々の箇所をいじるよりは特殊化を足すだけで済むほうが楽だと思うが。
テンプレート自体が実行性能の足を引っ張るってことはないが
個々の場面でより性能よく書けるはずのときに汎用部品で済ましてしまうってことはあるんじゃない?
そういうときでも個々の箇所をいじるよりは特殊化を足すだけで済むほうが楽だと思うが。
254デフォルトの名無しさん (スプッッ Sd1f-kZgD)
2023/01/27(金) 16:34:12.21ID:k7iFif1Jd 同じ結果になるように書けばそりゃ同じだろう
テンプレートで楽をすればコードは(一般的には)増える
memcpyで済む物が
型別にコードが発生したり
そういう所を気にすると結局楽が出来ない
テンプレートで楽をすればコードは(一般的には)増える
memcpyで済む物が
型別にコードが発生したり
そういう所を気にすると結局楽が出来ない
255デフォルトの名無しさん (スプッッ Sd1f-kZgD)
2023/01/27(金) 16:37:07.22ID:k7iFif1Jd256デフォルトの名無しさん (スプッッ Sd1f-kZgD)
2023/01/27(金) 16:40:41.26ID:k7iFif1Jd 10種類のテンプレート引数で使うコードは
基本的には10個のバイナリが生成される
10種類手で書けば
当然コードの共通化を(人間が)考える
基本的には10個のバイナリが生成される
10種類手で書けば
当然コードの共通化を(人間が)考える
257はちみつ餃子 ◆8X2XSCHEME (ワッチョイ 6f3e-j5s0)
2023/01/27(金) 17:11:02.52ID:B8oMym/70258デフォルトの名無しさん (スプッッ Sd1f-kZgD)
2023/01/27(金) 17:18:26.40ID:k7iFif1Jd259デフォルトの名無しさん (ワッチョイ 7f6a-HXiP)
2023/01/27(金) 17:22:03.06ID:6glVv8Ll0 Embedded C++やってろ
260デフォルトの名無しさん (ワッチョイ d312-Pfi1)
2023/01/27(金) 17:22:16.96ID:7yNCo9mI0 非力なハードで無理目なことをギリ勝負でやるときはアセンブラだろ
261デフォルトの名無しさん (スプッッ Sd1f-kZgD)
2023/01/27(金) 17:22:48.21ID:k7iFif1Jd 実際PC用コードの多くは組み込みでは全く使えず
ほとんどゼロからの開発になる
ほとんどゼロからの開発になる
262デフォルトの名無しさん (スプッッ Sd1f-kZgD)
2023/01/27(金) 17:24:10.47ID:k7iFif1Jd263デフォルトの名無しさん (ワッチョイ fff0-Jpma)
2023/01/27(金) 17:24:25.29ID:6ZIN/roZ0 そういう環境ってそもそも標準ライブラリ揃ってなかったりしない?このスレで扱う必要ある?
264デフォルトの名無しさん (スプッッ Sd1f-kZgD)
2023/01/27(金) 17:25:27.76ID:k7iFif1Jd >>263
標準ライブラリのスレではないから
標準ライブラリのスレではないから
265デフォルトの名無しさん (スプッッ Sd1f-kZgD)
2023/01/27(金) 17:32:21.49ID:k7iFif1Jd ぬるま湯環境しか知らないはちみつ
もう少し視野を広げた方が良いかと
もう少し視野を広げた方が良いかと
266デフォルトの名無しさん (ワッチョイ d312-Pfi1)
2023/01/27(金) 17:50:48.85ID:7yNCo9mI0 なんかやたらマウント取りたがるな
267デフォルトの名無しさん (ワッチョイ fff0-Jpma)
2023/01/27(金) 17:55:50.00ID:6ZIN/roZ0 学校でC++03教えてそう(笑)
268はちみつ餃子 ◆8X2XSCHEME (ワッチョイ 6f3e-j5s0)
2023/01/27(金) 18:01:40.26ID:B8oMym/70 ワイは Z80 時代を生きたおじさんやぞ。
いまどきチープな組み込みでも最初からそんなカリカリにチューニングするのはそんなにないやろ。
無いとは言わんけど C++ の利用例としては例外的やわ。
いまどきチープな組み込みでも最初からそんなカリカリにチューニングするのはそんなにないやろ。
無いとは言わんけど C++ の利用例としては例外的やわ。
269デフォルトの名無しさん (スプッッ Sd1f-kZgD)
2023/01/27(金) 18:16:51.47ID:tKRPgB5dd カリカリチューンとぬるま湯コーディング
はちみつの頭の中はどっちかしか存在しないのかよ
はちみつの頭の中はどっちかしか存在しないのかよ
270デフォルトの名無しさん (ワッチョイ d312-Pfi1)
2023/01/27(金) 18:24:03.96ID:7yNCo9mI0 人のことを小馬鹿にするだけなやつ出てけよ
プログラム技術の話の邪魔だ
プログラム技術の話の邪魔だ
271デフォルトの名無しさん (スプッッ Sd47-kZgD)
2023/01/27(金) 18:25:43.08ID:ESaqgTdPd272デフォルトの名無しさん (ワッチョイ d312-Pfi1)
2023/01/27(金) 18:28:51.80ID:7yNCo9mI0 は? 俺は技術の話をしている
途中で根拠も挙げずに変なことを言うやつにチクリとやったが
貴様と違いそれだけじゃねえんだよボケ
途中で根拠も挙げずに変なことを言うやつにチクリとやったが
貴様と違いそれだけじゃねえんだよボケ
273デフォルトの名無しさん (スプッッ Sd1f-kZgD)
2023/01/27(金) 18:30:54.17ID:cYktn2Sdd 根拠あるじゃん
274デフォルトの名無しさん (スプッッ Sd1f-kZgD)
2023/01/27(金) 18:31:53.95ID:cYktn2Sdd おれがいくつか書いた
275デフォルトの名無しさん (ワッチョイ d312-Pfi1)
2023/01/27(金) 18:32:25.20ID:7yNCo9mI0 どこにだよ
しどろもどろな返事だなスカタン
しどろもどろな返事だなスカタン
276デフォルトの名無しさん (スプッッ Sd1f-kZgD)
2023/01/27(金) 18:33:01.59ID:cYktn2Sdd 日本語読めない人かな?
277デフォルトの名無しさん (ワッチョイ d312-Pfi1)
2023/01/27(金) 18:38:13.74ID:7yNCo9mI0 ないものは示せないもんな
せいぜいそんな言い訳にもなってないことを勝手にぬかしてろ
俺はこれから夕飯作らにゃならんし害虫が出てくのを待つ意味でもしばらく落ちる
せいぜいそんな言い訳にもなってないことを勝手にぬかしてろ
俺はこれから夕飯作らにゃならんし害虫が出てくのを待つ意味でもしばらく落ちる
278はちみつ餃子 ◆8X2XSCHEME (ワッチョイ 6f3e-j5s0)
2023/01/27(金) 19:53:44.64ID:B8oMym/70279デフォルトの名無しさん (ワッチョイ 5310-xn9V)
2023/01/27(金) 19:59:17.27ID:RxpK1TrS0 10種類とかで肥大するのはテンプレートなのにデカい関数作るからやろ
共通化できる部分は型に依存しない箇所だからテンプレートだろうと外に出せる
共通化できる部分は型に依存しない箇所だからテンプレートだろうと外に出せる
280デフォルトの名無しさん (ワッチョイ 6301-H6v1)
2023/01/27(金) 22:01:21.69ID:GkVPt6s00 >>270
それお前やろ
それお前やろ
281デフォルトの名無しさん (ワッチョイ 0301-SUdz)
2023/01/27(金) 22:06:41.58ID:rBkTgp9F0 www
282デフォルトの名無しさん (ワッチョイ ffad-88l+)
2023/01/27(金) 22:15:36.78ID:y5pwToDP0 孤独のグルメじゃないけど「こういうのでいいんだよ」が最適解なこと多いよな、C/C++
283デフォルトの名無しさん (ワッチョイ e3da-c8s6)
2023/01/27(金) 22:37:05.53ID:kTII8Zcn0 あまりゴチャゴチャさせずにシンプルイズベストよな
284デフォルトの名無しさん (ブーイモ MM7f-snR2)
2023/01/27(金) 22:40:45.09ID:Tnyv3fMqM C++20 のビューとやらを使ってみてるんだがデバッガで見づらすぎるのどうにかならん?
285デフォルトの名無しさん (オイコラミネオ MM07-lPZJ)
2023/01/27(金) 23:34:33.68ID:qVpyYaSyM >>237
template<int N = 100> class A{
static int nnn{N};
};
とすると、
A<123>::nnn が 123 になるはず。
static を付けない場合は、インタンスオブジェクトに対して取得できる。
template<int N = 100> class A{
static int nnn{N};
};
とすると、
A<123>::nnn が 123 になるはず。
static を付けない場合は、インタンスオブジェクトに対して取得できる。
286デフォルトの名無しさん (ワッチョイ 0b01-Z6M9)
2023/01/28(土) 15:20:49.48ID:x4SDzju+0 これは>>239が面白いな
287デフォルトの名無しさん (ワッチョイ 1a34-5WkL)
2023/01/28(土) 15:29:40.57ID:ys7yM/+j0288デフォルトの名無しさん (ワッチョイ 0b01-Z6M9)
2023/01/28(土) 15:40:35.35ID:x4SDzju+0289デフォルトの名無しさん (ワッチョイ db76-xF8Z)
2023/01/28(土) 16:15:40.82ID:gfTDhobA0 単に初期化で使ってるだけでしょ
今回はintであることが明白だから=でも()でも{}でも初期化できるけど
この手のコンパイル時に決まるやつはstatic constexpr一択だね
array<T, nankanokosuu> a;みたいに他のテンプレート引数に使える
今回はintであることが明白だから=でも()でも{}でも初期化できるけど
この手のコンパイル時に決まるやつはstatic constexpr一択だね
array<T, nankanokosuu> a;みたいに他のテンプレート引数に使える
290デフォルトの名無しさん (ワッチョイ 83da-lkW6)
2023/01/28(土) 16:18:27.56ID:TUmaQinN0 constexprにするとコンパイル時に解決出来ない項目は弾かれてしまうからconstのままでいい
知らないなら余計な修正は加えるな
知らないなら余計な修正は加えるな
291デフォルトの名無しさん (ワッチョイ 0b01-Z6M9)
2023/01/28(土) 16:50:45.80ID:x4SDzju+0292デフォルトの名無しさん (オイコラミネオ MM63-ZqoR)
2023/01/28(土) 17:08:38.28ID:1oumyOI/M >>288
>それはさておき初期化の位置に使っている中括弧 {N} はなに?
C++11位から導入された初期化の一種。
a{N}は、a = N とほぼ同じだが、縮小変換をしないということや、
「どんな場所でも必ず使える」特徴があると言われており、Stroustrup氏
は、= よりも {} を推奨している。
また、{} による初期化は「直接初期化」と関係が深く、= による初期化は
「代入初期化」と関係が深い。
>それはさておき初期化の位置に使っている中括弧 {N} はなに?
C++11位から導入された初期化の一種。
a{N}は、a = N とほぼ同じだが、縮小変換をしないということや、
「どんな場所でも必ず使える」特徴があると言われており、Stroustrup氏
は、= よりも {} を推奨している。
また、{} による初期化は「直接初期化」と関係が深く、= による初期化は
「代入初期化」と関係が深い。
293デフォルトの名無しさん (ワッチョイ 0b01-Z6M9)
2023/01/28(土) 22:18:12.18ID:x4SDzju+0294デフォルトの名無しさん (オイコラミネオ MM63-ZqoR)
2023/01/28(土) 23:35:50.70ID:JY7EfERdM >>293
「直接初期化(direct initialization)」とも関係しているが、
{}による初期化は、「一様初期化 (uniform initialization)」
で検索すると出て来やすい。
なお、ネットでdirect initializationを検索しても間違った定義が出てくるかも知れない。
「直接初期化(direct initialization)」とも関係しているが、
{}による初期化は、「一様初期化 (uniform initialization)」
で検索すると出て来やすい。
なお、ネットでdirect initializationを検索しても間違った定義が出てくるかも知れない。
295デフォルトの名無しさん (ワッチョイ 0b01-Z6M9)
2023/01/29(日) 00:27:43.05ID:2zmXfTjk0 >>294
なるほど「直接初期化」と{}による初期化(= [一様初期化])は分かった
[一様初期化] https://cpprefjp.github.io/lang/cpp11/uniform_initialization.html
[直接初期化] https://learn.microsoft.com/ja-jp/cpp/cpp/initializers?view=msvc-170
「縮小変換」と「代入初期化」が分からん
「代入初期化」は=による初期化のことを言ってるのかな?
なるほど「直接初期化」と{}による初期化(= [一様初期化])は分かった
[一様初期化] https://cpprefjp.github.io/lang/cpp11/uniform_initialization.html
[直接初期化] https://learn.microsoft.com/ja-jp/cpp/cpp/initializers?view=msvc-170
「縮小変換」と「代入初期化」が分からん
「代入初期化」は=による初期化のことを言ってるのかな?
296デフォルトの名無しさん (スップ Sd5a-VuUV)
2023/01/29(日) 12:04:49.28ID:l1ZINGQtd C++17のcopy elisionでルール変わったね
297デフォルトの名無しさん (オイコラミネオ MM63-ZqoR)
2023/01/29(日) 13:42:04.03ID:uP7zelejM >>295
正しい定義かどうかは分からないが、一応、
「直接初期化」「コピー初期化」については、英語版の en.cppreference.com
をそれぞれ
「direct initialization」「copy initialization」
で検索すると「パターン」一覧が出てくるみたいだ。
ただし、一覧については「全てのパターン」かは定かではない。
例えば、direct initialization については、一覧には、new T(XXX) しか出てないが、
new T{XXX} でも良いハズ。
正しい定義かどうかは分からないが、一応、
「直接初期化」「コピー初期化」については、英語版の en.cppreference.com
をそれぞれ
「direct initialization」「copy initialization」
で検索すると「パターン」一覧が出てくるみたいだ。
ただし、一覧については「全てのパターン」かは定かではない。
例えば、direct initialization については、一覧には、new T(XXX) しか出てないが、
new T{XXX} でも良いハズ。
298デフォルトの名無しさん (オイコラミネオ MM63-ZqoR)
2023/01/29(日) 13:47:49.42ID:uP7zelejM >>297
https://en.cppreference.com/w/cpp/language/direct_initialization
T object ( arg );
T object ( arg1, arg2, ... ); (1)
T object { arg }; (2) (since C++11)
T ( other )
T ( arg1, arg2, ... ) (3)
static_cast< T >( other ) (4)
new T(args, ...) (5)
Class::Class() : member(args, ...) { ... } (6)
[arg](){ ... } (7) (since C++11)
[説明]
* (5)は、() しか出てないが、{} でも可能 :
new T(args, ...) (5)
new T{args, ...} (5')
* (3) も、() しか出てないが、{} でも可能で恐らくother でなくてもいい筈だ(定かではない) :
T ( other )
T ( arg )
T ( arg1, arg2, ... ) (3)
T { other }
T { arg }
T { arg1, arg2, ... } (3’)
https://en.cppreference.com/w/cpp/language/direct_initialization
T object ( arg );
T object ( arg1, arg2, ... ); (1)
T object { arg }; (2) (since C++11)
T ( other )
T ( arg1, arg2, ... ) (3)
static_cast< T >( other ) (4)
new T(args, ...) (5)
Class::Class() : member(args, ...) { ... } (6)
[arg](){ ... } (7) (since C++11)
[説明]
* (5)は、() しか出てないが、{} でも可能 :
new T(args, ...) (5)
new T{args, ...} (5')
* (3) も、() しか出てないが、{} でも可能で恐らくother でなくてもいい筈だ(定かではない) :
T ( other )
T ( arg )
T ( arg1, arg2, ... ) (3)
T { other }
T { arg }
T { arg1, arg2, ... } (3’)
299デフォルトの名無しさん (オイコラミネオ MM63-ZqoR)
2023/01/29(日) 13:56:42.30ID:uP7zelejM >>295
>「縮小変換」と「代入初期化」が分からん
>「代入初期化」は=による初期化のことを言ってるのかな?
縮小変換は、検索すると出てくる。
「代入初期化」という言葉は、俺の記憶違いだったらしく、「コピー初期化」
が正しかったようだ。難しい。
>「縮小変換」と「代入初期化」が分からん
>「代入初期化」は=による初期化のことを言ってるのかな?
縮小変換は、検索すると出てくる。
「代入初期化」という言葉は、俺の記憶違いだったらしく、「コピー初期化」
が正しかったようだ。難しい。
300デフォルトの名無しさん (オイコラミネオ MM63-ZqoR)
2023/01/29(日) 14:05:48.45ID:uP7zelejM ここが分かり易いかな:
「Is it direct-initialization or copy-initialization?」
https://stackoverflow.com/questions/46634869/is-it-direct-initialization-or-copy-initialization
「Is it direct-initialization or copy-initialization?」
https://stackoverflow.com/questions/46634869/is-it-direct-initialization-or-copy-initialization
301デフォルトの名無しさん (ワッチョイ 0b01-Z6M9)
2023/01/29(日) 20:57:42.75ID:2zmXfTjk0 >>299,300
なるほど「縮小変換をしない」とは
例えば以下でエラーになるってことね
int a {1.0};
「コピー初期化」ってのはコピーコンストラクタを呼ぶ初期化
あるいはコピーコンストラクタ自体のことで良いのかな?
なるほど「縮小変換をしない」とは
例えば以下でエラーになるってことね
int a {1.0};
「コピー初期化」ってのはコピーコンストラクタを呼ぶ初期化
あるいはコピーコンストラクタ自体のことで良いのかな?
302デフォルトの名無しさん (オイコラミネオ MM63-ZqoR)
2023/01/29(日) 23:00:33.52ID:JRnzhQFiM >>301
>「コピー初期化」ってのはコピーコンストラクタを呼ぶ初期化
>あるいはコピーコンストラクタ自体のことで良いのかな?
個人的には、
CPerson::CPerson( CPerson const &rPeson )
の形式のコンストラクタがコピーコンストラクタで、
それを使う初期化がコピー初期化、と思って今まで生きてきたが、
それだと、「直接初期化」の対比の意味のものとは違っているように思える。
どこかで、言葉の混乱が起きているかも。
分からない。
>「コピー初期化」ってのはコピーコンストラクタを呼ぶ初期化
>あるいはコピーコンストラクタ自体のことで良いのかな?
個人的には、
CPerson::CPerson( CPerson const &rPeson )
の形式のコンストラクタがコピーコンストラクタで、
それを使う初期化がコピー初期化、と思って今まで生きてきたが、
それだと、「直接初期化」の対比の意味のものとは違っているように思える。
どこかで、言葉の混乱が起きているかも。
分からない。
303デフォルトの名無しさん (オイコラミネオ MM63-ZqoR)
2023/01/29(日) 23:11:23.60ID:JRnzhQFiM >>302
一部の例外を除いては、「コピー初期化」とは、= が書いてある初期化で、
「直接初期化」とは、= が書いて無い初期化、だといわれている。
但し、沢山例外があって、
T x = T(a);
などは、直接初期化なんだそうだ。
また、return a などは、コピー初期化、なんだそうだ。
記憶に頼っているので間違っているかも知れない。
一部の例外を除いては、「コピー初期化」とは、= が書いてある初期化で、
「直接初期化」とは、= が書いて無い初期化、だといわれている。
但し、沢山例外があって、
T x = T(a);
などは、直接初期化なんだそうだ。
また、return a などは、コピー初期化、なんだそうだ。
記憶に頼っているので間違っているかも知れない。
304デフォルトの名無しさん (ワッチョイ 83da-lkW6)
2023/01/29(日) 23:20:25.89ID:ppqTPlns0 コピコンか代入か明示するためのexplicitよ
305はちみつ餃子 ◆8X2XSCHEME (ワッチョイ b63e-fO7+)
2023/01/30(月) 01:17:26.91ID:kRDQpz8S0 >>302
コンストラクタはどれも直接初期化に使えるコンストラクタだけど
一定の形式を満たすものはコピー初期化の文脈「でも」使えるってだけ。
>>303
> T x = T(a);
> などは、直接初期化なんだそうだ。
これについて形式的にはあくまでもコピー初期化の一種ということになる。
https://timsong-cpp.github.io/cppwp/n4659/dcl.init#15
その上でコピーの省略が起きて結果的には直接初期化と同じ挙動になる。
https://timsong-cpp.github.io/cppwp/n4659/class.copy.elision#1
コンストラクタはどれも直接初期化に使えるコンストラクタだけど
一定の形式を満たすものはコピー初期化の文脈「でも」使えるってだけ。
>>303
> T x = T(a);
> などは、直接初期化なんだそうだ。
これについて形式的にはあくまでもコピー初期化の一種ということになる。
https://timsong-cpp.github.io/cppwp/n4659/dcl.init#15
その上でコピーの省略が起きて結果的には直接初期化と同じ挙動になる。
https://timsong-cpp.github.io/cppwp/n4659/class.copy.elision#1
306デフォルトの名無しさん (オイコラミネオ MM63-ZqoR)
2023/01/30(月) 16:11:51.36ID:S2+yDPxmM 記憶に頼って書くけど、
1. 1つの引数を持つコンストラクタは、explicit修飾することが推奨されている。
2. explicit指定が無いと、そのつもりは無い「ひょんな場所」で勝手に変換コンストラクタとして
利用されてしまうことがある。特に関数に引数を渡す場合に起き易いらしい。
3. CPerson::CPerson( CPerson &rPerson ) は、同じ型を単純にコピーする
コンストラクタであるから、そもそも型の変換はしないので変換コンストラクタでなく、
「コピー・コンストラクタ」と言われる。
4. つまり、CPerson::CPerson( AAA &rAAA ) のような場合に
1. 1つの引数を持つコンストラクタは、explicit修飾することが推奨されている。
2. explicit指定が無いと、そのつもりは無い「ひょんな場所」で勝手に変換コンストラクタとして
利用されてしまうことがある。特に関数に引数を渡す場合に起き易いらしい。
3. CPerson::CPerson( CPerson &rPerson ) は、同じ型を単純にコピーする
コンストラクタであるから、そもそも型の変換はしないので変換コンストラクタでなく、
「コピー・コンストラクタ」と言われる。
4. つまり、CPerson::CPerson( AAA &rAAA ) のような場合に
307デフォルトの名無しさん (オイコラミネオ MM63-ZqoR)
2023/01/30(月) 16:18:21.06ID:S2+yDPxmM >>306
[誤送信してしまった。スマソ]
4. つまり、CPerson::CPerson( AAA const &rAAA ) や CPerson::CPerson( int &rX )
のような場合に explicit 指定することが推奨されていたと思う。
T x = T(a);
の場合、「C++のからくり」のような昔の解説書だと、最適化に任されているのではなく、
特別処理されているようなニュアンス(?)で、T x(a) と同じだと書いてあった。
もし、特別処理されてないと考えた場合、= の部分だけに着目すれば、T::T( T const &rX ) という
コピーコンストラクタの呼び出しと意味論的には考えて考えられなくも無い。
そうするとそこは「変換コンストラクタ」ではなく「コピーコンストラクタ」が使われることになる。
コピーコンストラクタはいくら使っても速度が遅くなる以外は劣化やデータの変化が無いため
無害と言えば無害。なので、explicit が付いていてもいなくても余り関係が無いような気がする。
[誤送信してしまった。スマソ]
4. つまり、CPerson::CPerson( AAA const &rAAA ) や CPerson::CPerson( int &rX )
のような場合に explicit 指定することが推奨されていたと思う。
T x = T(a);
の場合、「C++のからくり」のような昔の解説書だと、最適化に任されているのではなく、
特別処理されているようなニュアンス(?)で、T x(a) と同じだと書いてあった。
もし、特別処理されてないと考えた場合、= の部分だけに着目すれば、T::T( T const &rX ) という
コピーコンストラクタの呼び出しと意味論的には考えて考えられなくも無い。
そうするとそこは「変換コンストラクタ」ではなく「コピーコンストラクタ」が使われることになる。
コピーコンストラクタはいくら使っても速度が遅くなる以外は劣化やデータの変化が無いため
無害と言えば無害。なので、explicit が付いていてもいなくても余り関係が無いような気がする。
308デフォルトの名無しさん (オイコラミネオ MM63-ZqoR)
2023/01/30(月) 16:24:16.09ID:S2+yDPxmM >>307
[補足]
void f(T x);
に対して、
U a;
f(a);
と書くと、実引数aが仮引数xに渡される時の動作は、「コピー(?)初期化」と考えられて
いる。もしかしたら言葉は正しく無いかもしれないが、少なくとも「直接初期化」には
分類されないということ。
そしてexplicitが付いて無いコンストラクタは、このような初期化に対しては用いられ
ないことが保証されると書いてあったと思う。
[補足]
void f(T x);
に対して、
U a;
f(a);
と書くと、実引数aが仮引数xに渡される時の動作は、「コピー(?)初期化」と考えられて
いる。もしかしたら言葉は正しく無いかもしれないが、少なくとも「直接初期化」には
分類されないということ。
そしてexplicitが付いて無いコンストラクタは、このような初期化に対しては用いられ
ないことが保証されると書いてあったと思う。
309デフォルトの名無しさん (オイコラミネオ MM63-ZqoR)
2023/01/30(月) 16:25:22.84ID:S2+yDPxmM >>308
[訂正]
誤: そしてexplicitが付いて無いコンストラクタは、このような初期化に対しては用いられ
ないことが保証されると書いてあったと思う。
正: そしてexplicitが付いている無いコンストラクタは、このような初期化に対しては用いられ
ないことが保証されると書いてあったと思う。
[訂正]
誤: そしてexplicitが付いて無いコンストラクタは、このような初期化に対しては用いられ
ないことが保証されると書いてあったと思う。
正: そしてexplicitが付いている無いコンストラクタは、このような初期化に対しては用いられ
ないことが保証されると書いてあったと思う。
310デフォルトの名無しさん (オイコラミネオ MM63-ZqoR)
2023/01/30(月) 16:26:12.39ID:S2+yDPxmM >>309
[再訂正]
誤: そしてexplicitが付いている無いコンストラクタは、このような初期化に対しては用いられ
ないことが保証されると書いてあったと思う。
正: そしてexplicitが付いているコンストラクタは、このような初期化に対しては用いられ
ないことが保証されると書いてあったと思う。
[再訂正]
誤: そしてexplicitが付いている無いコンストラクタは、このような初期化に対しては用いられ
ないことが保証されると書いてあったと思う。
正: そしてexplicitが付いているコンストラクタは、このような初期化に対しては用いられ
ないことが保証されると書いてあったと思う。
311デフォルトの名無しさん (オイコラミネオ MM63-ZqoR)
2023/01/30(月) 16:50:51.20ID:S2+yDPxmM >>304
explicit指定の主な役割は、変換コンストラクタにexplicit修飾しておくことで
「変換コンストラクタが知らず知らずのうちに勝手に使われてしまう事」
を防げる、ということだったと思う。
explicit指定の主な役割は、変換コンストラクタにexplicit修飾しておくことで
「変換コンストラクタが知らず知らずのうちに勝手に使われてしまう事」
を防げる、ということだったと思う。
312デフォルトの名無しさん (スップ Sd5a-VuUV)
2023/01/30(月) 16:53:41.85ID:BI3s5DYMd regexやthreadのexplicitが邪魔
313はちみつ餃子 ◆8X2XSCHEME (ワッチョイ b63e-fO7+)
2023/01/30(月) 17:25:41.99ID:kRDQpz8S0 >>306
explicit を付けることは推奨されているわけじゃない。
推奨している人もいるけど普通は必要に応じて使い分けるよ。
明らかに変換を意味しないようなコンストラクタになっちゃうこともあるから気を付けろという程度の話。
たとえば vector は size_t を受け取るコンストラクタがある (指定サイズ分の大きさになる) がそれには当然 explicit が付いてる。
整数が vector に変換されるのは明らかにおかしいから。
char* から string への変換みたいな自然な変換では困らないし、あるほうが便利。
>>307
> 特別処理されているようなニュアンス
かつてはその場合はコピーの省略が許される (しなくてもよい) という仕様だった。 (今の仕様だとコピーの省略が必須。)
コピーコンストラクタは必ずしもコピーをするだけではなくなんらかの副作用を引き起こしても良いので
コピーの省略の有無によってプログラムの意味が変わってしまう。
プログラムの意味を変えない範囲で処理系が行う通常の「最適化」とは異なるという意味では特別扱いだ。
explicit を付けることは推奨されているわけじゃない。
推奨している人もいるけど普通は必要に応じて使い分けるよ。
明らかに変換を意味しないようなコンストラクタになっちゃうこともあるから気を付けろという程度の話。
たとえば vector は size_t を受け取るコンストラクタがある (指定サイズ分の大きさになる) がそれには当然 explicit が付いてる。
整数が vector に変換されるのは明らかにおかしいから。
char* から string への変換みたいな自然な変換では困らないし、あるほうが便利。
>>307
> 特別処理されているようなニュアンス
かつてはその場合はコピーの省略が許される (しなくてもよい) という仕様だった。 (今の仕様だとコピーの省略が必須。)
コピーコンストラクタは必ずしもコピーをするだけではなくなんらかの副作用を引き起こしても良いので
コピーの省略の有無によってプログラムの意味が変わってしまう。
プログラムの意味を変えない範囲で処理系が行う通常の「最適化」とは異なるという意味では特別扱いだ。
314デフォルトの名無しさん (ワッチョイ b7f4-+rQD)
2023/01/30(月) 17:35:07.72ID:c/LsY66H0 難しいなぁ。。。
ubuntu の g++って 11.1以降だから、c++23だったのね。
すご って思いました。
ubuntu の g++って 11.1以降だから、c++23だったのね。
すご って思いました。
315デフォルトの名無しさん (スップ Sd5a-VuUV)
2023/01/30(月) 19:37:46.73ID:BI3s5DYMd C++2bはまだドラフトだよ
316デフォルトの名無しさん (オイコラミネオ MM63-ZqoR)
2023/01/30(月) 20:58:31.18ID:rMqdSurOM >>313
>たとえば vector は size_t を受け取るコンストラクタがある (指定サイズ分の大きさになる) がそれには当然 explicit が付いてる。
>整数が vector に変換されるのは明らかにおかしいから。
>char* から string への変換みたいな自然な変換では困らないし、あるほうが便利。
なるほど。そうだったのか。
勉強になりました。
>たとえば vector は size_t を受け取るコンストラクタがある (指定サイズ分の大きさになる) がそれには当然 explicit が付いてる。
>整数が vector に変換されるのは明らかにおかしいから。
>char* から string への変換みたいな自然な変換では困らないし、あるほうが便利。
なるほど。そうだったのか。
勉強になりました。
317デフォルトの名無しさん (アウアウウー Sa47-hJvz)
2023/02/02(木) 23:34:11.97ID:Ce1dvKO2a C++やるとどんな言語も使えるとか言うけどNode.jsも数時間あれば使いこなせるの?
あれは言語じゃないでしょって言われそうだがjavascriptともhtmlとも違くて別言語に思えるんだけど
あれは言語じゃないでしょって言われそうだがjavascriptともhtmlとも違くて別言語に思えるんだけど
318デフォルトの名無しさん (ワッチョイ b7b7-5WkL)
2023/02/02(木) 23:52:01.04ID:zSdJjx9q0319デフォルトの名無しさん (ワッチョイ 83da-lkW6)
2023/02/03(金) 00:10:02.14ID:GSbNqAeQ0 C++出来ます‼ってのはC言語上がりのなんちゃってチャソも含まれるから一概には言えない
320はちみつ餃子 ◆8X2XSCHEME (ワッチョイ e33e-fO7+)
2023/02/03(金) 00:27:17.07ID:cvg0vFRY0 >>317
C++ を使っていれば低レイヤの事情やシステム全体の関連を知る機会があるし、
言語処理系がどう実装されるのか (低レイヤの視線から見てどう動くのか) を知っていれば
常識的な言語デザインの感覚がわかる。 (言語仕様を類推しやすい。)
C++ を使いこなしている状況からなら色々と理解しやすいという効果がないとは言えない。
ただ、あくまでも C++ を使いこなせるようになる過程で言語自体以外にも身につくことがあるという部分が効いてくるので
C++ の言語仕様の知識はそれほど役に立つわけではないし、さすがに数時間で Node.js を使いこなせるということはない。
C++ を使っていれば低レイヤの事情やシステム全体の関連を知る機会があるし、
言語処理系がどう実装されるのか (低レイヤの視線から見てどう動くのか) を知っていれば
常識的な言語デザインの感覚がわかる。 (言語仕様を類推しやすい。)
C++ を使いこなしている状況からなら色々と理解しやすいという効果がないとは言えない。
ただ、あくまでも C++ を使いこなせるようになる過程で言語自体以外にも身につくことがあるという部分が効いてくるので
C++ の言語仕様の知識はそれほど役に立つわけではないし、さすがに数時間で Node.js を使いこなせるということはない。
321デフォルトの名無しさん (アウアウウー Sa47-hJvz)
2023/02/03(金) 00:44:48.46ID:7WbTLk8Ha quoraとか知恵袋とかブログで「Cの次はC++をやればオブジェクト指向身について更にCから派生した言語が主流だからどんな言語も直ぐ理解できる」みたいなの多いよ
だからこのスレの人達ならNode.jsも余裕なのかなって
>>320
学ぶ過程の色んな経験が生きるって事か。そりゃそうだよね
だからこのスレの人達ならNode.jsも余裕なのかなって
>>320
学ぶ過程の色んな経験が生きるって事か。そりゃそうだよね
322はちみつ餃子 ◆8X2XSCHEME (ワッチョイ e33e-fO7+)
2023/02/03(金) 01:31:41.47ID:cvg0vFRY0 >>321
JavaScript は C 風の外観を持ってこそいるけど動的型、かつ、プロトタイプベースであるという点で
根本的に異なるメカニズムなわけでこういうのを「C から派生」と呼んでよいのかどうか……。
JavaScript は C 風の外観を持ってこそいるけど動的型、かつ、プロトタイプベースであるという点で
根本的に異なるメカニズムなわけでこういうのを「C から派生」と呼んでよいのかどうか……。
323デフォルトの名無しさん (ワッチョイ 9af0-2biX)
2023/02/03(金) 07:32:32.82ID:gaR1XNY40 よく使う言語と比べて在るもの無いもの違うわけで
ちゃんと理解しようとしたらそれなりに時間がかかるでしょ
気軽に使いこなすとか言葉にしてると怖いおじさんに怒られるぞ
ちゃんと理解しようとしたらそれなりに時間がかかるでしょ
気軽に使いこなすとか言葉にしてると怖いおじさんに怒られるぞ
324デフォルトの名無しさん (ワッチョイ 5f10-3kgq)
2023/02/03(金) 08:03:03.43ID:HPBiMoRp0 そもそも理解しやすいと使いこなせるは別の概念やろ
325デフォルトの名無しさん (ワッチョイ e76b-N2mU)
2023/02/03(金) 09:08:55.43ID:b6b2xU8/0 vector<int>& a = c, b = c;
としたときに、bがcの参照になりませんでした。
&が後ろにかかるからかと思って
vector<int> &a = c, &b = c;
としても結果が変わりませんでした。
vector<int> &a = c;
vector<int> &b = c;
とすればやっと期待通りの動作になりました。
参照の宣言と初期化は複数をカンマで区切って一行で書くことは不可能なのでしょうか?
としたときに、bがcの参照になりませんでした。
&が後ろにかかるからかと思って
vector<int> &a = c, &b = c;
としても結果が変わりませんでした。
vector<int> &a = c;
vector<int> &b = c;
とすればやっと期待通りの動作になりました。
参照の宣言と初期化は複数をカンマで区切って一行で書くことは不可能なのでしょうか?
326デフォルトの名無しさん (ワッチョイ 83da-lkW6)
2023/02/03(金) 09:24:27.07ID:GSbNqAeQ0 え?コンパイラなに使ったの?
> vector<int> &a = c, &b = c;
> としても結果が変わりませんでした。
処理系ぶっ壊れてんのかな
> vector<int> &a = c, &b = c;
> としても結果が変わりませんでした。
処理系ぶっ壊れてんのかな
327デフォルトの名無しさん (ラクッペペ MMb6-Go++)
2023/02/03(金) 12:28:10.97ID:31rfnruOM c言語スレで質問したのですが
スレ違いとのことでしたので
改めて質問致します。
c言語の標準入出力ストリームの
本当に基本的なことなんですが
わからずに困っています。
教えてください。
std::ofstream stream;
ostream << "ABCEFG";
この入力した文字列の"ABCEFG"を
右側3文字を削除して"ABC"にするには
どうすれば良いのでしょうか?
スレ違いとのことでしたので
改めて質問致します。
c言語の標準入出力ストリームの
本当に基本的なことなんですが
わからずに困っています。
教えてください。
std::ofstream stream;
ostream << "ABCEFG";
この入力した文字列の"ABCEFG"を
右側3文字を削除して"ABC"にするには
どうすれば良いのでしょうか?
328デフォルトの名無しさん (ワッチョイ 0b01-Z6M9)
2023/02/03(金) 12:36:10.39ID:l5lsJ9Ru0 カーソルをEのところに持ってきてDeleteキーを3回押す
またはカーソルをGの右の"の上に移動してBSキーを3回押す
またはカーソルをGの右の"の上に移動してBSキーを3回押す
329デフォルトの名無しさん (オイコラミネオ MM63-ZqoR)
2023/02/03(金) 13:21:17.85ID:cQeyOYIBM330デフォルトの名無しさん (オイコラミネオ MM63-ZqoR)
2023/02/03(金) 13:24:04.52ID:cQeyOYIBM >>329
[補足]
std::string str = "文字列";
の場合、
str.substr(開始位置, 取り出す長さ);
で部分文字列を作れるので、
std::string str = "ABCEFG";
の場合、
std::string str2 = str.substr(0, 3);
で str2 に "ABC" が入る。
[補足]
std::string str = "文字列";
の場合、
str.substr(開始位置, 取り出す長さ);
で部分文字列を作れるので、
std::string str = "ABCEFG";
の場合、
std::string str2 = str.substr(0, 3);
で str2 に "ABC" が入る。
331デフォルトの名無しさん (ラクッペペ MM4f-zLlH)
2023/02/04(土) 10:43:22.05ID:amDpu8JYM >>330
回答ありがとうございます。
あれから自分でも調べて
seekp()でファイル内位置を移動するなど
試してみたのですがうまくいきませんでした。
(修正の方向はあっていると思うのですが・・)
やはり>>330さんの言う通り、テキストの削除は難しくする
何かわかりませんがそういう思想があるみたいに感じました。
そこで自分も細かい編集は別に改めて行って
結果をまとめてstreamに出力する方法に切り替えました。
結果はOK、どうもありがとうございました。
tstring_t str = _T("ABCDEFG");
str.erase(str.size() - 3);
stream << str;
回答ありがとうございます。
あれから自分でも調べて
seekp()でファイル内位置を移動するなど
試してみたのですがうまくいきませんでした。
(修正の方向はあっていると思うのですが・・)
やはり>>330さんの言う通り、テキストの削除は難しくする
何かわかりませんがそういう思想があるみたいに感じました。
そこで自分も細かい編集は別に改めて行って
結果をまとめてstreamに出力する方法に切り替えました。
結果はOK、どうもありがとうございました。
tstring_t str = _T("ABCDEFG");
str.erase(str.size() - 3);
stream << str;
332デフォルトの名無しさん (ワッチョイ 4f01-hyUu)
2023/02/04(土) 11:10:24.50ID:e1OBQ9Uv0333デフォルトの名無しさん (アウアウウー Sa93-fxZT)
2023/02/04(土) 11:41:36.65ID:9C/WLP1pa >331
seekp seekg
tellp tellg
読み込み用と書き出し用でポインタが二つあるので
自分で思ってるのと違う場所になってるのかも
方向性はあってるはず
間違ってたらすまん子
seekp seekg
tellp tellg
読み込み用と書き出し用でポインタが二つあるので
自分で思ってるのと違う場所になってるのかも
方向性はあってるはず
間違ってたらすまん子
334デフォルトの名無しさん (ワッチョイ cf69-F1up)
2023/02/04(土) 14:37:50.00ID:cBqi3lSD0 >結果をまとめてstreamに出力する
これで済むなら、これこそが正道
必要のない出力をして後から切り詰めるなんて愚の骨頂
そうしなきゃならない理由があるならしょうがないけど
これで済むなら、これこそが正道
必要のない出力をして後から切り詰めるなんて愚の骨頂
そうしなきゃならない理由があるならしょうがないけど
335デフォルトの名無しさん (スッププ Sd5f-340S)
2023/02/04(土) 16:23:00.83ID:12Q26erYd >>331
テキストじゃなくてファイルの削除でしょ
そういう細かい言い間違いが多いから伝わりにくい文章になってると思う
ファイルに出力する前にメモリー上で編集済ますのは当たり前でファイルアクセスにはメモリよりも時間がかかるから
そういった基本を知ってたほうがいいプログラムを作れるよ
テキストじゃなくてファイルの削除でしょ
そういう細かい言い間違いが多いから伝わりにくい文章になってると思う
ファイルに出力する前にメモリー上で編集済ますのは当たり前でファイルアクセスにはメモリよりも時間がかかるから
そういった基本を知ってたほうがいいプログラムを作れるよ
336デフォルトの名無しさん (ラクッペペ MM4f-lcFY)
2023/02/04(土) 17:43:09.03ID:amDpu8JYM337デフォルトの名無しさん (アウアウウー Sa93-3Nzt)
2023/02/04(土) 17:45:16.88ID:NGTrSsWja アホの謎の上から目線
338デフォルトの名無しさん (スッププ Sd5f-340S)
2023/02/04(土) 19:15:57.04ID:EmptyAuWd >>336
ひょっとしてファイル上に出力した状態をテキストと呼んでるのか
メモリ上かファイル上かの区別でそんな呼び方はしない
思想とかじゃなくてメモリとファイルにはそういう性質があるってだけ
早とちりの激しい人のようだな
ひょっとしてファイル上に出力した状態をテキストと呼んでるのか
メモリ上かファイル上かの区別でそんな呼び方はしない
思想とかじゃなくてメモリとファイルにはそういう性質があるってだけ
早とちりの激しい人のようだな
339デフォルトの名無しさん (ワッチョイ 4f01-mMLA)
2023/02/04(土) 19:36:14.65ID:YYLIzwcR0 お前も人に言い間違い云々とか言う前にファイルの削除とか書くなよ...
せめてファイルのテキストから削除とか書かないと意味わからんだろ
せめてファイルのテキストから削除とか書かないと意味わからんだろ
340デフォルトの名無しさん (ラクッペペ MM4f-zLlH)
2023/02/04(土) 19:47:05.93ID:amDpu8JYM >>338
いや全然違うよ、もっと基礎的な話で
C言語の標準入出力ストリームでのテキスト出力の話をしているの。
(C++の文字列クラス std::stringとはまた別)
>>327の
ostream << "ABCEFG";
はテキストの書き込み処理だけど、
これをやっても内部のバッファに書き込まれるだけで
HDDファイルなどの真の書き込み先には書き込まれないの。
//ostream << std::fflush;
仮に上の関数を呼ぶことで初めてHDDファイルなどに書き込まれるの。
んで、入力されてまだフラッシュされていない文字列"ABCEFG"を
右側3文字を削除して"ABC"にするには
どうすれば良いのでしょうか?
ってのが私の質問なんです。
OK?
いや全然違うよ、もっと基礎的な話で
C言語の標準入出力ストリームでのテキスト出力の話をしているの。
(C++の文字列クラス std::stringとはまた別)
>>327の
ostream << "ABCEFG";
はテキストの書き込み処理だけど、
これをやっても内部のバッファに書き込まれるだけで
HDDファイルなどの真の書き込み先には書き込まれないの。
//ostream << std::fflush;
仮に上の関数を呼ぶことで初めてHDDファイルなどに書き込まれるの。
んで、入力されてまだフラッシュされていない文字列"ABCEFG"を
右側3文字を削除して"ABC"にするには
どうすれば良いのでしょうか?
ってのが私の質問なんです。
OK?
341デフォルトの名無しさん (ワッチョイ 3ff0-EOzK)
2023/02/04(土) 20:05:08.56ID:NNW9UvjL0 std::printってなんすか?鬱陶しいstream要らなくなりますか??
342デフォルトの名無しさん (ワッチョイ 0f7c-m47a)
2023/02/04(土) 20:22:02.19ID:Uc49lFdn0 >>340
std::flushは呼び出し後にバッファがフラッシュされることを保証するだけで、書き込みをするタイミングは未規定(pstreamの勝手)
ostreamはoperator<<が呼ばれたそばから全部書き出してもいいし、バッファを半分ずつとか書き出してもいいしそれはostreamの自由
「入力されてまだフラッシュされていない」なんていう状態はostreamが教える義理はないし真っ当な方法では外からは観測できないしするべきでもない
ましてそれを弄くろうなんて考えるのがカプセル化を無視した間違った考え方だ
std::flushは呼び出し後にバッファがフラッシュされることを保証するだけで、書き込みをするタイミングは未規定(pstreamの勝手)
ostreamはoperator<<が呼ばれたそばから全部書き出してもいいし、バッファを半分ずつとか書き出してもいいしそれはostreamの自由
「入力されてまだフラッシュされていない」なんていう状態はostreamが教える義理はないし真っ当な方法では外からは観測できないしするべきでもない
ましてそれを弄くろうなんて考えるのがカプセル化を無視した間違った考え方だ
343デフォルトの名無しさん (ワッチョイ 7fbb-jaVN)
2023/02/04(土) 20:26:28.53ID:b1h/gALG0 なんだろね。std::formatだけでは効率が悪かったのかな?
344デフォルトの名無しさん (オイコラミネオ MM03-IoIL)
2023/02/04(土) 20:26:47.52ID:KFFsFRScM >>340
C++のSTLには、ファイルではないstreamの中に、そういう機能を持つものがあり、
atoi()の代わりに用いる例が出ていた。
それは入力と出力が可能なstreamで、文字列を出力しておいて、整数型として
入力することが出来る。
それが出来るということは、語尾を削除することも出来そう。
C++のSTLには、ファイルではないstreamの中に、そういう機能を持つものがあり、
atoi()の代わりに用いる例が出ていた。
それは入力と出力が可能なstreamで、文字列を出力しておいて、整数型として
入力することが出来る。
それが出来るということは、語尾を削除することも出来そう。
345デフォルトの名無しさん (オイコラミネオ MM03-IoIL)
2023/02/04(土) 20:59:53.67ID:KFFsFRScM 全く確認できてないが、。
stringstring s;
s << "ABCDEF";
string s2;
s >> setw(3) >> s2;
で s2 に "ABC" が読み込めるかもしれない。
誰か確認して候。
stringstring s;
s << "ABCDEF";
string s2;
s >> setw(3) >> s2;
で s2 に "ABC" が読み込めるかもしれない。
誰か確認して候。
346デフォルトの名無しさん (ワッチョイ 4f01-hyUu)
2023/02/04(土) 21:06:47.02ID:e1OBQ9Uv0347デフォルトの名無しさん (オイコラミネオ MM03-IoIL)
2023/02/04(土) 21:10:37.97ID:KFFsFRScM >>345
[追加]
(2)
std::ofstream ostream;
ostream << setw(3) << "ABCEFG";
(3) C++ 20 以降限定になるが、
std::format() を使う。
[追加]
(2)
std::ofstream ostream;
ostream << setw(3) << "ABCEFG";
(3) C++ 20 以降限定になるが、
std::format() を使う。
348デフォルトの名無しさん (ワッチョイ 3fad-t53W)
2023/02/04(土) 21:44:35.26ID:J5X2r1Ng0 >>340
>んで、入力されてまだフラッシュされていない文字列"ABCEFG"を
>右側3文字を削除して"ABC"にするには
>どうすれば良いのでしょうか?
"ABC"しか入力(ストリームに対する出力)されないようにするのが筋じゃねえの?
何がしたいのか
>んで、入力されてまだフラッシュされていない文字列"ABCEFG"を
>右側3文字を削除して"ABC"にするには
>どうすれば良いのでしょうか?
"ABC"しか入力(ストリームに対する出力)されないようにするのが筋じゃねえの?
何がしたいのか
349デフォルトの名無しさん (アウアウエー Sabf-FmQs)
2023/02/04(土) 21:50:32.61ID:b6Tm4pTJa そういう感じの質問こそAIに聞くと的確な答が返ってきそう
■ このスレッドは過去ログ倉庫に格納されています
ニュース
- 橋下徹氏 外務省幹部の訪中受け「口だけ番長」へ痛烈指摘 「喧嘩は日本の完敗…なんとかっこ悪い日本か」 [冬月記者★]
- 【外国人問題】小野田紀美担当相「不法就労や不法滞在は許さない」 [シャチ★]
- 【野球】井端監督 大谷翔平、山本由伸らのWBCへの参加 「1日も早く返事ほしい」「待っててといっても、国内組が遅くなってしまう」★3 [冬月記者★]
- 経団連会長、日中は建設的対話を 経済3団体が高市首相と初会談も日中関係は話題に登らず… [BFU★]
- 中国で「クレしん」公開延期 対日報復、エンタメに波及 [蚤の市★]
- 東京株式市場 インバウンド関連株が下落 中国政府の渡航自粛要請で [バイト歴50年★]
- 🏡
- 高校のうちにガチでセックスできる可能性あったのに逃した俺は負け組
- 有識者「高市総理が発言を撤回したり、辞職するしかないと言っている人は、それで日中関係が今まで通りになると思ってる?」 [834922174]
- 戦争は無くならないし殺人は起きるし女はレイプされるし子供は餓死するし
- スマホってスクリーントーンみにくくね?
- 日経時間外、5万円割れ 垂直落下始まる [402859164]
