Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people, just like you, are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
Solved

Detect set bits

Posted on 2004-04-14
8
272 Views
Last Modified: 2010-04-15
I need to determine if bits 0, 1, 10 and 11 are set
in unsigned short that is passed to me.

I wrote the code, but there's no way for me to test!
Need to make sure I'm getting it right.
Value passed to me will something like 3515, or so I was told.

Plz help, urgent.
0
Comment
Question by:jd9288
8 Comments
 

Author Comment

by:jd9288
ID: 10827022
BTW, the code I have is this:

ReadBit(int dat, int bitno)
{

     int dattest;

     //
     // shift desired bit into rightmost position
     //
     dattest = (dat >> bitno);

     return (dattest & 1);

}
0
 
LVL 6

Assisted Solution

by:joghurt
joghurt earned 150 total points
ID: 10827067
unsigned short value = ...;

if ((value & (1 << 0)) != 0) {
  // bit 0 is set
}
if ((value & (1 << 1)) != 0) {
  // bit 1 is set
}
etc.

For bits 0, 1, 10 AND 11 (at the same time) you'd try (1 << 0) | (1 << 1) | (1 << 10) | (1 << 11).
You may be surprised but the above expression gives me 3075 (or 0x0C03) instead of 3515.
So for checking what you want you should write

if ((value & 0x0C03) == 0x0C03) {
// All the required bits are set.
}

OR

if ((value & 0x0C03) != 0) {
// At least one of the required bits are set.
}
0
 
LVL 45

Expert Comment

by:Kent Olsen
ID: 10827072
Hi jd9288,

#define BITMASK ((1 << 0) | (1 << 1) | (1 << 10) | 1 << 11))


if (Value == BITMASK)  /*  All bits in bitmask are set, no others are set  */

if (Value & BITMASK)   /*  All bits in bitmask are set, others may be set  */

if (Value & BITMASK)   /*  Any bit in bitmask is set  */



Good Luck,
Kent
0
Are your AD admin tools letting you down?

Managing Active Directory can get complicated.  Often, the native tools for managing AD are just not up to the task.  The largest Active Directory installations in the world have relied on one tool to manage their day-to-day administration tasks: Hyena. Start your trial today.

 
LVL 45

Expert Comment

by:Kent Olsen
ID: 10827078
Whoops...

#define BITMASK ((1 << 0) | (1 << 1) | (1 << 10) | (1 << 11))


:-)

0
 
LVL 45

Expert Comment

by:Kent Olsen
ID: 10827098
Man, what a day...

#define BITMASK ((1 << 0) | (1 << 1) | (1 << 10) | (1 << 11))


if (Value == BITMASK)  /*  All bits in bitmask are set, no others are set  */

if ((Value & BITMASK) == BITMASK)  /*  All bits in bitmask are set, others may be set  */

if (Value & BITMASK)   /*  Any bit in bitmask is set  */


0
 
LVL 4

Assisted Solution

by:bkfirebird
bkfirebird earned 150 total points
ID: 10827105
>> I need to determine if bits 0, 1, 10 and 11 are set
does this mean you want  to check whether the four least significant bits of the number are set?
your ReadBit function looks fine ... you can check if a particular bit is set by calling .....

if (ReadBit(num, 1)) // bit is set
// do something

0
 
LVL 45

Accepted Solution

by:
Kent Olsen earned 200 total points
ID: 10827164
You can test this easy enough.

#define BITMASK ((1 << 0) | (1 << 1) | (1 << 10) | (1 << 11))

unsigned int TestBit (unsigned integer Value)
{
  unsigned int Result;

  Result = Value & BITMASK;
  printf ("Test Value = %8.8x, Mask=%8.8x, Result=%8.8x\n", Value, BITMASK, Result);
}

If the displayed value for Result is the same as for BITMASK, then all bits in the bitmask were set in the original word.


Kent
0
 

Author Comment

by:jd9288
ID: 10827187
Thank you all.
0

Featured Post

ScreenConnect 6.0 Free Trial

Explore all the enhancements in one game-changing release, ScreenConnect 6.0, based on partner feedback. New features include a redesigned UI, app configurations and chat acknowledgement to improve customer engagement!

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

Title # Comments Views Activity
undefined reference to `bswap_128' 9 169
outside company writing a dll in c/c++, I want to call it from C# 2 74
How to align numbers in C using the %d 2 104
How to learn Linux? 10 66
Have you thought about creating an iPhone application (app), but didn't even know where to get started? Here's how: ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ Important pre-programming comments: I’ve never tri…
This is a short and sweet, but (hopefully) to the point article. There seems to be some fundamental misunderstanding about the function prototype for the "main" function in C and C++, more specifically what type this function should return. I see so…
The goal of this video is to provide viewers with basic examples to understand and use pointers in the C programming language.
The goal of this video is to provide viewers with basic examples to understand opening and writing to files in the C programming language.

792 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question