C言語の話題のみ取り扱います C++の話題はC++スレへ
質問には最低限の情報(ソース/コンパイラ/OS)を付ける
数行で収まらないソースは以下を適当に使ってURLを晒す
https://paiza.io/
https://ideone.com/
http://codepad.org/
C11
http://www.open-std.org/jtc1/sc22/WG14/www/docs/n1570.pdf
C99
http://www.open-std.org/jtc1/sc22/WG14/www/docs/n1256.pdf
http://kikakurui.com/x3/X3010-2003-01.html
C FAQ 日本語訳
http://www.kouno.jp/home/c_faq/
JPCERT C コーディングスタンダード
https://www.jpcert.or.jp/sc-rules/
前
http://mevius.2ch.net/test/read.cgi/tech/1500293207/
http://www.geocities.jp/c_cpp_cs/about_c/
VIPQ2_EXTDAT: checked:vvvvv:1000:512:----: EXT was configured
探検
C言語なら俺に聞け 142 [無断転載禁止]©2ch.net
■ このスレッドは過去ログ倉庫に格納されています
1デフォルトの名無しさん 転載ダメ©2ch.net (ワッチョイ 8a6f-bDrV)
2017/08/10(木) 20:21:23.44ID:hEocmkh502017/09/27(水) 22:01:39.03ID:htvdQyi40
日頃の行い
2017/09/27(水) 22:08:30.48ID:6Zcxzpoi0
エラーのせろハゲ!
2017/09/27(水) 22:35:55.70ID:MZoqRzWL0
どうやってWndProcをフックするつもりなのか知らんが、初心者のやることじゃない
2017/09/27(水) 22:46:41.34ID:Ep3hxvTm0
スレチ
420デフォルトの名無しさん (ワッチョイ e523-d/1N)
2017/09/28(木) 00:13:55.27ID:LEgoP/Tm0 >>412
本当にそれがソースの全てか?
本当にそれがソースの全てか?
2017/09/28(木) 06:54:14.40ID:0QfR7+YkM
>>412
とりあえず文法エラーのないソースを出せよ
とりあえず文法エラーのないソースを出せよ
2017/09/28(木) 08:22:53.76ID:veeq8lRB0
>>415
windowsプログラムでFuckファックは初心者がやるものではない
何故かと言うとFuckファックは非常に拙いからで、これはご存じの通りにFuckファックつまりはセクロスとかセックスを意味する
FuckRawInputなどと書かれると非常に面食らうので、動作には全く関係ないがFuckファックの箇所をHookフックとする
Fookという間違いならまだしもFuckが出てくるのは途轍もなく拙い
windowsプログラムは入門書を一通り終えた後にようやく手を出せる程度に面倒くさい
windowsプログラムでFuckファックは初心者がやるものではない
何故かと言うとFuckファックは非常に拙いからで、これはご存じの通りにFuckファックつまりはセクロスとかセックスを意味する
FuckRawInputなどと書かれると非常に面食らうので、動作には全く関係ないがFuckファックの箇所をHookフックとする
Fookという間違いならまだしもFuckが出てくるのは途轍もなく拙い
windowsプログラムは入門書を一通り終えた後にようやく手を出せる程度に面倒くさい
2017/09/28(木) 12:17:20.62ID:wLxR5weia
最近勉強始めたんだがループ動作めんどくさ
2017/09/28(木) 16:28:25.85ID:p7vLxmpX0
C++の標準でWindowsのCOMみたいなのはできるの?
モジュールがあれば動的リンクできて、向こう側の関数の形式とエントリポイントがわかるような。
モジュールがあれば動的リンクできて、向こう側の関数の形式とエントリポイントがわかるような。
2017/09/28(木) 18:20:04.96ID:klqlvKrNM
2017/09/28(木) 19:27:04.11ID:te0QQW2V0
>>418-422
WndProcフックでは目的の動作できなくて、APIフックしか手がないと分かりましたので、
MSのdetourとかいうの使ったAPIフックに変更されました。改めて、見てください。
@やりたいこと
Rawinputマウス関数が呼び出させられる代わりDirectInputマウス関数を呼び出し、強制的にマウス操作をDirectInputにする
ソース↓
// APIhook_RawInput.c
#include <windows.h>
#include "detours.h"
hoge target = NULL; // ターゲットポインタ
hoge tp = NULL; //トランポリンポインタ
// 関数生成
BOOL WINAPI Direct_Input(HWND hWnd, UINT Msg, WPARAM wParam, LPARAM lParam) {
return tp(hWnd, Msg, wParam, lParam);
}
// user32インスタンス
HINSTANCE xxxxx;
case WM_CREATE:
//user32.DLLをロード
xxxxx = LoadLibrary("user32.dll");
//Raw Inputポインタ取得
target = (hoge) GetProcAddress(xxxxx, "WM_INPUT");
// WM_INPUTフック、"WM_INPUT"→"Direct_Input"置き換え
tp = (hoge) DetourFunction((PBYTE) target, (PBYTE) Direct_Input);
break;
// 終了時の処理
case WM_DESTROY:
// フック削除
DetourRemove((PBYTE) tp, (PBYTE) Direct_Input);
WndProcフックでは目的の動作できなくて、APIフックしか手がないと分かりましたので、
MSのdetourとかいうの使ったAPIフックに変更されました。改めて、見てください。
@やりたいこと
Rawinputマウス関数が呼び出させられる代わりDirectInputマウス関数を呼び出し、強制的にマウス操作をDirectInputにする
ソース↓
// APIhook_RawInput.c
#include <windows.h>
#include "detours.h"
hoge target = NULL; // ターゲットポインタ
hoge tp = NULL; //トランポリンポインタ
// 関数生成
BOOL WINAPI Direct_Input(HWND hWnd, UINT Msg, WPARAM wParam, LPARAM lParam) {
return tp(hWnd, Msg, wParam, lParam);
}
// user32インスタンス
HINSTANCE xxxxx;
case WM_CREATE:
//user32.DLLをロード
xxxxx = LoadLibrary("user32.dll");
//Raw Inputポインタ取得
target = (hoge) GetProcAddress(xxxxx, "WM_INPUT");
// WM_INPUTフック、"WM_INPUT"→"Direct_Input"置き換え
tp = (hoge) DetourFunction((PBYTE) target, (PBYTE) Direct_Input);
break;
// 終了時の処理
case WM_DESTROY:
// フック削除
DetourRemove((PBYTE) tp, (PBYTE) Direct_Input);
2017/09/28(木) 21:05:11.91ID:9JTfqDLya
>>426
で、お前が聞きたいのは「C言語」に関するどんな質問なんだ?
で、お前が聞きたいのは「C言語」に関するどんな質問なんだ?
2017/09/28(木) 22:00:23.65ID:kmv+HSxh0
>>421が悪い
責任もって相手しろ
責任もって相手しろ
2017/09/28(木) 22:01:12.32ID:kmv+HSxh0
>>419が正しい対応
2017/09/28(木) 23:13:22.30ID:hENZyM/7a
会話にすらなってないな。
こういうのホントにいるんだよなあ。、。
こういうのホントにいるんだよなあ。、。
2017/09/28(木) 23:59:03.21ID:mJZoGNOM0
2017/09/29(金) 01:12:28.71ID:tjqo0EG60
433デフォルトの名無しさん (ワッチョイ e523-d/1N)
2017/09/29(金) 01:17:32.92ID:EHQhOpQV0 >>426
本当にそれがソースの全てなのか?
本当にそれがソースの全てなのか?
434デフォルトの名無しさん (ワッチョイ 9baa-iHa+)
2017/09/30(土) 05:35:50.31ID:/O3sxKWS0 これ無理だろうWindowsプログラムの言語を理解してないと直せないっしょ
2017/10/02(月) 09:21:38.64ID:SGi8KvwU0
勘所がすぐつかめる人ならそうでもない
知らんOS知らん言語知らん環境でもデバッグできちゃうんだぜ
あいつら宇宙人だろ
知らんOS知らん言語知らん環境でもデバッグできちゃうんだぜ
あいつら宇宙人だろ
2017/10/02(月) 13:06:27.14ID:6IbuGwAs0
>16 :デフォルトの名無しさん:2006/03/10(金) 22:15:19
>>>10
>> こんな変数名があちこちに散らばっているのがPerl
>
>大学の研究室のボスは、特殊変数の表をふ~んと2分ほど眺めて完全に暗記した。
>
>そういうレベルの人たちのための言語なんだなと思って、トイレで血の涙を流した。
>>>10
>> こんな変数名があちこちに散らばっているのがPerl
>
>大学の研究室のボスは、特殊変数の表をふ~んと2分ほど眺めて完全に暗記した。
>
>そういうレベルの人たちのための言語なんだなと思って、トイレで血の涙を流した。
2017/10/03(火) 03:00:19.61ID:TSZxzm0B0
お助けください。
自作コードにおいて、以下の部分でmemsetの際にsegmentation faultになってしまいます。
int n = 2;
char charList[n+1][32]; // 32文字の文字列をn+1確保・・・①
func(charList); // charListに書き込む関数
for (int i = 0; i < n; ++i) memset(charList[i], ' ', 32); // 空白で埋めたい
funcを省いたりmemsetの前に適当にcharListをプリントしたりすると何故か問題なく動きます。
この部分だけ切り出したテストコードでは全く再現しませんでした。
この手のエラーでよくあるのは未初期化領域へのアクセスだと思いますが、
①で領域の確保はできているからこれは原因ではないですよね?
どこがエラーの原因でしょうか・・・?
自作コードにおいて、以下の部分でmemsetの際にsegmentation faultになってしまいます。
int n = 2;
char charList[n+1][32]; // 32文字の文字列をn+1確保・・・①
func(charList); // charListに書き込む関数
for (int i = 0; i < n; ++i) memset(charList[i], ' ', 32); // 空白で埋めたい
funcを省いたりmemsetの前に適当にcharListをプリントしたりすると何故か問題なく動きます。
この部分だけ切り出したテストコードでは全く再現しませんでした。
この手のエラーでよくあるのは未初期化領域へのアクセスだと思いますが、
①で領域の確保はできているからこれは原因ではないですよね?
どこがエラーの原因でしょうか・・・?
2017/10/03(火) 06:29:26.41ID:TvjHrbVD0
funcがnを壊してる
とか
とか
439デフォルトの名無しさん (ワッチョイ 4b32-HyX/)
2017/10/03(火) 06:57:44.74ID:ZkSEHHAS0 うん、funcが怪しい
440デフォルトの名無しさん (ワッチョイ e59f-Txnz)
2017/10/03(火) 08:24:29.85ID:759fwjeu0 うん
2017/10/03(火) 11:40:15.04ID:QFI8P6tG0
配列サイズ 32要素で 32個 空白で生めてるが
文字列 という用語を使ってるあたり func は一般の文字列操作してそうだけど
終端記号 '\0' の分の考慮が落ちてるんでないの?
文字列 という用語を使ってるあたり func は一般の文字列操作してそうだけど
終端記号 '\0' の分の考慮が落ちてるんでないの?
2017/10/03(火) 11:59:57.12ID:QFI8P6tG0
「文字列」で32文字を取り扱いたいのなら 33要素の器が必要ってことで
文字の配列なら問題ないけどねー
文字の配列なら問題ないけどねー
2017/10/03(火) 12:44:46.02ID:mP+8qDfMd
そもそも再現しないコードを提示されてもなあ
2017/10/03(火) 14:52:11.00ID:YUFfLdQY0
>>437
処理系は何じゃらほい
処理系は何じゃらほい
2017/10/03(火) 15:25:21.73ID:rugh+s9w0
2017/10/03(火) 15:27:20.07ID:xmgx6pPY0
int n = 2;
char charList[n+1][32];
C言語的に、これってOKだっけ?
char charList[n+1][32];
C言語的に、これってOKだっけ?
447デフォルトの名無しさん (ガックシ 06cb-huvM)
2017/10/03(火) 15:39:40.20ID:2Eoq+Ro56 >>446
だめ
だめ
448デフォルトの名無しさん (ワッチョイ 9be7-a1BF)
2017/10/03(火) 16:18:15.22ID:9r7sfmBO0 char charList[n+1,32]こうしないとダメだよね?なにかっこ二つ使ってんだよ読み込めねえよって昔2次元配列で怒られたな
2017/10/03(火) 16:39:41.13ID:uTLw0mNj0
>>446
最近は大丈夫になった
最近は大丈夫になった
450デフォルトの名無しさん (ワッチョイ 4b32-HyX/)
2017/10/03(火) 16:45:08.36ID:ZkSEHHAS0 うん、今の1回生が生まれた頃から
451デフォルトの名無しさん (ワッチョイ 9be7-a1BF)
2017/10/03(火) 18:25:07.16ID:9r7sfmBO0 >>449
なったのか少しは便利になったのか
なったのか少しは便利になったのか
2017/10/03(火) 18:27:21.85ID:eHwxQvGT0
最近どころか、20年近く前からだし
>>448みたいな文法は存在しないんだけど、どこの世界のC言語なんだろ
>>448みたいな文法は存在しないんだけど、どこの世界のC言語なんだろ
2017/10/03(火) 18:32:06.89ID:HgW0fxVo6
>>448みたいな文法欲しかった
2017/10/03(火) 18:48:25.91ID:9KgPFlPY0
>>449
最近、ダメかもしれなくなったんだが
最近、ダメかもしれなくなったんだが
455デフォルトの名無しさん (ワッチョイ 9be7-a1BF)
2017/10/03(火) 18:53:27.85ID:9r7sfmBO0 >>448
これダメだC#だった、エラーになるわ
これダメだC#だった、エラーになるわ
2017/10/03(火) 19:11:20.28ID:XytTuyvU0
LLVMの作者に物凄い勢いで嫌われたから…
457デフォルトの名無しさん (ササクッテロリ Spe1-3BEe)
2017/10/03(火) 22:39:06.25ID:djTGgeKPp iOS11にしたらまともに入力できない
このクソOS
このクソOS
458デフォルトの名無しさん (ササクッテロリ Spe1-3BEe)
2017/10/03(火) 22:39:07.29ID:djTGgeKPp iOS11にしたらまともに入力できない
このクソOS
このクソOS
459デフォルトの名無しさん (ササクッテロリ Spe1-3BEe)
2017/10/03(火) 22:46:23.61ID:djTGgeKPp このクソOS死ね
460デフォルトの名無しさん (ササクッテロリ Spe1-3BEe)
2017/10/03(火) 22:46:56.99ID:djTGgeKPp まともに入力できないって
461デフォルトの名無しさん (ワッチョイ e59f-d/1N)
2017/10/04(水) 00:38:32.06ID:JPTWWYYO02017/10/04(水) 01:30:41.39ID:+TP/cS/R0
463デフォルトの名無しさん (ワッチョイ 4b32-HyX/)
2017/10/04(水) 06:19:36.24ID:Sd/env2d02017/10/04(水) 06:24:24.64ID:dCjKMF950
二次元配列の宣言についての話で合って
コンパイルが通るかどうかだけの話なんてしてねーぞ
コンパイルが通るかどうかだけの話なんてしてねーぞ
2017/10/04(水) 07:22:39.57ID:zhlDARQmM
>>462
func何やってんの?
func何やってんの?
2017/10/04(水) 08:10:59.64ID:F93q6j3ba
*charList=0とかやってんじゃない?
2017/10/04(水) 08:22:11.58ID:F93q6j3ba
ってか二次元配列と二重配列間違ってねーか?
それとfunc呼んでからmemsetしたらfunc呼ぶ意味あるの?
memsetもループさせるんじゃなく一回で全部fillした方がよくない?
とかとか。
それとfunc呼んでからmemsetしたらfunc呼ぶ意味あるの?
memsetもループさせるんじゃなく一回で全部fillした方がよくない?
とかとか。
2017/10/04(水) 11:24:36.83ID:hBVSLcAId
2017/10/04(水) 13:29:31.00ID:ugGBRoRga
2017/10/04(水) 13:49:31.85ID:hBVSLcAId
>>469
funcの中身を知らないのに「意味無い」とか「意味あるの?」とかっていう書き込み、意味あるの?
それを聞けば問題の解決になるの?
少なくとも空白を埋めてない部分があるし
問題が発生する範囲で簡略化したのかもしれないし
当然意味があるから呼んでるんだろうと思うのが普通
funcの中身を知らないのに「意味無い」とか「意味あるの?」とかっていう書き込み、意味あるの?
それを聞けば問題の解決になるの?
少なくとも空白を埋めてない部分があるし
問題が発生する範囲で簡略化したのかもしれないし
当然意味があるから呼んでるんだろうと思うのが普通
2017/10/04(水) 14:20:16.63ID:Ot6iICCz0
C言語は俺に訊くなスレになってるな
2017/10/04(水) 14:30:40.85ID:eeE5kOTG0
最近オブジェクト指向が入り口で、C言語がわからんっていう子が多いからなあ
2017/10/04(水) 14:50:53.16ID:38WTG0/g0
再現する最小限のコードに削ってるうちに問題点を自ら発見して終了
2017/10/04(水) 14:54:54.68ID:PNa+p1hk0
つーかfunc()以外の部分で特に問題が見当たらないならfunc()のせいで確定という単純明快な話
自作コードならfunc()もうpできるっしょ
自作コードならfunc()もうpできるっしょ
2017/10/04(水) 14:56:07.21ID:6Zs0a9ZSa
>>470
出されたソースのコメント見ると、配列の考え方が間違ってるように感じるけどね。それを示唆したかっただけだよ。
出されたソースのコメント見ると、配列の考え方が間違ってるように感じるけどね。それを示唆したかっただけだよ。
2017/10/04(水) 15:12:09.84ID:f7rOF4qk0
2017/10/04(水) 16:34:23.23ID:hBVSLcAId
2017/10/04(水) 16:35:46.39ID:hBVSLcAId
あとはfuncの中身を見ないとなんとも
組み込みのショボい環境だとスタックオーバーフローって可能性も無いことは無いが
組み込みのショボい環境だとスタックオーバーフローって可能性も無いことは無いが
479デフォルトの名無しさん (ワッチョイ 35d2-asy+)
2017/10/04(水) 16:51:26.35ID:+admsRHQ0 struct I2C_MEM //構造体の型宣言
{
char DEV_ADR ;
char REG_ADR ;
char DATA[0x03] ;
};
struct I2C_MEM I2C_MEM[3] =//構造体の型宣言
{
{ 0x7C , 0x01 , 0x00000000 }
{ 0x7C , 0x01 , 0x00000000 }
{ 0x7C , 0x01 , 0x00000000 }
} ;
{
char DEV_ADR ;
char REG_ADR ;
char DATA[0x03] ;
};
struct I2C_MEM I2C_MEM[3] =//構造体の型宣言
{
{ 0x7C , 0x01 , 0x00000000 }
{ 0x7C , 0x01 , 0x00000000 }
{ 0x7C , 0x01 , 0x00000000 }
} ;
480デフォルトの名無しさん (ワッチョイ 35d2-asy+)
2017/10/04(水) 16:56:16.34ID:+admsRHQ0 ↑構造体の初期化で
charを連続4byte設定するときの書き方
0x00000000はたぶん違いますよね?
どう書けば良いんですか?
初心者過ぎてすいません
charを連続4byte設定するときの書き方
0x00000000はたぶん違いますよね?
どう書けば良いんですか?
初心者過ぎてすいません
481デフォルトの名無しさん (ワッチョイ 35d2-asy+)
2017/10/04(水) 16:59:03.20ID:+admsRHQ0 struct I2C_MEM //構造体の型宣言
{
char DEV_ADR ;
char REG_ADR ;
char DATA[0x03] ;
};
struct I2C_MEM I2C_MEM[3] = //構造体の初期化
{
{ 0x7C , 0x01 , 0x00000000 }
{ 0x7C , 0x02 , 0x00000000 }
{ 0x7C , 0x03 , 0x00000000 }
} ;
{
char DEV_ADR ;
char REG_ADR ;
char DATA[0x03] ;
};
struct I2C_MEM I2C_MEM[3] = //構造体の初期化
{
{ 0x7C , 0x01 , 0x00000000 }
{ 0x7C , 0x02 , 0x00000000 }
{ 0x7C , 0x03 , 0x00000000 }
} ;
2017/10/04(水) 17:01:20.64ID:HMkkIXOid
>>479
> struct I2C_MEM
> {
> char DEV_ADR ;
> char REG_ADR ;
> char DATA[0x03] ;
> };
struct I2C_MEM I2C_MEM[3] =
{
{ 0x7C , 0x01 , {0} }
{ 0x7C , 0x01 , {0} }
{ 0x7C , 0x01 , {0} }
} ;
> struct I2C_MEM
> {
> char DEV_ADR ;
> char REG_ADR ;
> char DATA[0x03] ;
> };
struct I2C_MEM I2C_MEM[3] =
{
{ 0x7C , 0x01 , {0} }
{ 0x7C , 0x01 , {0} }
{ 0x7C , 0x01 , {0} }
} ;
483デフォルトの名無しさん (ワッチョイ 35d2-asy+)
2017/10/04(水) 17:04:07.51ID:+admsRHQ0 >>482
回答ありがとうございます!
ちなみにこれだったらどうかくんでしょうか?
struct I2C_MEM I2C_MEM[3] = //構造体の初期化
{
{ 0x7C , 0x01 , 0x12345678 },
{ 0x7C , 0x02 , 0x12345678 },
{ 0x7C , 0x03 , 0x12345678 },
} ;
回答ありがとうございます!
ちなみにこれだったらどうかくんでしょうか?
struct I2C_MEM I2C_MEM[3] = //構造体の初期化
{
{ 0x7C , 0x01 , 0x12345678 },
{ 0x7C , 0x02 , 0x12345678 },
{ 0x7C , 0x03 , 0x12345678 },
} ;
2017/10/04(水) 17:19:18.44ID:HMkkIXOid
>>483
struct I2C_MEM I2C_MEM[3] =
{
#ifdef BIG_ENDIAN //ビッグエンディアンの場合
{ 0x7C , 0x01 , {0x12, 0x34, 0x56, 0x78} },
{ 0x7C , 0x02 , {0x12, 0x34, 0x56, 0x78} },
{ 0x7C , 0x03 , {0x12, 0x34, 0x56, 0x78} },
#else // リトルエンディアンの場合
{ 0x7C , 0x01 , {0x78, 0x56, 0x34, 0x12} },
{ 0x7C , 0x02 , {0x78, 0x56, 0x34, 0x12} },
{ 0x7C , 0x03 , {0x78, 0x56, 0x34, 0x12} },
#endif
} ;
struct I2C_MEM I2C_MEM[3] =
{
#ifdef BIG_ENDIAN //ビッグエンディアンの場合
{ 0x7C , 0x01 , {0x12, 0x34, 0x56, 0x78} },
{ 0x7C , 0x02 , {0x12, 0x34, 0x56, 0x78} },
{ 0x7C , 0x03 , {0x12, 0x34, 0x56, 0x78} },
#else // リトルエンディアンの場合
{ 0x7C , 0x01 , {0x78, 0x56, 0x34, 0x12} },
{ 0x7C , 0x02 , {0x78, 0x56, 0x34, 0x12} },
{ 0x7C , 0x03 , {0x78, 0x56, 0x34, 0x12} },
#endif
} ;
2017/10/04(水) 17:21:40.35ID:HMkkIXOid
2017/10/04(水) 17:27:10.52ID:PA2rRcfg0
全くどうでもいいことだが最近の若いモンはスマホに合わせて上矢印なのな
一つ勉強になった
一つ勉強になった
487デフォルトの名無しさん (ガックシ 06cb-huvM)
2017/10/04(水) 17:28:20.90ID:VznoOWf36 PCでも上じゃね?
2017/10/04(水) 17:40:04.96ID:HMkkIXOid
>>484
#ifdef BIG_ENDIAN
# define ENDIAN_FIX(a,b,c,d) a,b,c,d
#else
# define ENDIAN_FIX(a,b,c,d) d,c,b,a
#endif
struct I2C_MEM I2C_MEM[3] =
{
{ 0x7C , 0x01 , {ENDIAN_FIX(0x12, 0x34, 0x56, 0x78)} },
{ 0x7C , 0x02 , {ENDIAN_FIX(0x12, 0x34, 0x56, 0x78)} },
{ 0x7C , 0x03 , {ENDIAN_FIX(0x12, 0x34, 0x56, 0x78)} },
} ;
#ifdef BIG_ENDIAN
# define ENDIAN_FIX(a,b,c,d) a,b,c,d
#else
# define ENDIAN_FIX(a,b,c,d) d,c,b,a
#endif
struct I2C_MEM I2C_MEM[3] =
{
{ 0x7C , 0x01 , {ENDIAN_FIX(0x12, 0x34, 0x56, 0x78)} },
{ 0x7C , 0x02 , {ENDIAN_FIX(0x12, 0x34, 0x56, 0x78)} },
{ 0x7C , 0x03 , {ENDIAN_FIX(0x12, 0x34, 0x56, 0x78)} },
} ;
2017/10/04(水) 18:04:30.94ID:9y3nqzOw0
構造体の中身から推測すると、
書く順番はエンディアンに依存しないと思う
単純に配列の頭から1バイトずつ送信するだけ
仮にエンディアンで順番が変わるとしても
どうせガッツリ環境依存なコードなんだから
依存しちゃえばいい
環境依存が無いコードを書くつもりなら、
charが1バイトかどうかにも依存しないようにしないとね
書く順番はエンディアンに依存しないと思う
単純に配列の頭から1バイトずつ送信するだけ
仮にエンディアンで順番が変わるとしても
どうせガッツリ環境依存なコードなんだから
依存しちゃえばいい
環境依存が無いコードを書くつもりなら、
charが1バイトかどうかにも依存しないようにしないとね
2017/10/04(水) 18:10:15.78ID:9y3nqzOw0
>>488みたいなマクロは最悪
エンディアンていう言葉を覚えたばっかりの初心者が作る糞コード
エンディアンていう言葉を覚えたばっかりの初心者が作る糞コード
491デフォルトの名無しさん (ガックシ 06cb-huvM)
2017/10/04(水) 18:48:35.51ID:VznoOWf36 もちつけよw
2017/10/04(水) 19:22:55.76ID:HMkkIXOid
エンディアンについて解説が必要ですか?
はい/いいえ
はい/いいえ
2017/10/04(水) 20:07:04.96ID:V7FXDajl0
いいえ
2017/10/04(水) 20:09:03.80ID:V7FXDajl0
Definitely no.
2017/10/04(水) 20:18:42.31ID:38WTG0/g0
struct I2C_MEM //構造体の型宣言
struct I2C_MEM I2C_MEM[3] =//構造体の型宣言
この手の文法で自明なことをコメントにする文化はなくならないのかな
struct I2C_MEM I2C_MEM[3] =//構造体の型宣言
この手の文法で自明なことをコメントにする文化はなくならないのかな
2017/10/04(水) 20:46:10.64ID:hBVSLcAId
俺のコードはその対極
大きな流れしかコメントをかかない
大きな流れしかコメントをかかない
2017/10/04(水) 21:20:04.88ID:azmmV5/P0
I2Cか。データは8ビットで受けて、8ビットシフトしてビットORだな。
data = hi<<16 | mid<<8 | lo
data = hi<<16 | mid<<8 | lo
2017/10/04(水) 21:27:53.34ID:hBVSLcAId
どう見ても送信
2017/10/04(水) 21:31:39.40ID:hBVSLcAId
>>492
お前の糞マクロ、どの辺が糞か解説が必要?
お前の糞マクロ、どの辺が糞か解説が必要?
2017/10/04(水) 21:32:35.25ID:hBVSLcAId
ちなみに、ゆで玉子は輪切り派
501デフォルトの名無しさん (ワッチョイ 059f-XSap)
2017/10/05(木) 01:23:13.38ID:ioWgBjMx0 >>483
やってみな。
やってみな。
2017/10/05(木) 01:24:28.79ID:ioWgBjMx0
やってみなじゃない。どう動くかじゃなくてどう書くかか。
どうなって欲しいのかが書かれてないから答えられないな。
どうなって欲しいのかが書かれてないから答えられないな。
2017/10/05(木) 03:25:02.16ID:JVwY/YZa0
>>465
全体のコードは自作というか(自社製)ですが、funcは他社のライブラリなんです。
ソースがあればなんとかなったのかもですが・・・。
>>467
実際はfunc呼んだ後にcharListの値を呼んで色々作業しています。
>>469
普通の2次元char配列のつもりです。2次元配列というのはC言語的にはシンタックスシュガーにすぎず、
char a[m][n]もchar a[m*n]も等価なのですよね。なので、先頭ポインタから(m*n-1)個先までの
アドレスの範囲内なら範囲外アクセスエラーは起こり得ないと理解しています。
>>474の結論に至る前に、何かC言語で致命的な勘違いや思い込みをしているのかと
思って質問した次第です。今思うとエスパー回答を強いてしまって大変申し訳ありませんでした。
ひとまずはfuncを一切呼ばない形に直して事なきを得ました。
>>437で言った、「charListをプリントしたりすると何故か問題なく動く」からそれで一時凌ぎする考えも
頭をよぎりましたが、思いとどまりました。
ひとまずこれで終えます。回答くださった方々、本当にありがとうございました。
全体のコードは自作というか(自社製)ですが、funcは他社のライブラリなんです。
ソースがあればなんとかなったのかもですが・・・。
>>467
実際はfunc呼んだ後にcharListの値を呼んで色々作業しています。
>>469
普通の2次元char配列のつもりです。2次元配列というのはC言語的にはシンタックスシュガーにすぎず、
char a[m][n]もchar a[m*n]も等価なのですよね。なので、先頭ポインタから(m*n-1)個先までの
アドレスの範囲内なら範囲外アクセスエラーは起こり得ないと理解しています。
>>474の結論に至る前に、何かC言語で致命的な勘違いや思い込みをしているのかと
思って質問した次第です。今思うとエスパー回答を強いてしまって大変申し訳ありませんでした。
ひとまずはfuncを一切呼ばない形に直して事なきを得ました。
>>437で言った、「charListをプリントしたりすると何故か問題なく動く」からそれで一時凌ぎする考えも
頭をよぎりましたが、思いとどまりました。
ひとまずこれで終えます。回答くださった方々、本当にありがとうございました。
2017/10/05(木) 03:26:43.92ID:JVwY/YZa0
2017/10/05(木) 05:32:30.50ID:PdAAtG4s0
2017/10/05(木) 05:39:44.88ID:+DJIpzmcM
char[m][n]はchar**、char[m*n]はchar*、データ型は違う
2017/10/05(木) 08:10:49.48ID:2SMjslBqM
funcに与える引数の条件がちゃんと理解できてないとか
2017/10/05(木) 08:15:39.56ID:Nh1QNpvaF
char[m*n]って何?
結局ただの一次元配列でしょ?
結局ただの一次元配列でしょ?
509デフォルトの名無しさん (ワッチョイ b632-rzHd)
2017/10/05(木) 10:10:50.98ID:6niZC7Nf02017/10/05(木) 10:11:07.83ID:TrTYAooo0
>>503
> 2次元配列というのはC言語的にはシンタックスシュガーにすぎず、
> char a[m][n]もchar a[m*n]も等価なのですよね。なので、先頭ポインタから(m*n-1)個先までの
> アドレスの範囲内なら範囲外アクセスエラーは起こり得ないと理解しています。
だいたいの実装では、特に char 類なら、動作上問題が起こることは考えにくいものの、
言語規格上の保証は無いよ。
https://www.jpcert.or.jp/m/sc-rules/c-arr30-c.html
> 2次元配列というのはC言語的にはシンタックスシュガーにすぎず、
> char a[m][n]もchar a[m*n]も等価なのですよね。なので、先頭ポインタから(m*n-1)個先までの
> アドレスの範囲内なら範囲外アクセスエラーは起こり得ないと理解しています。
だいたいの実装では、特に char 類なら、動作上問題が起こることは考えにくいものの、
言語規格上の保証は無いよ。
https://www.jpcert.or.jp/m/sc-rules/c-arr30-c.html
511デフォルトの名無しさん (ワッチョイ b632-rzHd)
2017/10/05(木) 12:14:43.27ID:6niZC7Nf0 そういう保証は紙っきれの条文より自分で確認・検証することが最重要だ
いくら「保証されている」ことでもコンパイラがバグったり中には確信的に違反するケースまである
空想論の域を出ないくだらんことのために
現実的なアイディアを諦めていては生産性が上がらない
いくら「保証されている」ことでもコンパイラがバグったり中には確信的に違反するケースまである
空想論の域を出ないくだらんことのために
現実的なアイディアを諦めていては生産性が上がらない
512デフォルトの名無しさん (ワッチョイ bdd2-qWqy)
2017/10/05(木) 12:51:26.83ID:TRdRMfhC0 struct I2C_MEM
{
char DEV_ADR ;
char REG_ADR ;
char DATA[4] ;
} static I2C_MEM0 ;
I2C_MEM0.DEV_ADR = 0x7C ;
I2C_MEM0.REG_ADR = 0x01 ;
I2C_MEM0.DATA[4] = { 0x11,0x12,0x13,0x14 } ; ←これはエラーになる
//I2C_MEM0.DATA[0] = 0x11 ; ←こちらのパターンはエラーにならない
//I2C_MEM0.DATA[1] = 0x12 ;
//I2C_MEM0.DATA[2] = 0x13 ;
//I2C_MEM0.DATA[3] = 0x14 ;
4バイト一気に設定の書き方はどうすればいいんでしょうか?
{
char DEV_ADR ;
char REG_ADR ;
char DATA[4] ;
} static I2C_MEM0 ;
I2C_MEM0.DEV_ADR = 0x7C ;
I2C_MEM0.REG_ADR = 0x01 ;
I2C_MEM0.DATA[4] = { 0x11,0x12,0x13,0x14 } ; ←これはエラーになる
//I2C_MEM0.DATA[0] = 0x11 ; ←こちらのパターンはエラーにならない
//I2C_MEM0.DATA[1] = 0x12 ;
//I2C_MEM0.DATA[2] = 0x13 ;
//I2C_MEM0.DATA[3] = 0x14 ;
4バイト一気に設定の書き方はどうすればいいんでしょうか?
2017/10/05(木) 12:51:30.07ID:/OlbfMDH0
コメント邪魔
2017/10/05(木) 12:52:03.70ID:/OlbfMDH0
誤爆m(_'_)m
2017/10/05(木) 12:59:34.91ID:/OlbfMDH0
>>512
一気に初期化する必要性がわからんが
糞コード
assert( 4 == sizeof ( unsigned long ) );
*( unsigned long* )I2C_MEM0.DATA = *( unsigned long* )"\x11\x12\x13\x14";
一気に初期化する必要性がわからんが
糞コード
assert( 4 == sizeof ( unsigned long ) );
*( unsigned long* )I2C_MEM0.DATA = *( unsigned long* )"\x11\x12\x13\x14";
■ このスレッドは過去ログ倉庫に格納されています
ニュース
- 【自主回収】「あんまん」に「肉まん」が混入1314パックを自主回収「肉まん」に「あんまん」が混入の可能性もあり [おっさん友の会★]
- 【映画】165億円の赤字か 米ディズニー「白雪姫」実写版、大型連休中の日本でも上映打ち切り [ネギうどん★]
- 【住宅】退職後も家賃支払う「賃貸」か、住宅ローン見極め「持ち家」か…住居費は手取りの3割が目安 ★5 [ぐれ★]
- 【大阪・関西万博】来場者数きのう=5日『12万人1千人』(関係者1万7千人含む) [少考さん★]
- あのちゃん、“普通”の押し付けに苦言「お前が言ってるその普通も僕からしたら普通じゃない」 [ネギうどん★]
- 「これ、かわいくない」と同意を求めただけなのに…SNSのやりとりで誤解防ぐには [少考さん★]
- ウク信「ロシアと中国の経済は崩壊する!!」。ロシア、GDP成長率4.1%、中国、GDP成長率5.2% [805596214]
- GW最終日の大阪万博、大雨でガラガラ [931948549]
- 【悲報】白人絵師「初音ミクは白人に見えるからアジア人に描き直した」→日本人ブチギレwwwwwwwwwwwwwwww [839150984]
- キィー🐢💢🏡
- ナザレンコさん、アンチにキレる [834922174]
- 【正論】X民「炎上覚悟で言う、開示請求は確実にインターネットをつまらなくしてる」 3.7万いいね [839150984]