Heim  >  Artikel  >  Backend-Entwicklung  >  Programmierbeispiele ohne If-Anweisungen

Programmierbeispiele ohne If-Anweisungen

小云云
小云云Original
2018-02-01 14:27:442045Durchsuche

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];

wenn Implementierung

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

nicht-wenn Implementierung

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

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()));

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()));

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');
  }),
);
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');
  }),
);
ä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!

Stellungnahme:
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