I made a simple program that allows the user to pick a number of dice then guess the outcome... I posted this code before but with the wrong question so it was deleted... now I cannot have any errors or even warnings on this code but for some reason this warning keeps popping and I have no clue how to fix it... "warning C4244: 'argument' : conversion from 'time_t' to 'unsigned int', possible loss of data"
#include <iostream>
#include <string>
#include <cstdlib>
#include <time.h>
using namespace std;
int choice, dice, random;
int main(){
string decision;
srand ( time(NULL) );
while(decision != "no" || decision != "No")
{
std::cout << "how many dice would you like to use? ";
std::cin >> dice;
std::cout << "guess what number was thrown: ";
std::cin >> choice;
for(int i=0; i<dice;i++){
random = rand() % 6 + 1;
}
if( choice == random){
std::cout << "Congratulations, you got it right! \n";
std::cout << "Want to try again?(Yes/No) ";
std::cin >> decision;
} else{
std::cout << "Sorry, the number was " << random << "... better luck next time \n" ;
std::cout << "Want to try again?(Yes/No) ";
std::cin >> decision;
}
}
std::cout << "Press ENTER to continue...";
std::cin.ignore( std::numeric_limits<std::streamsize>::max(), '\n' );
return 0;
}
This is what I am trying to figure out, why am I getting this warning: warning C4244: 'argument' : conversion from 'time_t' to 'unsigned int', possible loss of data
This line involves an implicit cast from
time_t
whichtime
returns tounsigned int
whichsrand
takes:You can make it an explicit cast instead:
time()
returns atime_t
, which can be 32 or 64 bits.srand()
takes anunsigned int
, which is 32 bits. To be fair, you probably won't care since it's only being used as a seed for randomization.This line involves an implicit cast from time_t which time returns to unsigned int which srand takes:
You can make it an explicit cast instead:
That's because on your system,
time_t
is a larger integer type thanunsigned int
.time()
returns atime_t
which is probably a 64-bit integer.srand()
wants anunsigned int
which is probably a 32-bit integer.Hence you get the warning. You can silence it with a cast:
In this case, the downcast (and potential data loss) doesn't matter since you're only using it to seed the RNG.