Python, 358 281 268 221 194 Bytes
Monochrom ist ja letztes Jahr. Dies verwendet mehrere Prozesse und Systemaufrufe, um zweifarbige CPU-Grafiken zu erhalten!
import os,time
A='%-99o'%int('t12q2lxqkap48euoej9429cstbnazl63ubyryteo49u',36)
for i in'0123456':
t=os.fork()
while t<1:T=int(time.time())%50;(time.sleep,(id,os.urandom)[i<A[T+49]])[i<A[T]](1)
Ausgabe von Activity Monitor (OS X 10.9):
Ausgabe von MenuMeters:
Alle Ausgaben wurden mit einer Aktualisierungsgeschwindigkeit von 1s generiert. Es wurden keine signifikanten Hintergrundaufgaben ausgeführt, obwohl diese Ausgabe jede Single-Threaded-CPU-Aufgabe ziemlich leicht übertrifft.
Dieser Code setzt voraus, dass Sie 8 Kerne haben. Es sollte ziemlich einfach sein, für weniger / mehr Änderungen vorzunehmen. Es ist portabel für Linux / UNIX-Systeme (obwohl es nur unter OS X getestet wurde) und sollte für jeden CPU-Monitor, der die CPU-Zeit des Benutzers von der des Systems unterscheiden kann, dieselbe zweifarbige Ausgabe erzeugen.
Dies funktioniert im Wesentlichen, indem sieben Prozesse abgebrochen werden, von denen jeder 1 Sekunde Schlaf, Drehen im Benutzermodus oder Drehen des Kernels verbringt. Das Starten im Kernel-Modus wird durch das Anfordern großer Datenmengen von erreicht /dev/urandom
, was den Treiber-Backup /dev/urandom
dazu zwingt , viele "System" -CPU-Zyklen zu verbringen.
EDITED [07/21]: Deutlich verkürzt durch Verwendung von fork()
anstelle von multiprocessing.Process
( /dev/urandom
funktioniert ohnehin nur auf * NIX-Systemen, sodass die Portabilität nicht beeinträchtigt wird). Beachten Sie jedoch, dass das Programm jetzt Hintergrundaufgaben erzeugt . Möglicherweise müssen Sie killall Python
(oder ähnliches), um die CPU-Esser loszuwerden.
Ich konnte nicht widerstehen, noch ein paar Briefe umzusetzen. Ich habe 16 Buchstaben und ein paar Symbole:
Das vollständige Alphabet lautet "ACDFHILMNOPTUVWY" mit den Symbolen "._ ~ / \". Es gibt wahrscheinlich viel mehr Zeichen, die dargestellt werden können.
Völlig unbenutzter Code für die zusätzlichen Buchstaben:
from time import*
from multiprocessing import*
chars6 = {
'A': ('123456654321',
'000123321000'),
'C': ('344556666666',
'321110000000'),
'D': ('666666655443',
'000000011123'),
'F': ('66666666666666',
'00002222244444'),
'H': ('666664444466666',
'000002222200000'),
'I': ('66666',
'00000'),
'L': ('666662222222',
'000000000000'),
'M': ('6665544334455666',
'0004321001234000'),
'N': ('66665544336666',
'00003322110000'),
'O': ('3445556666555443',
'3221110000111223'),
'P': ('666666666555',
'000003333444'),
'T': ('777776666677777',
'444440000044444'),
'U': ('6666322236666',
'4211000001124'),
'V': ('66654322345666',
'33321000012333'),
'W': ('66542466424566',
'43210133101234'),
'Y': ('66665433456666',
'44333000033344'),
'_': ('1111111111',
'0000000000'),
' ': ('000',
'000'),
'.': ('12221',
'10001'),
'~': ('44445544334444',
'11223322112233'),
'/': ('2234566',
'0012344'),
'\\': ('6654322',
'4432100'),
}
s = 'ANCHOVY '
A = '000'.join(chars6[t][0] for t in s)
B = '000'.join(chars6[t][1] for t in s)
t=time()
f=open('/dev/urandom')
def F(n):
while 1:T=int(time()-t)%len(A);[sleep,[].count,lambda x:f.read(4**9)][(n<int(A[T]))+(n<int(B[T]))](1)
for i in range(7):Process(target=F,args=(i,)).start()
F(7)