Programmierbeispiele ohne If-Anweisungen

小云云
Freigeben: 2023-03-19 20:20:01
Original
2084 Leute haben es durchsucht

Bitte vermeiden Sie von nun an die Verwendung von if-Anweisungen zur Umsetzung unseres Geschäfts.

Sie fragen sich vielleicht, welche Vorteile es hat, wenn Sie nicht if verwenden. Nun ja, vielleicht gibt es keinen offensichtlichen Vorteil, es ist nur eine andere Denkweise, um das Problem zu lösen. An if-else ist nichts auszusetzen, aber in manchen Fällen kann eine große Anzahl von if-else dazu führen, dass der Code weniger lesbar ist. Nachfolgend finden Sie einige Beispiele, die Ihnen helfen sollen, das Geheimnis zu spüren.

Codierungstipp: Versuchen Sie, ohne If-Anweisungen zu codieren

Programmierbeispiele ohne If-Anweisungen

Herausforderung Nr. 1: Zählen Sie, wie viele ungerade Zahlen es in der gibt numerisches Array

Zählen Sie bei einem gegebenen Array vom Typ Integer die Anzahl der ungeraden Zahlen im Array

const arrayOfIntegers = [1, 4, 5, 9, 0, -1, 5];
Nach dem Login kopieren

wenn Implementierung

let counter = 0;
arrayOfIntegers.forEach((integer) => {
  const remainder = Math.abs(integer % 2);
  if (remainder === 1) {
    counter++;
  }
});
console.log(counter);
Nach dem Login kopieren

nicht-wenn Implementierung

let counter = 0;
arrayOfIntegers.forEach((integer) => {
  const remainder = Math.abs(integer % 2);
  // 偶数除2的余数为零,奇数的余数为一
  counter += remainder;
});
console.log(counter);
Nach dem Login kopieren

Hinweis: In den beiden obigen Beispielen ändert forEach das ursprüngliche Array und die Methode ist 可变的, was gegen das aktuelle Konzept der funktionalen Programmierung verstößt. immutable Keine Sorge, das ist nicht der Fall Schwerpunkt dieses Artikels. Beim Vergleich der beiden Beispiele ist die Implementierung von if语句 möglicherweise kompatibler und kann an die Situation angepasst werden, in der das Array-Element 小数 ist. Wenn die Array-Elemente vom Typ Gleitkomma sind, funktioniert das zweite Beispiel nicht ordnungsgemäß.

Herausforderung Nr. 2: Bestimmen Sie, ob ein Datum ein Wochenende oder ein Arbeitstag ist.

implementiert eine Funktion, die ein Datumsobjekt new Date() als Eingabe verwendet und zurückgibt, ob der aktuelle Tag 工作日 ist oder 周末 basierend auf unterschiedlichen Daten.

If-Implementierung

const weekendOrWeekday = inputDate => {
  const day = inputDate.getDay();
  if (day === 0 || day === 6) {
    return 'weekend';
  }

  return 'weekday';
  // Or, for ternary fans:
  // return (day === 0 || day === 6) ? 'weekend' : 'weekday';
};
console.log(weekendOrWeekday(new Date()));
Nach dem Login kopieren

Nicht-If-Implementierung

const weekendOrWeekday = (inputDate) => {
  const day = inputDate.getDay();
  return weekendOrWeekday.labels[day] ||
         weekendOrWeekday.labels['default'];
};
weekendOrWeekday.labels = {
  0: 'weekend',
  6: 'weekend',
  default: 'weekday'
};
console.log(weekendOrWeekday(new Date()));
Nach dem Login kopieren

Ist Ihnen aufgefallen, dass die Zahl in if语句 angibt, welcher Tag das Wochenende ist, und die Bedingung bestimmt? Verteilung Es ist fragmentierter. Wir müssen Zahlen den 周末或工作日-Typen zuordnen. Wie in Beispiel 2 können Sie ein Objekt oder eine Karte verwenden, um die entsprechende Beziehung zu speichern.

Beim Vergleich der beiden oben genannten Beispiele ist deutlich zu erkennen, dass die 非if代码-Implementierung eine bessere Lesbarkeit und Skalierbarkeit aufweist

Herausforderung Nr. 3: Die Doubler-Funktion (hier sind Drachen), Übersetzung Don' Es kommt nicht heraus~Awkward~

implementiert eine Verdoppelungsfunktion und führt die folgende Verarbeitung entsprechend verschiedenen Eingaben durch:

  1. Wenn die Eingabe vom Typ number ist, tun Sie dies der Verdopplungsprozess (5 => 10, -10 => -20)

  2. Wenn die Eingabe vom Typ string ist, wiederholen Sie jedes Zeichen ('hello' => 'hheelloo')

  3. Wenn die Eingabe vom Typ function ist, rufen Sie die Funktion zweimal auf und führen Sie sie aus

  4. Wenn die Eingabe vom Typ ist array, führen Sie dies für jedes Element des Arrays aus. doublerVerarbeitung

  5. Wenn die Eingabe vom Typ object ist, führen Sie die doublerVerarbeitung für jedes Attribut des Objekts

Die Implementierung von switch

const doubler = (input) => {
  switch (typeof input) {
    case 'number':
      return input + input;
    case 'string':
      return input
        .split('')
        .map(letter => letter + letter)
        .join('');
    case 'object':
      Object.keys(input)
            .map(key => (input[key] = doubler(input[key])));
      return input;
    case 'function':
      input();
      input();
  }
};
console.log(doubler(-10));
console.log(doubler('hey'));
console.log(doubler([5, 'hello']));
console.log(doubler({ a: 5, b: 'hello' }));
console.log(
  doubler(function() {
    console.log('call-me');
  }),
);
Nach dem Login kopieren
Nicht-

-Implementierung von switch

const doubler = (input) => {
  return doubler.operationsByType[typeof input](input);
};
doubler.operationsByType = {
  number: (input) => input + input,
  string: (input) =>
    input
      .split('')
      .map((letter) => letter + letter)
      .join(''),
  function: (input) => {
    input();
    input();
  },
  object: (input) => {
    Object.keys(input)
          .map((key) => (input[key] = doubler(input[key])));
    return input;
  },
};
console.log(doubler(-10));
console.log(doubler('hey'));
console.log(doubler([5, 'hello']));
console.log(doubler({ a: 5, b: 'hello' }));
console.log(
  doubler(function() {
    console.log('call-me');
  }),
);
Nach dem Login kopieren
ähnelt Herausforderung Nr. 2, Aggregationsbedingung Werte für eine einheitliche Verarbeitung zusammen.

Zusammenfassung

Wenn es viele Beurteilungsbedingungen für

gibt, werden die Bedingungen zentral verarbeitet (verwenden Sie Objekte, um ihre entsprechenden Beziehungen zu speichern – die Bedingungen werden als Schlüssel verwendet und die Verarbeitung erfolgt als Werte). Der Vorteil besteht darin, dass es einfacher wird, eine bestimmte Bedingung hinzuzufügen oder zu löschen, und der Code besser lesbar ist. Es wird empfohlen, einen Teil der if-else-Bedingungsbeurteilung durch die Korrespondenz zu ersetzen. key-valueif-elseVerwandte Empfehlungen:


Sprechen Sie über die aktuelle Situation, Aussichten und Chancen von if-Anweisungen

Der Code der elseif-Anweisung basierend auf PHP Zusammenfassung der Beispiele

Detaillierte Erklärung der if-Anweisung in SQL

Das obige ist der detaillierte Inhalt vonProgrammierbeispiele ohne If-Anweisungen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage
Über uns Haftungsausschluss Sitemap
Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!