Number of bits in basic data type

杀马特。学长 韩版系。学妹 提交于 2019-12-11 06:15:35

问题


Here's a couple of thoughts.I'm learning so there might be mistake(s) and even missing some basics.

  1. sizeof operator returns number of bytes.
  2. number of bits in byte is not constant value(correct me but it's number of bits char has).
  3. I want to know how many bits variable occupies, and sizeof won't tell me that without making assumptions about number of bits in char.

So I came up with this piece of (probably unnecessary) code:

#include <stdio.h>
#include <math.h>
#include <limits.h>

int main(void)
{
  double bits;

  bits=sizeof(int)*log10(UCHAR_MAX+1)/log10(2);

  printf("Bits = %lf\n", bits);

  return 0;
}

Is there easier (standard) way to check how many bits given type occupies?
CHAR_BIT * sizeof(type) will do the job, but is there standard one argument macro/function that does that for me?
Someone with better mathematical background could check if my code will be always giving correct answers.


回答1:


If you want to check for how many bits the machine actually used for a single char use the CHAR_BIT macro (note that sizeof (char) will always return one by definition though the actual allocation size per char may be still taller (even 32bits) though wasteful)


I am not aware of any predefined macro, but

#define REAL_BITS(type) (CHAR_BIT*sizeof(type))

should suffice




回答2:


const size_t numberOfBits = CHAR_BIT * sizeof(type);



回答3:


Using CHAR_BIT (defined in limits.h) should do it.

CHAR_BIT * sizeof(something)

I have checked a number of *nix platforms and they are all 8 bits in a byte, but I guess it may vary on some stranger platforms.




回答4:


char data type is a byte. a int is 4bytes (dword). short is 2bytes (word). so, how many bits? just sizeof(the_char)*8. when you want to convert bytes to bits just bits_number=bytes_number*8 :)



来源:https://stackoverflow.com/questions/19244371/number-of-bits-in-basic-data-type

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!