• ベストアンサー

u_shortなどの省略した宣言について

unsigned short A; のように長い型の変数の宣言を行う場合に u_short A; などと省略形で書いてあるのをたまに参考書などで見かけるのですが、 実際に省略形で宣言をすると `u_short' undeclared とエラーが出て使うことができません。 これはどうすれば省略した形で宣言できるのでしょうか? typedefで宣言すればできるのかと思い試行錯誤してみたのですができませんでした。 ご教授、宜しくお願いいたします。 環境 OS Fedora Core 2 言語 C

質問者が選んだベストアンサー

  • ベストアンサー
  • notnot
  • ベストアンサー率47% (4848/10262)
回答No.1

>typedefで宣言すればできるのかと思い試行錯誤してみたのですができませんでした。 typedef宣言で出来ますよ。こういう質問の時は、どのように書いて駄目だったのかを書いたほうがいいです。 typedef unsigned short u_short; また、includeのディレクトリで、grep u_short *.h */*.h 等とすると既に定義してあるヘッダファイルが見つかるかもしれません。

pirosuke88
質問者

お礼

回答ありがとうございます。 説明不足ですみません。 Socketプログラミングを組んでいた時にポート番号を格納する変数を u_short client_port; と宣言している資料があり、同じように宣言したのですが エラーが出てコンパイルできなかったので typedef unsigned short u_short; と書き加えたのですができず、typedefの位置を変えたりして試行錯誤していました。 試しに、簡単なプログラムを組み同じことを試してみたらすんなりコンパイルできたので、 他に問題があると思い、調べていたら <netinet/in.h> が原因だったことが分かりました。 notnotさん、迅速なお回答ありがとうございました。

関連するQ&A

  • unsigned *という宣言について

    char *str = "\x01\x23\x45\x67\x89\xab\xcd\xef"; unsigned *u = (unsigned *)(str + 1); このようなコードをみかけたのですが、 unsigned *uという宣言が理解できません。 これはどのような型として解釈されているのでしょうか? 暗黙でunsigned int* uと解釈されるのでしょうか?

  • MicroC コンパイラ 変数宣言

    MicroC コンパイラ 変数宣言について質問です BYTE tmp1; WORD tmp2; なる定義があったとして 変数型範囲はどの範囲になるのでしょう 下記の定義は見つかったのですが 上記は分かりません 変数型 バイト数 範囲 (unsigned) char 1 0 .. 255 signed char 1 - 128 .. 127 (signed) short (int) 1 - 128 .. 127 unsigned short (int) 1 0 .. 255 (signed) int 2 -32768 .. 32767 unsigned (int) 2 0 .. 65535 (signed) long (int) 4 -2147483648 .. 2147483647 unsigned long (int) 4 0 .. 4294967295 float 4 ±1.17549435082 * 10-38 .. ±6.80564774407 * 1038 double 4 ±1.17549435082 * 10-38 .. ±6.80564774407 * 1038 long double 4 ±1.17549435082 * 10-38 .. ±6.80564774407 * 1038

  • C++ basic_ostreamの拡張

    UTF-16文字列を扱うためのostreamを用意したいのですが、wcoutの代わりに、unsigned shortを用いたostreamを使いたいと思いました。 そこで、basic_ostreamのクラスのunsigned short型のインスタンスを作ったのですが、以下のエラーが出てしまってコンパイルが出来ませんでした。 「error C2296: '<<' : 無効です。左オペランドには型 'u16ostream (__cde cl *)(void)' が指定されています。」 「error C2297: '<<' : 無効です。右オペランドには型 'u16char *' が指定 されています。」 コンパイラはVC++2008です。 それとついでですが、通常通りwcoutを使う時みたいに、localeを設定する必要はあるのでしょうか? 回答、よろしくお願いします。 /* 以下ソースコード */ #include <iostream> typedef unsigned short u16char; typedef basic_ostream<u16char> u16ostream; int main() { u16ostream ucout(); u16char* str = (u16char*)(L"ああ"); ucout << str << '\n'; return 0; }

  • 型宣言の場合分け

    下記のようなプログラムを作成しようと色々試行錯誤しているのですが、うまくいきません。trueとfalseで場合分けして関数を2つ作れば目的は達成されるのですが、プログラムが冗長になってしまい釈然としないのです。以下、私が試してみた方法を載せておきます。 (試行1) sengen関数の頭で  if (togle) float a;  else double a; としてみる。 結果 >> if文内でしか宣言されず、以後の処理でundeclared (試行2) まず、ソースの頭で #define SENGEN float とし、 sengen関数の頭で SENGEN a; とする。 次に、関数2の実行直前に #define SENGEN double と定義を上書きすることで関数1ではfloat宣言を、関数2ではdouble宣言を狙う。 結果 >> ディレクティブはプログラムの一番初めに実行されるらしく、両方ともdouble宣言になってしまって撃沈 完全にお手上げです。解決法を思いつく方いらっしゃいましたら助けてください   //目的とするプログラム void sengen(bool togle){   // togle==true ならば float a;   // togle==false ならば double a; ...適宜処理 } int main(){   sengen(true);   // 関数1   sengen(false);   // 関数2 }

  • 変数の型でlong longとunsigned long longと言うのは何ですか?

    教えていただきたいのですが、変数の型にlong longやunsigned long long なるものがあると聞いたのですが、どのようなものでしょうか? また、どのように宣言するのでしょうか?通常のlongなどと同じ要領で宣言し てやれば良いのでしょうか? もし、この型がある場合に、制約はあるのでしょうか?Unixでしか使えないとか の制約等ありましたらぜひ教えてください。 お願いいたします。

  • C言語の配列の扱い

    次のような配列bufと変数dataを宣言して bufの中身をdataにコピーしたいのですが、 buf[0]のみで、buf[1]の値が入りません。 具体的には、buf[0]には16進数で0x3f、 buf[1]には0x3aが入っていて、 dataの値を0x3a3fにしたいのです。 教えてください。 ***************************** unsigned char buf[2]; unsigned short data; data = (unsigned short)*buf; *****************************

  • VB.NETにおける構造体の初期化

    お世話になります。VB2005を使用しています。 C言語では、以下のように変数宣言時に配列の初期化が 出来ますが、VB.NETではできないのでしょうか? typedef struct{  short a1;  short a2; } TEST; int main(void) {  // ここのところをVBで実現したいです  TEST stTest[] = {{0, 10}, {1, 10}};  return 0; }

  • 複雑なポインタの定義

    #include <stdio.h> typedef int *(*i[3])[2]; int main() { int a = 0; int b = 1; int c = 2; int d = 3; int e = 4; int f = 5; int *u[2] = {&a, &b}; int *v[2] = {&c, &d]; int *w[2] = {&e, &f}; int **pp[3] = {u, v, w}; /* arrayをi型(intへのポインタを要素とする2個の配列へのポインタを要素とする3個の配列)として宣言 */ i array; /* この部分でarrayを使って変数a~fの内容を表示したい */ } 上記の最後の部分で、typedefで定義したi型の変数arrayを使って、変数a~fの内容を表示させたいのですが、その上で定義している諸々の変数との型の不整合が起こって、どういう記述をしたらよいか分かりかねています。要は、複雑なポインタの型定義をした場合の使い方がよく分からないのです。 御経験のある方は、御教示願えれば助かります。

  • ポインタがわからない

    C言語初心者です。 Int num; Int  *p=&num; という変数を宣言したとします。 下は「int *型」と呼び、pは「int型オブジェクトであるnumを指すポインタ」であることはわかりました。 ですが、「int型」と「int  *型」そのものの違いがわかりません。 たとえば、今読んでいるテキストに Printf(“int 型は%uバイトです。\n”,(unsigned)sizeof(int));→結果は2バイト Printf(“int *型は%uバイトです。\n”,(unsigned)sizeof(int *));→結果は4バイト 僕の環境では両方とも4バイトと結果は変わりませんでしたがテキストでは結果は上記のように変わってきてしまうようでした。これはなぜ変わってくるのでしょうか? 「int型」と「int  *型」そのものを比較した際の違いがわかりません。

  • ポインタ変数を変数に渡す方法

    (int * 型)ポインタ変数に代入されたアドレスを、(普通の)int 型変数に代入したいのですが、どのようにするのが正しいのでしょうか。 想定しているケースは、与えられたメモリ番地に対して、アドレスオフセットを加えるなどの操作を施して「補正アドレス」を生成し、メモリアクセスを行う、というような特殊な操作を実現するような場合です。 ※ メモリ番地がポインタ宣言で与えられる、という制約があります。 以下サンプルプログラムを書きました。組み込み系のプログラムを記述していますが、これで正しいでしょうか。 unsigned int *p, *p1; // ポインタ変数宣言 unsigned int value; p= (unsigned int *)0x00001F00; // メモリの0x1F00番地 value = p; // <-- ここが心配 value |= 0xCC << 16; // 与えられたアドレスから value &= 0x4 << 12; // 「補正アドレス」生成 p1 = (unsigned int *)value; *p1 = 0xA5A5_A5A5; // 「補正アドレス」にA5A5... をライト C言語初心者で、いろいろなサイトを見てみたのですが、説明されているページが見つからず質問させていただきました。どうぞよろしくお願いします。