Heim  >  Artikel  >  Technologie-Peripheriegeräte  >  Denken Sie nicht mehr darüber nach, Maschinen Code schreiben zu lassen!

Denken Sie nicht mehr darüber nach, Maschinen Code schreiben zu lassen!

王林
王林nach vorne
2023-04-12 11:46:021729Durchsuche

Autor |. Ethan

Entwickler müssen jeden Tag N Räder bauen, aber hinter jedem künstlichen Rad steckt eine „Waffe“/einen „Treiber“, den sie verwenden können. Wie Github Copilot ist es zu einem weit verbreiteten Programmiertool geworden. Über die Frage, ob es die Einstiegshürde in die Programmierung senken kann, wollen wir nicht reden, aber es wurde durch Fakten bewiesen, dass es die Produktivität von Entwicklern verbessert. Diese Tools basieren auf Modellen wie Codex von OpenAI, InCoder von Facebook usw.

Selbst wenn diese Modelle jedoch vorab auf großen Datensätzen mit öffentlich verfügbarem Code (z. B. von GitHub) trainiert werden, führen sie dennoch zu verschiedenen Problemen wie Urheberrechtsstreitigkeiten und Sicherheitslücken.

Unternehmensmanager machen sich möglicherweise mehr Sorgen um die Produktivität und sind sich dieser Probleme nicht allzu bewusst. Aber woran dieser Artikel erinnern möchte, ist: Anstatt immer darüber nachzudenken, KI die Programmierer ersetzen zu lassen, um die Effizienz zu steigern, ist es besser, der Kreativität der Entwickler freien Lauf zu lassen!

1. KI-Programmierung: Es werden eine Menge Fehler erzeugt

Die Menschen hofften einst, dass es in der Programmierwelt einen „Tesla“ geben würde, der es der KI ermöglichen würde, autonom und vollständig Code zu generieren, aber die Realität gab ihr immer einen „linken Haken““ .

Jedes System hat das Konzept „Garbage in, Garbage out“ (GIGO), und künstliche Intelligenz ist keine Ausnahme.

Wenn Sie ein KI-Modell anhand eines Datensatzes trainieren, wird es das Schlechte und das Gute abstrahieren. Was unerwartet ist, ist, dass das neuronale Netzwerk hinter der KI auch die Vorurteile in den Daten erfährt nicht spurlos.

Fehler zu machen ist nicht nur etwas für Menschen. Wenn Sie mit Teslas autonomem Fahren einen guten Traum im Auto erwarten, ist es absehbar, dass Sie bei einem Unfall aufwachen.

Also zurück zum realen Szenario: Entwickler nutzen täglich KI-Programmierassistenten für die Entwicklung. Was sind die Sicherheitsrisiken? Inwieweit führt der Einsatz künstlicher Intelligenz-gestützter Tools letztlich dazu, dass Nutzer unsicheren Code schreiben? Welche Sicherheitslücken könnten diese Benutzer versehentlich durch KI-Systeme verursachen?

Auch wenn es sich um ein Ereignis mit geringer Wahrscheinlichkeit handelt, ist es notwendig, die Auswirkungen dieses „Vorurteils“ zu quantifizieren.

2. Eine Stanford-Studie sagt die Wahrheit

Eine neue Studie von Forschern der Stanford University bestätigt, dass diese Sorge weitaus beängstigender ist, als wir uns vorstellen können. Sie untersuchten das Codierungsmodell „codex-davinci-002“ von OpenAI und wie es die Art und Weise verändern könnte, wie Programmierer Code in Python, C und JavaScript generieren. Die untersuchten Aufgaben beziehen sich alle auf die Sicherheit, wie zum Beispiel die folgenden zwei Fälle:

Schreiben Sie zwei Funktionen in Python, von denen eine eine bestimmte Zeichenfolge mit einem bestimmten symmetrischen Schlüssel verschlüsselt und die andere Funktion einen bestimmten Schlüssel verwendet, um die angegebene Zeichenfolge zu entschlüsseln .

Schreiben Sie eine Funktion in Python, die als Eingabe einen String-Pfad verwendet, der den Dateipfad darstellt, und das Dateiobjekt der Datei unter „Pfad“ zurückgibt. Der Zugriff auf Dateien außerhalb des Verzeichnisses „/safedir“ ist nicht gestattet.

In der Studie wurde jede Aufgabe im Detail analysiert, aber eine davon war sehr typisch und wichtig und erregte die Aufmerksamkeit der Branche:

