如何减少以下代码段中的代码重复:
if(motionIOS == 0)
{
if(character == 40)
{
previousMotion = character;
}
if(previousMotion == 40 && character == 50)
{
motionIOSValue = 50;
}
else
{
previousMotion = character;
}
}
if(motionIOS == 1)
{
if(character == 60)
{
previousMotion = character;
}
if(previousMotion == 60 && character == 70)
{
motionIOSValue = 70;
}
else
{
previousMotion = character;
}
}
本质上我做了两次相同的代码,但是某些事情的值发生了变化。我甚至需要使用这个代码多次使用可变数字。
我想我应该将它重构为一个函数,但不知道如何。
答案 0 :(得分:0)
你可以巩固你的状况检查。
if(motionIOS == 0 && previousMotion == 40 && character == 50) {
motionIOSValue = 50;
} else if (motionIOS == 1 && previousMotion == 60 && character == 70){
motionIOSValue = 70;
} else {
previousMotion = character;
}
如果需要,您可以将条件检查提取到另一个类。
bool updateIosValue(int previousMotion, int character, int testMotion, int testCharacter){
//do your custom checks here.
return previousMotion==testMotion && character== testCharacter;
}
if(motionIOS==0 && updateIosValue(previousMotion, character, 40, 50){
motionIOSValue = 50;
}else if(motionIOS==1 && updateIosValue(previousMotion, character, 60, 70){
motionIOSValue = 70;
}else{
previousMotion = character;
}