エスケープシーケンスやWin32APIなどの環境依存なものもOK
そのような質問は必ず環境を書きましょう
半角空白やタブでのインデントはスレに貼ると無くなります
コードを貼れる所
http://codepad.org/
https://ideone.com/
前スレ
【初心者歓迎】C/C++室 Ver.105【環境依存OK】
https://mevius.5ch.net/test/read.cgi/tech/1556142878/
【初心者歓迎】C/C++室 Ver.106【環境依存OK】
■ このスレッドは過去ログ倉庫に格納されています
2020/07/13(月) 13:51:48.09ID:WBkWHxcT
2020/07/31(金) 02:35:13.36ID:E2vmFTLm
そうだね
というか最初はbegin=endだから、findで一度もループ処理が発生しないだけ
というか最初はbegin=endだから、findで一度もループ処理が発生しないだけ
2020/07/31(金) 08:38:17.94ID:UG/y1RVK
2020/07/31(金) 10:00:44.09ID:zHNUGG0v
72デフォルトの名無しさん
2020/07/31(金) 11:04:11.23ID:N0eufbNj #include <vector>
#include <algorithm>
#include <iostream>
int main() {
std::vector<int>vec;
vec.reserve(10);
auto result = std::find(vec.begin(), vec.end(),3);
std::vector<int>vec2;
vec2.resize(10);
auto result2 = std::find(vec2.begin(), vec2.end(),3);
return 0;
}
#include <algorithm>
#include <iostream>
int main() {
std::vector<int>vec;
vec.reserve(10);
auto result = std::find(vec.begin(), vec.end(),3);
std::vector<int>vec2;
vec2.resize(10);
auto result2 = std::find(vec2.begin(), vec2.end(),3);
return 0;
}
2020/08/04(火) 14:37:50.75ID:Rtr7oft5
boostっていうやつはもう下火なんですか?
74はちみつ餃子 ◆8X2XSCHEME
2020/08/04(火) 20:36:32.51ID:tYSlSmQK んなわけない
2020/08/04(火) 22:16:06.06ID:GxIT23CH
極力使わずに済ませたい
2020/08/05(水) 08:45:38.77ID:FS19WAoY
下火っていうか
調理場にあるラップのようなもので特に意識されることはないけど欠かすことのできないもの
でもラップを使った料理っていうとどうしてもお手軽感がぬぐえない
プロの調理師はこういうものはできるだけ人目につかないようにする
調理場にあるラップのようなもので特に意識されることはないけど欠かすことのできないもの
でもラップを使った料理っていうとどうしてもお手軽感がぬぐえない
プロの調理師はこういうものはできるだけ人目につかないようにする
2020/08/05(水) 12:41:11.56ID:2ArdD7yz
ラップは隠さんだろ
化調でどうよ
化調でどうよ
2020/08/06(木) 09:55:51.94ID:oJAb3tlF
聞き方が悪かった
boostは習熟したほうがいいですか?
boostは習熟したほうがいいですか?
2020/08/06(木) 10:17:16.18ID:5aD4OAJs
あなたのやりたいことに役立つのなら。
80デフォルトの名無しさん
2020/08/06(木) 11:01:09.05ID:6QU45l4b boostじゃなくても同じことが出来るものがあったら後者を選ぶな
なんでだろ自分でもわからんω
なんでだろ自分でもわからんω
81デフォルトの名無しさん
2020/08/06(木) 11:13:25.84ID:YI93igBY いまならasioなどのために使うのでは。
そしてネットワーキングTSが標準に入ると、また使わなくなる。
そういうサイクルがあるのでは。
そしてネットワーキングTSが標準に入ると、また使わなくなる。
そういうサイクルがあるのでは。
2020/08/07(金) 21:54:30.74ID:3kAM9W6f
>>42
win32api使うならTCHAR使いましょうよ
win32api使うならTCHAR使いましょうよ
2020/08/08(土) 02:45:50.43ID:sjyRGzAl
MBCS対応する気ないならTCHAR使う意味ないよ
MBCS_Support_Deprecated_In_MFCだし
MBCS_Support_Deprecated_In_MFCだし
2020/08/08(土) 07:16:16.82ID:f+HIJ1ud
WCHAR決め打ちで行くんならDrawTextWにしないと
85デフォルトの名無しさん
2020/08/08(土) 10:09:00.08ID:noFfmCPy2020/08/08(土) 11:52:52.81ID:xwl14JrI
じゃあ何使うか言え
2020/08/08(土) 12:49:23.95ID:jGasFcRb
ナウはQuattroかな
2020/08/08(土) 13:08:28.52ID:Lqpd9lsB
2020/08/08(土) 13:25:08.03ID:xwl14JrI
>>88
ありがとう
ありがとう
90デフォルトの名無しさん
2020/08/08(土) 15:09:16.42ID:OT1M6D8391デフォルトの名無しさん
2020/08/08(土) 15:39:24.58ID:pp0rnVLU92デフォルトの名無しさん
2020/08/08(土) 16:39:57.58ID:/RuHG5bH C++11の前はboostめっちゃ使ってました
93デフォルトの名無しさん
2020/08/08(土) 16:52:58.78ID:OT1M6D83 Debianがgcc8なのでfilesystemをboostのほう使うとか。
互換性が動機という場合もありますね。
互換性が動機という場合もありますね。
2020/08/08(土) 19:24:55.75ID:Sbg9T/ud
C++ の仕様に関する質問です。
OpenGL では、
typedef unsigned char GLboolean;
#define GL_FALSE 0
#define GL_TRUE 1
void glVertexAttribPointer (GLuint index, GLint size, GLenum type, GLboolean normalized,
GLsizei stride, const void *pointer);
となっていますが、
glVertexAttribPointer(locAttr, 3, GL_FLOAT, GL_FALSE, 8 * sizeof(float), (void*)0);
と書いた場合、第四引数の GL_FALSE は 0 なので、int 型の整数リテラル(32BIT)ですが、対応する仮引数は、
GLboolean 型(8BIT)となっています。
overload resolution で、best matching アルゴリズムで最適な関数を探す際、対象の関数のプロトタイプ宣言の仮引数の型と
実引数の型を比較して、1つでも型が不適格のものが見つかった場合、「viable function」ではないとみなされ、候補から除外されます。
例として、unsigned char 型の仮引数に、int 型の変数を渡そうとすれば、不適格に成り、その関数は対象から除外されます。
しかし、この場合の様に、0 や 1 という整定値ならどうなるでしょうか。つまり、
unsigend char 型の仮引数に int 型の整数であるところの 0 という整数リテラルが、「適合」するというのは、
正しい仕様でしょうか?
OpenGL では、
typedef unsigned char GLboolean;
#define GL_FALSE 0
#define GL_TRUE 1
void glVertexAttribPointer (GLuint index, GLint size, GLenum type, GLboolean normalized,
GLsizei stride, const void *pointer);
となっていますが、
glVertexAttribPointer(locAttr, 3, GL_FLOAT, GL_FALSE, 8 * sizeof(float), (void*)0);
と書いた場合、第四引数の GL_FALSE は 0 なので、int 型の整数リテラル(32BIT)ですが、対応する仮引数は、
GLboolean 型(8BIT)となっています。
overload resolution で、best matching アルゴリズムで最適な関数を探す際、対象の関数のプロトタイプ宣言の仮引数の型と
実引数の型を比較して、1つでも型が不適格のものが見つかった場合、「viable function」ではないとみなされ、候補から除外されます。
例として、unsigned char 型の仮引数に、int 型の変数を渡そうとすれば、不適格に成り、その関数は対象から除外されます。
しかし、この場合の様に、0 や 1 という整定値ならどうなるでしょうか。つまり、
unsigend char 型の仮引数に int 型の整数であるところの 0 という整数リテラルが、「適合」するというのは、
正しい仕様でしょうか?
2020/08/08(土) 20:40:58.31ID:jGasFcRb
その関数はCの関数なので、そもそもマンぐり返されてないし、より適合するオーバーロード関数の存在なんて考慮してないんじゃね?
2020/08/08(土) 21:31:49.81ID:Sl6pvmJG
2020/08/09(日) 00:18:25.48ID:5wTPapRC
>>96
確認しました。charの仮引数の場所に、int 変数を実引数にして渡しても、
エラーも警告も出ませんでした。
関数呼び出しだけでなく、
int i = 0x123456;
char c = i;
としてもエラーも警告も出ませんでした。
テストは、VS2019のC++で行いました。
確認しました。charの仮引数の場所に、int 変数を実引数にして渡しても、
エラーも警告も出ませんでした。
関数呼び出しだけでなく、
int i = 0x123456;
char c = i;
としてもエラーも警告も出ませんでした。
テストは、VS2019のC++で行いました。
98はちみつ餃子 ◆8X2XSCHEME
2020/08/09(日) 00:32:08.26ID:ayHdPpdd 整数型同士はどの組み合わせでも暗黙の型変換はされるんじゃね。
変換後の型が符号付きかつ、変換後の型が表現できる範囲に収まらない値だったときの挙動が未定義ではあるので、
狭い方向への変換のときに警告くらいは出してくれることもあるみたいだが、
オーバーロードの解決の際に排除されることはない。
変換後の型が符号付きかつ、変換後の型が表現できる範囲に収まらない値だったときの挙動が未定義ではあるので、
狭い方向への変換のときに警告くらいは出してくれることもあるみたいだが、
オーバーロードの解決の際に排除されることはない。
2020/08/09(日) 12:09:42.16ID:5wTPapRC
>>98
ついでに、お聞きしたいのですが、
class CBase {・・・};
class CDerived : public CBase {・・・};
の場合、
CDerive* ---> CBase*
への変換は標準変換は有りますが、
CBase* ---> CDerive*
への変換は標準変換は有りませんよね。
しかし、
CBase *pBase;
に対して、
(CDerived*)pBase
というcastは、down castであり、気をつけなければならないキャストではありますが、組み込みのcastとして、
どのコンパイラでもサポートしています。
(この場合、型の解釈の変更だけでなく、マシン語レベルでの生の値も、offset分だけ変更になることがあるのは
周知の通りです。)
ということは、標準変換ではないにも関わらず、キャストではなぜかサポートしていると言うことになるのでしょうか?
ついでに、お聞きしたいのですが、
class CBase {・・・};
class CDerived : public CBase {・・・};
の場合、
CDerive* ---> CBase*
への変換は標準変換は有りますが、
CBase* ---> CDerive*
への変換は標準変換は有りませんよね。
しかし、
CBase *pBase;
に対して、
(CDerived*)pBase
というcastは、down castであり、気をつけなければならないキャストではありますが、組み込みのcastとして、
どのコンパイラでもサポートしています。
(この場合、型の解釈の変更だけでなく、マシン語レベルでの生の値も、offset分だけ変更になることがあるのは
周知の通りです。)
ということは、標準変換ではないにも関わらず、キャストではなぜかサポートしていると言うことになるのでしょうか?
100デフォルトの名無しさん
2020/08/09(日) 12:11:08.88ID:q7SdW+2C >>97
viable function とか言うから規格上の確認がしたいのかと思ってたけど、そこは実験でいいのか。
viable function とか言うから規格上の確認がしたいのかと思ってたけど、そこは実験でいいのか。
101デフォルトの名無しさん
2020/08/09(日) 12:17:12.21ID:q7SdW+2C >>99
まずキャストが「標準変換」しか「サポート」しないというその前提はどこから出てきたのか示すのが先でしょ。
https://timsong-cpp.github.io/cppwp/n4861/expr.cast
まずキャストが「標準変換」しか「サポート」しないというその前提はどこから出てきたのか示すのが先でしょ。
https://timsong-cpp.github.io/cppwp/n4861/expr.cast
102デフォルトの名無しさん
2020/08/09(日) 12:26:51.20ID:5wTPapRC103デフォルトの名無しさん
2020/08/09(日) 12:29:59.88ID:5wTPapRC >>102
最後、何が言いたいかと言うと、
『「組み込みの変換」には、「標準変換」には含まれていない変換も含まれている。』
ということです。
CBase*--->CDerived*
は、「標準変換」には含まれていませんが、「組み込みの変換」には含まれているということです。
また、それとは別に、int--->charは、危険を招くことがあるにも関わらず、「標準変換」
に含まれてしまっていると言うことです。
最後、何が言いたいかと言うと、
『「組み込みの変換」には、「標準変換」には含まれていない変換も含まれている。』
ということです。
CBase*--->CDerived*
は、「標準変換」には含まれていませんが、「組み込みの変換」には含まれているということです。
また、それとは別に、int--->charは、危険を招くことがあるにも関わらず、「標準変換」
に含まれてしまっていると言うことです。
104デフォルトの名無しさん
2020/08/09(日) 13:40:09.55ID:3E+EuOxc CBase* は CDerived* から変換したものかもしれないから変換可能なのが自然だろう。アップキャストとは違って暗黙にはされないし。
C式のキャストはチェックは継承関係をチェックしないがC++のキャストはするしな。
C式のキャストはチェックは継承関係をチェックしないがC++のキャストはするしな。
105デフォルトの名無しさん
2020/08/09(日) 15:59:54.85ID:EBrjBl58 char と int は cast されてる訳じゃないからな
106デフォルトの名無しさん
2020/08/09(日) 18:28:19.40ID:5wTPapRC みなさま、色々と有難うございました。
今回はこれで質問を閉じたいと思います。
今回はこれで質問を閉じたいと思います。
107デフォルトの名無しさん
2020/08/11(火) 07:34:37.14ID:DHq4+2OG マンぐり返しってなんですか?
108デフォルトの名無しさん
2020/08/11(火) 14:53:04.07ID:RaTUar/r109デフォルトの名無しさん
2020/08/13(木) 15:42:03.16ID:Tr7DEHMo 初心者なんですけど、tupleって使ってますか?
110デフォルトの名無しさん
2020/08/13(木) 15:49:39.88ID:hDTlT7Ky tuple も tie も便利よ
111デフォルトの名無しさん
2020/08/13(木) 18:45:13.00ID:Mkk4UD94 tupleは型リストとして良く使うな
112デフォルトの名無しさん
2020/08/15(土) 00:15:34.53ID:VOQ0TGNs 回答ありがとうございます
使って人いて安心しました
使って人いて安心しました
113デフォルトの名無しさん
2020/08/15(土) 01:10:43.51ID:cZ2se/D1 自分は構造体で間に合ってるからまだタプルの恩恵に与ったことない
114デフォルトの名無しさん
2020/08/15(土) 19:36:08.85ID:YDp7CJXQ 超ド素人の質問ですみません。
https://stackoverflow.com/questions/18647965/createprocess-problems-when-using-proc-thread-attribute-preferred-node-or-proc-t
このURLのサンプルコードをコンパイルすると、以下のエラーが発生します。
引数の型がおかしいんでしょうか?
何が悪いのか?どう修正したら良いかわかりません。教えて下さい。
[bcc32c エラー] File1.cpp(37): no matching function for call to 'InitializeProcThreadAttributeList'
processthreadsapi.h(650): candidate function not viable: no known conversion from 'std::size_t *' (aka 'unsigned int *') to 'PSIZE_T' (aka 'unsigned long *') for 4th argument
このURLの中の質問者の現象の再現をしたいのです。
https://stackoverflow.com/questions/18647965/createprocess-problems-when-using-proc-thread-attribute-preferred-node-or-proc-t
このURLのサンプルコードをコンパイルすると、以下のエラーが発生します。
引数の型がおかしいんでしょうか?
何が悪いのか?どう修正したら良いかわかりません。教えて下さい。
[bcc32c エラー] File1.cpp(37): no matching function for call to 'InitializeProcThreadAttributeList'
processthreadsapi.h(650): candidate function not viable: no known conversion from 'std::size_t *' (aka 'unsigned int *') to 'PSIZE_T' (aka 'unsigned long *') for 4th argument
このURLの中の質問者の現象の再現をしたいのです。
115デフォルトの名無しさん
2020/08/15(土) 19:50:05.09ID:5gsdnDz9 読んだままだろ
cbの型が合っていないといっているからcbの型をSIZE_Tにすりゃ良いんでないかい
cbの型が合っていないといっているからcbの型をSIZE_Tにすりゃ良いんでないかい
116デフォルトの名無しさん
2020/08/15(土) 20:10:51.19ID:YDp7CJXQ ほうほう。で、どうやって?
言っとくが私はC言語をポインタで挫折した男だ!!
言っとくが私はC言語をポインタで挫折した男だ!!
117デフォルトの名無しさん
2020/08/15(土) 20:16:57.66ID:MrJ6yMOt PSIZE_Tとやらじゃね
main関数の中の
size_t cb;
これを
PSIZE_T cb;
にするだけ?
main関数の中の
size_t cb;
これを
PSIZE_T cb;
にするだけ?
118デフォルトの名無しさん
2020/08/15(土) 20:21:07.23ID:YDp7CJXQ >>117
ありがとう。
でもエラーが以下に変わっただけでした。
processthreadsapi.h(650): candidate function not viable: no known conversion from 'PSIZE_T *' (aka 'unsigned long *') to 'PSIZE_T' (aka 'unsigned long *') for 4th argument
ありがとう。
でもエラーが以下に変わっただけでした。
processthreadsapi.h(650): candidate function not viable: no known conversion from 'PSIZE_T *' (aka 'unsigned long *') to 'PSIZE_T' (aka 'unsigned long *') for 4th argument
119デフォルトの名無しさん
2020/08/15(土) 20:25:40.50ID:YDp7CJXQ あ、PSIZE_Tじゃなくて、SIZE_Tにしたら行けました!!
大文字小文字の間違いだったってことですか?
とにかくありがとうございました!!
大文字小文字の間違いだったってことですか?
とにかくありがとうございました!!
120デフォルトの名無しさん
2020/08/29(土) 01:18:06.72ID:2rJgngxa 変数やら関数にtemplate指定するのに一々上に記述するのが面倒なんですが、スコープ内で一括指定するみたいな記法ってありますか?
121デフォルトの名無しさん
2020/08/29(土) 01:27:39.26ID:ayWkdCf9 typedef HogeT<Fuga> Piyo;
とかこういうこと?
とかこういうこと?
122はちみつ餃子 ◆8X2XSCHEME
2020/08/29(土) 01:35:50.74ID:2JVy7qNC typedef でも害はないけどusing を使うのがモダンな方法やぞ。
C と共用するヘッダファイル (または C++11 未満の規格に従わざるを得ない場合) を除いては typedef を使う理由はもう無い。
C と共用するヘッダファイル (または C++11 未満の規格に従わざるを得ない場合) を除いては typedef を使う理由はもう無い。
123デフォルトの名無しさん
2020/08/29(土) 01:45:55.49ID:2rJgngxa template<typename foo>
foo bar[256];
template<typename foo>
foo baz();
を仮に
template<typename foo>{
foo bar[256];
foo baz();
}
みたいな感じで
foo bar[256];
template<typename foo>
foo baz();
を仮に
template<typename foo>{
foo bar[256];
foo baz();
}
みたいな感じで
124デフォルトの名無しさん
2020/08/29(土) 10:19:15.51ID:HmjSn9P9 foo bar[256], baz();
125デフォルトの名無しさん
2020/08/30(日) 16:59:19.60ID:6dVOYYO/ 列挙型を宣言した後に構造体型で列挙型の変数を作成、
列挙型の変数はキーボードから入力できないので、構造体型にキーボードから入力するための変数を作成、
その値によって列挙型の変数に代入、
動的にメモリを確保して列挙型を入力、後に出力
これが上手く動作しないです助けてください
列挙型の変数はキーボードから入力できないので、構造体型にキーボードから入力するための変数を作成、
その値によって列挙型の変数に代入、
動的にメモリを確保して列挙型を入力、後に出力
これが上手く動作しないです助けてください
126デフォルトの名無しさん
2020/08/30(日) 17:04:48.88ID:6Ogy6ZZb コード晒せよ
127デフォルトの名無しさん
2020/08/30(日) 17:18:07.67ID:6dVOYYO/ #include<iostream>
using namespace std;
enum Type{Tec, Des, NA};
struct Human{
Type type;
char ans;
};
int n; char* pA;
void dataInput(Type& tp){
for(int i=0;i<n;i++){
cin>>tp.ans;
pA[i]=tp.ans;}
}
void showData(Type& tp);
int main(){
cin>>n;
pA=new char[n];
Type tp;
dataInput(tp);
showData(tp);
return 0;}
void showData(Type& tp){
for(int j=0;j<n;j++){
cout << pA[j] << "\n";}
}
using namespace std;
enum Type{Tec, Des, NA};
struct Human{
Type type;
char ans;
};
int n; char* pA;
void dataInput(Type& tp){
for(int i=0;i<n;i++){
cin>>tp.ans;
pA[i]=tp.ans;}
}
void showData(Type& tp);
int main(){
cin>>n;
pA=new char[n];
Type tp;
dataInput(tp);
showData(tp);
return 0;}
void showData(Type& tp){
for(int j=0;j<n;j++){
cout << pA[j] << "\n";}
}
128デフォルトの名無しさん
2020/08/30(日) 17:35:41.30ID:7nTpFOtc129デフォルトの名無しさん
2020/08/30(日) 17:52:49.59ID:sTqYAgvH 複数のLEDをリズミカルに光らせるプログラムを書いております。
現在は赤、青2色で色々遊んでおります。
'' __delay_ms(100);''
って感じの関数(用語?)を覚えまして、各パート毎に点灯時間、消灯時間を打ち込みました。
で、実行してみた所、1パートの青LEDが全て点滅し終わった後で2パートの赤LEDの
点滅に移る形になってしまいました。
赤、青LEDには各1個づつPICマイコンのピンを振ってありますので
スタティック制御ができるんだと思いますが、その制御(点滅)を同時に開始出来る
文(?)を教えて頂きたいと思います。
よろしくお願いします。
現在は赤、青2色で色々遊んでおります。
'' __delay_ms(100);''
って感じの関数(用語?)を覚えまして、各パート毎に点灯時間、消灯時間を打ち込みました。
で、実行してみた所、1パートの青LEDが全て点滅し終わった後で2パートの赤LEDの
点滅に移る形になってしまいました。
赤、青LEDには各1個づつPICマイコンのピンを振ってありますので
スタティック制御ができるんだと思いますが、その制御(点滅)を同時に開始出来る
文(?)を教えて頂きたいと思います。
よろしくお願いします。
130デフォルトの名無しさん
2020/08/30(日) 17:59:55.82ID:GgAZZaQa131デフォルトの名無しさん
2020/08/30(日) 18:03:01.59ID:GgAZZaQa >>129
PICの質問なら電気電子板の方が良いぞ
PICの質問なら電気電子板の方が良いぞ
132デフォルトの名無しさん
2020/08/30(日) 18:11:43.57ID:bozI2ZZf tp.ansで入力された値によって対応した識別子を出力させたいのですが、charでは1文字しか出力できないので手詰まりになってます。どなたかご助言頂けないでしょうか。
133デフォルトの名無しさん
2020/08/30(日) 18:26:31.79ID:zSKZhw1k >>132 これじゃダメ?
#include <iostream>
#include <string_view>
enum class Type{ Tec, Des, NA };
struct Human{ Type type; }
Type to_type(std::string_view s) noexcept {
if (s == "Tec") : return Type::Tec;
if (s == "Des") : return Type::Des;
// Expects(s == "NA");
return Type::NA;
}
std::string to_string(Type t) {
if (t == Type::Tec) return "Tec";
if (t == Type::Des) return "Des";
return "NA";
}
int main() {
int n; std::cin >> n; // サイズとか要らないので読み飛ばす
std::string str;
std::cin >> str;
auto data = to_type(str); // 列挙型にして保持
std::cout >> to_string(data) >> '\n'; // 文字列型にして出力
}
#include <iostream>
#include <string_view>
enum class Type{ Tec, Des, NA };
struct Human{ Type type; }
Type to_type(std::string_view s) noexcept {
if (s == "Tec") : return Type::Tec;
if (s == "Des") : return Type::Des;
// Expects(s == "NA");
return Type::NA;
}
std::string to_string(Type t) {
if (t == Type::Tec) return "Tec";
if (t == Type::Des) return "Des";
return "NA";
}
int main() {
int n; std::cin >> n; // サイズとか要らないので読み飛ばす
std::string str;
std::cin >> str;
auto data = to_type(str); // 列挙型にして保持
std::cout >> to_string(data) >> '\n'; // 文字列型にして出力
}
134デフォルトの名無しさん
2020/08/30(日) 20:44:11.23ID:bozI2ZZf135デフォルトの名無しさん
2020/08/31(月) 10:54:44.11ID:pX0ZQbZW auto は甘え
136デフォルトの名無しさん
2020/09/03(木) 14:13:37.77ID:PYkyhK1l mainのスレッドをCPUハグなしに無限に一時停止しておく方法はありますか?
137デフォルトの名無しさん
2020/09/03(木) 14:26:19.18ID:DK3Ul6vK ハゲ
138デフォルトの名無しさん
2020/09/04(金) 12:14:12.72ID:zd548qQ8 >>136
目いっぱいsleep_forしてループで回す
目いっぱいsleep_forしてループで回す
139デフォルトの名無しさん
2020/09/05(土) 12:38:00.42ID:wi57tP1l >>136
無限に実行されるサブスレッドの終了を待つ。
無限に実行されるサブスレッドの終了を待つ。
140デフォルトの名無しさん
2020/09/06(日) 09:31:49.54ID:2h7jeAag mainからWinMainを呼ぶことも可能
WinMainが動いてる間はmainは止まってるよ
強制的に一時停止させるならPauseキー
WinMainが動いてる間はmainは止まってるよ
強制的に一時停止させるならPauseキー
141デフォルトの名無しさん
2020/09/07(月) 16:47:36.61ID:I5P3h+Uu cmakelistsでメモリ関連の設定の仕方をご教授いただけないでしょうか。
142デフォルトの名無しさん
2020/09/08(火) 00:01:30.52ID:vx/b5nCh >>141
もっと具体的に
もっと具体的に
143デフォルトの名無しさん
2020/09/08(火) 03:22:53.47ID:jacy6RM2 マルチっぽい
144デフォルトの名無しさん
2020/09/10(木) 22:29:57.24ID:XqO8hjOE >>141
はい
はい
145デフォルトの名無しさん
2020/09/19(土) 19:53:45.14ID:k5fZduun linuxでvswprint()使ってみたんだが、事前に必要なバッファサイズがわからない場合の求め方がわからん。
1. vsnprintf() と同じように nullptr を渡してみた
⇒必要サイズじゃなくてエラーの-1が返ってきた
2. 仮のサイズで呼び出して領域不足のエラーなら増やす方針にした
⇒エラーが領域不足なのか他のエラーなのか見分けがつかない(errno=0のまま)
どうすりゃいいんだろう?
1. vsnprintf() と同じように nullptr を渡してみた
⇒必要サイズじゃなくてエラーの-1が返ってきた
2. 仮のサイズで呼び出して領域不足のエラーなら増やす方針にした
⇒エラーが領域不足なのか他のエラーなのか見分けがつかない(errno=0のまま)
どうすりゃいいんだろう?
146デフォルトの名無しさん
2020/09/19(土) 19:54:59.55ID:k5fZduun ×vswprint()
〇vswprintf()
〇vswprintf()
147デフォルトの名無しさん
2020/09/19(土) 22:28:47.13ID:4o2U5hp6 cppreferenceにはエラーが消えるまで再確保&呼び出しやり直す必要があるかもねって書いてある
148デフォルトの名無しさん
2020/09/20(日) 03:23:25.61ID:Suv1r7e5 C++のコードを拾ってきてコンパイルしたら、構造体の初期化で non-trivial designated
initializers not supported というエラーになってしまいます。
例えば typedef struct _Hoge { int a; int b; int c; } Hoge; みたいなときに
Hoge hoge = { .b = 1, .c = 2, }; みたいにメンバーが省略されていると駄目のようです。
でも元のプロジェクトではコンパイルできてるっぽいです。
自分の側では諸般の事情(?)でg++ 7.5.0で-std=c++1zでコンパイルしています。
上記のエラーを避けるにはどういう方法があるでしょうか?
initializers not supported というエラーになってしまいます。
例えば typedef struct _Hoge { int a; int b; int c; } Hoge; みたいなときに
Hoge hoge = { .b = 1, .c = 2, }; みたいにメンバーが省略されていると駄目のようです。
でも元のプロジェクトではコンパイルできてるっぽいです。
自分の側では諸般の事情(?)でg++ 7.5.0で-std=c++1zでコンパイルしています。
上記のエラーを避けるにはどういう方法があるでしょうか?
149はちみつ餃子 ◆8X2XSCHEME
2020/09/20(日) 04:34:43.96ID:7quNJlhN >>148
C++ の規格としてその書き方が採用されたのは C++20 から。
(余談だが C だと C99 から出来る。)
それらの規格に準拠したコンパイラ (より新しいバージョンの g++) を用意するか、
でなければ古いスタイルの書き方で初期化するしかないという普通のことしか言えぬ。
C++ の規格としてその書き方が採用されたのは C++20 から。
(余談だが C だと C99 から出来る。)
それらの規格に準拠したコンパイラ (より新しいバージョンの g++) を用意するか、
でなければ古いスタイルの書き方で初期化するしかないという普通のことしか言えぬ。
150デフォルトの名無しさん
2020/09/20(日) 07:17:40.34ID:Suv1r7e5 >>149
どうもです。いえ、何かコンパイラーオプションとかあるのかなと思いまして。
ちなみに新しい書き方の場合
1. 全ての要素を
2. 宣言と同じ要素順序で初期化
しないといけない、で正解ですかね? 1.の縛りは未初期化要素を避けるため?
とりあえず Hoge hoge; hoge.b = 1; とか書き直して逃げておこうかと思います。
どうもです。いえ、何かコンパイラーオプションとかあるのかなと思いまして。
ちなみに新しい書き方の場合
1. 全ての要素を
2. 宣言と同じ要素順序で初期化
しないといけない、で正解ですかね? 1.の縛りは未初期化要素を避けるため?
とりあえず Hoge hoge; hoge.b = 1; とか書き直して逃げておこうかと思います。
151145
2020/09/20(日) 08:00:08.91ID:OXACXz1O152はちみつ餃子 ◆8X2XSCHEME
2020/09/20(日) 12:32:15.36ID:7quNJlhN >>150
> 1. 全ての要素を
いいえ。 要素の初期化を一部省略して書いた場合は
デフォルトメンバ初期化子 (があればそれ) で初期化するか
あたかも {} が与えられたかのようになります。
つまり >>148 の例でいえばデータメンバ a は 0 で初期化される
ことが保証されます。
> 2. 宣言と同じ要素順序で初期化
はい。 その通りです。
どうしてこのような制限を入れたのかきちんと議論をみたわけではありませんが、
コンストラクタのメンバ初期化子リストは自由な順序で書けるが
実際の初期化順序は宣言の順序になるというルールが微妙にイケてなかったことの
反省なんじゃないかなと想像します。
> 1. 全ての要素を
いいえ。 要素の初期化を一部省略して書いた場合は
デフォルトメンバ初期化子 (があればそれ) で初期化するか
あたかも {} が与えられたかのようになります。
つまり >>148 の例でいえばデータメンバ a は 0 で初期化される
ことが保証されます。
> 2. 宣言と同じ要素順序で初期化
はい。 その通りです。
どうしてこのような制限を入れたのかきちんと議論をみたわけではありませんが、
コンストラクタのメンバ初期化子リストは自由な順序で書けるが
実際の初期化順序は宣言の順序になるというルールが微妙にイケてなかったことの
反省なんじゃないかなと想像します。
153デフォルトの名無しさん
2020/09/22(火) 21:06:20.18ID:qIJInCqV gdb で、カレントディレクトリに .gdbinit を作って "b func" を記述したんですが、
funcが共有ライブラリの中にあると、funcがまだロードされてないので無視されますよね?
対話的に追加する場合はyを押して強制追加できますが、.gdbinit の中だとデフォでnが
選ばれるようです。.gdbinit の中での強制(自動)追加は可能でしょうか?
ちなみに ~/.gdbinit で add-auto-load-safe-path というのはやってあります。
ググったらありそうですが見つけられず... お願いします。
funcが共有ライブラリの中にあると、funcがまだロードされてないので無視されますよね?
対話的に追加する場合はyを押して強制追加できますが、.gdbinit の中だとデフォでnが
選ばれるようです。.gdbinit の中での強制(自動)追加は可能でしょうか?
ちなみに ~/.gdbinit で add-auto-load-safe-path というのはやってあります。
ググったらありそうですが見つけられず... お願いします。
154デフォルトの名無しさん
2020/09/23(水) 18:31:13.84ID:a8yFZa5Q 「C++には特にこれ!と言えるような入門書がない」という書き込みを見たのですが、そうだとしたらC++を習得した人は初学者のときどうやって技術を身につけていったのでしょうか?
155デフォルトの名無しさん
2020/09/23(水) 18:36:58.57ID:a8yFZa5Q 「ロベールのC++入門講座(ロベール著)」と「明解C++入門編(柴田望洋著)」を買ったけどこれでいいのかな…
156はちみつ餃子 ◆8X2XSCHEME
2020/09/23(水) 18:37:15.81ID:2N0Iktsg >>154
絶対確実というようなものは挙げられないけど、ほどほどのものはたくさんあるよ。
絶対確実というようなものは挙げられないけど、ほどほどのものはたくさんあるよ。
157デフォルトの名無しさん
2020/09/23(水) 18:37:48.29ID:avHWzJtR 1. 既に C を覚えて使いこなしてた
2. Eiffel を学んだ
3. C++ は better than C として使った
4. template を学んだ
5. Perl を学んだ
6. Python を学んだ
7. D を学んだ
8. C# 悪くないね
2. Eiffel を学んだ
3. C++ は better than C として使った
4. template を学んだ
5. Perl を学んだ
6. Python を学んだ
7. D を学んだ
8. C# 悪くないね
158はちみつ餃子 ◆8X2XSCHEME
2020/09/23(水) 18:45:30.79ID:2N0Iktsg >>155
C++ の規格はちょくちょく改定されてて、特に 2011 年の改定はインパクトが強かったんだ。
入門の範囲にすらいくらかの影響がある程度には。
それより古い本だと (今となっては) 不格好なスタイルになっているかもしれない。
C++ の規格はちょくちょく改定されてて、特に 2011 年の改定はインパクトが強かったんだ。
入門の範囲にすらいくらかの影響がある程度には。
それより古い本だと (今となっては) 不格好なスタイルになっているかもしれない。
159デフォルトの名無しさん
2020/09/23(水) 18:51:28.72ID:a8yFZa5Q >>158
私は、もう年を取ってもう新しい規格にはついていけないと悟ったので、せめて初心者のための本を買ってレビューする余生を過ごそうと思っています
そういえば江添本を放置してましたね、10/4 の資格試験が終わったら、あらためて江添本をレビューするつもりです
私は、もう年を取ってもう新しい規格にはついていけないと悟ったので、せめて初心者のための本を買ってレビューする余生を過ごそうと思っています
そういえば江添本を放置してましたね、10/4 の資格試験が終わったら、あらためて江添本をレビューするつもりです
161デフォルトの名無しさん
2020/09/28(月) 19:18:28.08ID:QruIJ5oN 今読んでいる入門書の例題です
時間計算機で9時45分の1時間25分後を計算するには以下のように入力します
945+125=
11:10
http://codepad.org/jOsbQgsX
ところが実行してみるとVC++では0:10、mingwでは0:70という結果が出ます
掲載されたソースと見比べても違いはないようなのでお手上げです
教えて下さい
時間計算機で9時45分の1時間25分後を計算するには以下のように入力します
945+125=
11:10
http://codepad.org/jOsbQgsX
ところが実行してみるとVC++では0:10、mingwでは0:70という結果が出ます
掲載されたソースと見比べても違いはないようなのでお手上げです
教えて下さい
162デフォルトの名無しさん
2020/09/28(月) 19:26:38.70ID:JgS2isID163デフォルトの名無しさん
2020/09/28(月) 19:30:48.89ID:JgS2isID あと、なんて本?
関数の戻り値型(関数名の前に書くintとかそういうやつ)を省略する入門書なんて珍しいから気になる
関数の戻り値型(関数名の前に書くintとかそういうやつ)を省略する入門書なんて珍しいから気になる
164はちみつ餃子 ◆8X2XSCHEME
2020/09/28(月) 20:34:20.88ID:VnC2vdM3 関数の返却値の型を省略すると int とみなされるのは C89 では保証された動作だったが C99 で廃止された。
だから古い本ならそれほど珍しいわけではない。
そんなに古い本をいまどき手にしてしまうってのはめずらしくはあるが。
だから古い本ならそれほど珍しいわけではない。
そんなに古い本をいまどき手にしてしまうってのはめずらしくはあるが。
165デフォルトの名無しさん
2020/09/28(月) 20:45:52.82ID:QruIJ5oN >>162
おっしゃるとおりでした、なぜかreturnの行を完全に打ち忘れました。
見直しの最中にも気づかず・・・
今読んでいるのは「はじめて読むC言語」という1991年の本で名著らしいです。
ネットで「はじめて読む8086」の後に続けて読めば理解が深まると言われ手に入れて読んでいます。
途中コンパイルが通らずさんざん頭を捻って拡張子をcppからcにしたら動くようになったりして
古い本で勉強するのはなかなか大変です。
ありがとうございました。
おっしゃるとおりでした、なぜかreturnの行を完全に打ち忘れました。
見直しの最中にも気づかず・・・
今読んでいるのは「はじめて読むC言語」という1991年の本で名著らしいです。
ネットで「はじめて読む8086」の後に続けて読めば理解が深まると言われ手に入れて読んでいます。
途中コンパイルが通らずさんざん頭を捻って拡張子をcppからcにしたら動くようになったりして
古い本で勉強するのはなかなか大変です。
ありがとうございました。
166はちみつ餃子 ◆8X2XSCHEME
2020/09/28(月) 23:29:53.28ID:VnC2vdM3 >>165
当時としては名著だったかもしれんが、仕様の改定はあるし、
周辺事情も変わっていくものなので古い資料で入門するのはだいぶん遠回りな気はするぞ。
C は最新規格でも歴史的事情を色々と引きずっているので古い規格から追っていくのも
無駄になるわけではないし、それを楽しめているならそれもよいけれど、
入門の段階で変な苦労を背負いこんで挫折するともったいないので
キツいと思ったら他の学び方もとれるということは覚えておいて欲しい。
当時としては名著だったかもしれんが、仕様の改定はあるし、
周辺事情も変わっていくものなので古い資料で入門するのはだいぶん遠回りな気はするぞ。
C は最新規格でも歴史的事情を色々と引きずっているので古い規格から追っていくのも
無駄になるわけではないし、それを楽しめているならそれもよいけれど、
入門の段階で変な苦労を背負いこんで挫折するともったいないので
キツいと思ったら他の学び方もとれるということは覚えておいて欲しい。
167デフォルトの名無しさん
2020/09/29(火) 06:25:09.45ID:jqf8qavY いやいや
.cpp を .c と間違えてコンパイル通らないってのは
古い本のせいじゃないぞ
あるあるだけど
.cpp を .c と間違えてコンパイル通らないってのは
古い本のせいじゃないぞ
あるあるだけど
168デフォルトの名無しさん
2020/09/29(火) 06:27:46.01ID:pVIW4ypp 世の中にはJavaとJavascript一緒にしてるひともいるからなー(棒)
169デフォルトの名無しさん
2020/09/29(火) 19:54:00.24ID:ME3902LM やさしいCとかはじめてのCとかを買えばいい
■ このスレッドは過去ログ倉庫に格納されています
ニュース
- 【いちご高騰】ヤマザキのクリスマスケーキ、いちご無し販売 [おっさん友の会★]
- ネット殺到「高市総理の責任」「完全に高市リスク」「負けるな」中国が水産物輸入停止→流石に総理批判の声も「どう責任取る?」 ★10 [樽悶★]
- 【日中対立】 朝日新聞のタイトル修正が中国逆ギレの火種か SNSで批判相次ぐ [♪♪♪★]
- 「ドラゴンボール」初の全世界キャラクター人気投票が開幕!212キャラからナンバーワンが決まる!! [ひかり★]
- 【音楽】『日本レコード大賞』各賞発表! 大賞候補にILLIT、M!LK、ふるっぱー、幾田りら、アイナ、ミセスら… 作詩賞は指原莉乃 [冬月記者★]
- 映画史上もっとも“スカッとする”結末の作品5選 [muffin★]
- 【すべてが】𝗮𝗺͜𝗮͉𝘇𝗼𝗻ブラックフライデーSALE総合【いいだろ!】 [194819832]
- ワイ刀オタ、欲しい刀が中々ネットで見つからず咽び泣く
- 【高市速報】日本人の3割「中国への武力行使に踏み切る必要がある」ANN世論調査 [931948549]
- 【訃報】日経平均先物逝く、円安株安債券安 [943688309]
- 2045年からきたけど質問ある?
- 【悲報】立憲岡田「間違った答弁をした高市総理に問題がある」→愛国者ブチギレ炎上 [834922174]
