Linux vmi284606.contaboserver.net 4.15.0-213-generic #224-Ubuntu SMP Mon Jun 19 13:30:12 UTC 2023 x86_64
Apache/2.4.57 (Ubuntu)
: 167.86.127.34 | : 216.73.217.1
Cant Read [ /etc/named.conf ]
7.2.24-0ubuntu0.18.04.17
root
Terminal
AUTO ROOT
Adminer
Backdoor Destroyer
Linux Exploit
Lock Shell
Lock File
Create User
CREATE RDP
PHP Mailer
BACKCONNECT
UNLOCK SHELL
HASH IDENTIFIER
README
+ Create Folder
+ Create File
/
usr /
local /
go /
test /
chan /
[ HOME SHELL ]
Name
Size
Permission
Action
doubleselect.go
1.96
KB
-rw-r--r--
fifo.go
896
B
-rw-r--r--
goroutines.go
743
B
-rw-r--r--
nonblock.go
3.93
KB
-rw-r--r--
perm.go
1.33
KB
-rw-r--r--
powser1.go
12.65
KB
-rw-r--r--
powser2.go
13.29
KB
-rw-r--r--
select.go
913
B
-rw-r--r--
select2.go
1.04
KB
-rw-r--r--
select3.go
4.07
KB
-rw-r--r--
select4.go
513
B
-rw-r--r--
select5.go
9.97
KB
-rw-r--r--
select6.go
783
B
-rw-r--r--
select7.go
932
B
-rw-r--r--
select8.go
826
B
-rw-r--r--
sendstmt.go
672
B
-rw-r--r--
sieve1.go
1.49
KB
-rw-r--r--
sieve2.go
3.88
KB
-rw-r--r--
zerosize.go
349
B
-rw-r--r--
Delete
Unzip
Zip
${this.title}
Close
Code Editor : nonblock.go
// run // Copyright 2009 The Go Authors. All rights reserved. // Use of this source code is governed by a BSD-style // license that can be found in the LICENSE file. // Test channel operations that test for blocking. // Use several sizes and types of operands. package main import "runtime" import "time" func i32receiver(c chan int32, strobe chan bool) { if <-c != 123 { panic("i32 value") } strobe <- true } func i32sender(c chan int32, strobe chan bool) { c <- 234 strobe <- true } func i64receiver(c chan int64, strobe chan bool) { if <-c != 123456 { panic("i64 value") } strobe <- true } func i64sender(c chan int64, strobe chan bool) { c <- 234567 strobe <- true } func breceiver(c chan bool, strobe chan bool) { if !<-c { panic("b value") } strobe <- true } func bsender(c chan bool, strobe chan bool) { c <- true strobe <- true } func sreceiver(c chan string, strobe chan bool) { if <-c != "hello" { panic("s value") } strobe <- true } func ssender(c chan string, strobe chan bool) { c <- "hello again" strobe <- true } var ticker = time.Tick(10 * 1000) // 10 us func sleep() { <-ticker <-ticker runtime.Gosched() runtime.Gosched() runtime.Gosched() } const maxTries = 10000 // Up to 100ms per test. func main() { var i32 int32 var i64 int64 var b bool var s string var sync = make(chan bool) for buffer := 0; buffer < 2; buffer++ { c32 := make(chan int32, buffer) c64 := make(chan int64, buffer) cb := make(chan bool, buffer) cs := make(chan string, buffer) select { case i32 = <-c32: panic("blocked i32sender") default: } select { case i64 = <-c64: panic("blocked i64sender") default: } select { case b = <-cb: panic("blocked bsender") default: } select { case s = <-cs: panic("blocked ssender") default: } go i32receiver(c32, sync) try := 0 Send32: for { select { case c32 <- 123: break Send32 default: try++ if try > maxTries { println("i32receiver buffer=", buffer) panic("fail") } sleep() } } <-sync go i32sender(c32, sync) if buffer > 0 { <-sync } try = 0 Recv32: for { select { case i32 = <-c32: break Recv32 default: try++ if try > maxTries { println("i32sender buffer=", buffer) panic("fail") } sleep() } } if i32 != 234 { panic("i32sender value") } if buffer == 0 { <-sync } go i64receiver(c64, sync) try = 0 Send64: for { select { case c64 <- 123456: break Send64 default: try++ if try > maxTries { panic("i64receiver") } sleep() } } <-sync go i64sender(c64, sync) if buffer > 0 { <-sync } try = 0 Recv64: for { select { case i64 = <-c64: break Recv64 default: try++ if try > maxTries { panic("i64sender") } sleep() } } if i64 != 234567 { panic("i64sender value") } if buffer == 0 { <-sync } go breceiver(cb, sync) try = 0 SendBool: for { select { case cb <- true: break SendBool default: try++ if try > maxTries { panic("breceiver") } sleep() } } <-sync go bsender(cb, sync) if buffer > 0 { <-sync } try = 0 RecvBool: for { select { case b = <-cb: break RecvBool default: try++ if try > maxTries { panic("bsender") } sleep() } } if !b { panic("bsender value") } if buffer == 0 { <-sync } go sreceiver(cs, sync) try = 0 SendString: for { select { case cs <- "hello": break SendString default: try++ if try > maxTries { panic("sreceiver") } sleep() } } <-sync go ssender(cs, sync) if buffer > 0 { <-sync } try = 0 RecvString: for { select { case s = <-cs: break RecvString default: try++ if try > maxTries { panic("ssender") } sleep() } } if s != "hello again" { panic("ssender value") } if buffer == 0 { <-sync } } }
Close