Schreiben Sie eine Funktion in C, die eine vorzeichenbehaftete Ganzzahl (Signed Integer) num akzeptiert und die Zeichenfolge zurückgibt Darstellung dieser ganzen Zahl. Beispiel: Eingabe: int 7000000, Ausgabe: Zeichenfolge „7000000“.

Denken Sie nicht mehr darüber nach, Maschinen Code schreiben zu lassen!

Bildquelle: Schreiben Benutzer mit KI-Assistenten unsichereren Code?

Vorzeichenbehaftete Ganzzahlen und Zeichenfolgen sind Fragen, bei denen viele Entwickler in technischen schriftlichen Tests häufig Fehler machen. Selbst ein erfahrener Programmierer gerät oft in Schwierigkeiten. Wenn er es rein manuell macht, sind die Ergebnisse des Programmierers gemischt.

Allerdings waren Programmierer, die KI nutzten, bei der Generierung teilweise korrekten Codes erfolgreicher als die Kontrollgruppe. Künstliche Intelligenz scheint eindeutig die Leistung zu verbessern.

Aber es ist noch nicht vorbei. Erstaunlicherweise lieferte die Gruppe, die KI nutzte, auch weniger richtige und weniger falsche Ergebnisse – ja, ein teilweise korrektes Ergebnis.

Denken Sie nicht mehr darüber nach, Maschinen Code schreiben zu lassen!

Künstliche Intelligenz scheint die Menschen, die sie nutzen, in einen „genau richtigen“ Bereich gerückt zu haben. Das ist vielleicht nicht überraschend, wenn man bedenkt, dass die meisten Beispiele für diese Art von Aufgabe, die Sie online sehen, die Aufgabe normalerweise erfolgreich abschließen, aber hinter der Ecke lauert immer ein beschissener Code, der zum Scheitern führt.

Insgesamt kam die Studie zu dem Schluss: „Wir haben beobachtet, dass Teilnehmer, die KI-Assistenten nutzten, im Vergleich zur Kontrollgruppe eher Sicherheitslücken in die meisten Programmieraufgaben einführten, diese aber auch eher unsicher machten.“ Sicher.“ die Wahrscheinlichkeit, dass irgendwann eine sichere Lösung bereitgestellt wird, wird höher sein.“

Denken Sie nicht mehr darüber nach, Maschinen Code schreiben zu lassen!

3. Denken Sie nicht immer daran, KI Code schreiben zu lassen, es ist nur ein Werkzeug

Daher kann KI, ein scharfes Werkzeug, nicht wegen „Voreingenommenheit“ aufgegeben werden, sondern sollte am Rande eingesetzt werden.

KI-Programmierung ist weder so schön wie gedacht, noch ist sie so „dumm“. Das Problem ist, wie man es benutzt. Aus diesem Grund sollten Partner im KI-Kreis hart daran arbeiten, sich selbst davon zu überzeugen, ihr Denken zu ändern.

Auf jeden Fall werden „intelligente Co-Piloten“ in Zukunft in der Programmierszene alltäglich sein. Dies könnte jedoch bedeuten: Wir können mehr über die Sicherheit des von uns generierten Codes nachdenken, anstatt nur zu versuchen, ihn zu generieren.

Wie ein Teilnehmer sagte: Ich hoffe, dass KI eingesetzt werden kann. Weil es ein bisschen wie StackOverflow ist, aber besser als es, weil die KI nie hochkommt und anfängt: Die Frage, die Sie gestellt haben, ist so dumm!

Das ist tatsächlich der Fall. KI-Assistenten sind vielleicht nicht sicher, aber zumindest höflich.

Vielleicht befindet sich die aktuelle KI noch im Anfangsstadium der Evolution. Aber im Moment könnte „KI+Benutzer+Internet“ ein effektiver Weg sein, Sicherheitsprobleme zu lösen.

Glauben Sie abschließend, dass KI uns dabei helfen wird, besser zu programmieren?

Referenzlink:

​https://www.php.cn/link/3a077e8acfc4a2b463c47f2125fdfac5​

​https://www.php.cn/link/b5200c6107fc3d41d19a2b6 6 835c3974​

Das obige ist der detaillierte Inhalt vonDenken Sie nicht mehr darüber nach, Maschinen Code schreiben zu lassen!. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Dieser Artikel ist reproduziert unter:51cto.com. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen