In C++ I can use compiler specific intrisics to find the left|right most bit set, like shown in this thread.
Is there anything similar in C#? Or I need to iterate over all the bits to achieve that?
Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.
Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.
Lost your password? Please enter your email address. You will receive a link and will create a new password via email.
Please briefly explain why you feel this question should be reported.
Please briefly explain why you feel this answer should be reported.
Please briefly explain why you feel this user should be reported.
There is no access to compiler-specific “builtin” instructions for things like ffs. You would have to use a regular code implementation using things like bitmasks and shift operations. However, that doesn’t necessarily mean you need to iterate over all the bits: there are some scary-clever “regular” implementations for many of these methods, doing crazy “add some bizarre constant that isn’t obvious” that are designed to cut out most of the branching and iteration, and which would be perfectly fine in C#. The main thing to keep in mind if you port one of these is knowing whether it is using “signed” or “unsigned” right-shifts; if it is using “signed” use
int(etc); if it is “unsigned”, useuint(etc).