0

uint32_t 変数があり、最初の 10 個の下位ビット (0-9) をランダムに変更したいのですが、それでもランダムに、ビットを 10 番目から 23 番目に変更したいと考えています。この単純なプログラムを C++ で作成しましたが、最初の 10 ビットでは機能しますが、他のビットでは機能しません。理由がわかりません

#include <stdio.h>
#include <stdlib.h>
#include <stdint.h>
#include <iostream>
#include <math.h>

using namespace std;

void printuint(uint32_t value);

int main(){

    uint32_t initval=0xFFFFFFFF;
    uint32_t address;
    uint32_t value;
    uint32_t final;


    address=rand()%1024;
    address<<=23;
    printf("address \n");
    printuint(address);

    printf("final\n");
    final = (initval & address);
    printuint(final);


    return 0;
}

void printuint (uint32_t value){

    while (value) {
        printf("%d", value & 1);
        value >>= 1;
    }
    cout<<endl;
}

これを追加

    value = rand() % 16384;
    printuint(value);

および変更final = (initval & address) & value;

4

2 に答える 2

0

ランダム ビットを反転する例を次に示します。

int main(void)
{
  srand(time());
  unsigned int value = 0;
  for (unsigned int iterations = 0;
       iterations < 10;
       ++iterations)
  {
    unsigned int bit_position_to_change = rand() % sizeof(unsigned int);
    unsigned int bit_value = 1 << bit_position_to_change;
    value = value ^ bit_value;  // flip the bit.
    std::cout << "Iteration: " << iterations
              << ", value: 0x" << hex << value
              << "\n";
  }
  return EXIT_SUCCESS;
}

で表される排他的 OR 関数は、operator ^ビットの反転に適しています。

別の方法は、ビットを置き換えることです。

unsigned int bit_pattern;
unsigned int bit_mask; // contains a 1 bit in each position to replace.
value = value & ~bit_mask;  // Clear bits using the mask
value = value | bit_pattern;  // Put new bit pattern in place.
于 2015-03-24T00:21:47.530 に答える