Wenn ich eine Reihe von Jobs (Runnable oder Callable) habe, die ich gerade parallel ausführen lassen möchte, kann ich das mit Threads lösen. Die modernere Variante sind jedoch angepasste Executoren. Hier wird es aber schnell aufwendig, wenn ich eine Queue der beendeten Futures verwalten möchte. Eine einfachere Lösung bietet hier Guava mit der ListenableFuture Klasse an. Mit Hilfe der Executor-Decoratoren lassen sich die Standard Java Executoren verwenden, so dass der Code-Overhead an dieser Stelle minimiert werden kann. Ein kleines Anwendungsbeispiel lässt sich in oben erwähntem Link finden.
Montag, 8. September 2014
Dienstag, 2. September 2014
Reflection, neue Instanz und Generics
Es gibt Gelegenheiten, wo man eine Klasse über Reflection erzeugen möchte, dabei aber auch hässliche Casts verzichten will.
Am einfachsten geht die wie folgt:
Am einfachsten geht die wie folgt:
Class<?> genClazz = Class.forName(className); Class<? extends XYZ> clazz = genClazz.asSubclass(XYZ.class); Constructor<? extends XYZ> ctor = clazz.getConstructor(String.class, Integer.TYPE); XYZ var = ctor.newInstance("bla", 10);
Donnerstag, 31. Juli 2014
Abstellen der temporären IPv6 Adresse unter Windows
Im internen Netzwerk kann die temporäre IPv6 Adresse eher stören, wenn Dienste diese per DNS Request versuchen aufzulösen, da sie nicht im DNS eingetragen wird. Daher kann es, um Wartezeiten zu vermeiden, praktisch sein, diese abzuschalten.
Hierzu müssen in einer Admin-Shell folgende Befehle eingegeben werden:
netsh interface ipv6 set privacy state=disabled store=active netsh interface ipv6 set privacy state=disabled store=persistent netsh interface ipv6 set global randomizeidentifiers=disabled store=active netsh interface ipv6 set global randomizeidentifiers=disabled store=persistentNach einem Reboot sollten keine neue temporären IPv6 Adressen erstellt werden. Quelle: https://knowledge.zomers.eu/misc/Pages/How-to-disable-temporary-IPv6-address-allocation-at-a-Windows-PC.aspx
Freitag, 6. Juni 2014
Konfiguration
Unter Ubuntu lassen sich installierte Pakete mittels des Befehls dpkg-reconfigure neu konfigurieren. Hinter dem Befehl muss aber der Name des gewünschten Paketes angegeben werden. Aber woher kommt dieser?
Mit Hilfe des Befehls debconf-show --listowners bekommt man eine Liste der Pakete, die mit debconf (und damit auch mit dpkg-reconfigure) konfiguriert werden. Mit debconf-show paketname bekommt man dann auch die aktuelle Konfiguration angezeigt.
Alternativ kann man das Programm configure-debian benutzen. Hier wird man grafisch durch eine Liste geführt. Falls man nicht die Pakete in Gruppen zusammengefasst haben möchte, muss man den Parameter --list beim Aufruf mit angeben.
Mit Hilfe des Befehls debconf-show --listowners bekommt man eine Liste der Pakete, die mit debconf (und damit auch mit dpkg-reconfigure) konfiguriert werden. Mit debconf-show paketname bekommt man dann auch die aktuelle Konfiguration angezeigt.
Alternativ kann man das Programm configure-debian benutzen. Hier wird man grafisch durch eine Liste geführt. Falls man nicht die Pakete in Gruppen zusammengefasst haben möchte, muss man den Parameter --list beim Aufruf mit angeben.
Montag, 2. Juni 2014
rsync
Als Notiz (schließlich heißt das hier Notizbuch) die rsync Parameter:
Einfache Kopie
Einfache Kopie
rsync --stats --archive --verbose --compress --partial --progress --rsh=ssh \ source user@dest:/directoryKopie mit Checksumme
rsync --checksum --stats --archive --verbose --compress --partial --progress \ --rsh=ssh source user@dest:/directoryPrüfung ohne Kopiervorgang
rsync --dry-run --stats --archive --verbose --compress --partial --progress \ --rsh=ssh source user@dest:/directory
Freitag, 9. Mai 2014
Oracle Funktionen
Die Funktion regexp_substr kann als "split" Ersatz verwendet werden. Der reguläre Ausdruck enthält dazu die Zeichen zwischen den Delimitern (siehe das unten stehende Beispiel). Die benötigte Gruppe holt man sich dann mit dem vierten Parameter.
Beispiel:
select regexp_substr('a/b/c','[^/]+', 1, 2) from dual
SQL Developer Tastatur Shortcuts
Da ich üblicherweise lieber mit der Tastatur als mit der Maus arbeite, suche ich gerne Tastaturkürzel für die verwendeten Programme.
In der letzten Zeit muss ich häufiger mit dem SQL Developer arbeiten, daher hier eine Liste von interessanten Tastaturkürzeln:
Quellen:
In der letzten Zeit muss ich häufiger mit dem SQL Developer arbeiten, daher hier eine Liste von interessanten Tastaturkürzeln:
- Ctrl-Enter: Führe das aktuelle Statement aus
- Ctrl-F7: Führe eine Formatierung des Fensters aus
- Ctrl-Shift-N: Neues SQL Arbeitsblatt mit eigener Verbindung
Quellen:
Abonnieren
Posts (Atom)