sym enc

func main() {
n := 0x5fffff
key := make([]byte, 32)
nonce := make([]byte, 12)
copy(key, []byte("ok, this is key..."))
copy(nonce, []byte("ok, this is nonce"))

plaintext := []byte("ok, ewasflkjewaojhewofhaowigqherdveuiwprqufuepriauwafeshfjkaewhfhjsadjfhasukfjasjfsaahashjkfewiuhfiuwfiuahfhuawhufhuawufhiawuhfiuwafghigiuihuhuiu9yr8p98yqp3894y3-aqrst3qfdegr423qe43")
ciphertext := make([]byte, len(plaintext))
b, err := chacha20.NewCipher(key, nonce)
if err != nil{
panic(err)
}
s := chacha20.NewChaCha20(b)
t1 := time.Now()
for i:=0; i<=n; i++{
s.XORKeyStream(ciphertext, plaintext)
}
t1e := time.Now()

ciphertext1 := make([]byte, len(plaintext))
s1,_ := salsa.NewUnauthenticatedCipher(key, nonce)
t2 := time.Now()
for i:=0; i<=n; i++{
s1.XORKeyStream(ciphertext1, plaintext)
}
t2e := time.Now()

akey := make([]byte, 16)
aiv := make([]byte, 16)
copy(akey, []byte("ok, this is key..."))
copy(aiv, []byte("ok, this is nonce"))
ab, err := aes.NewCipher(akey)
if (err != nil){
panic(err)
}
as := cipher.NewCTR(ab, aiv)
t3 := time.Now()
for i:=0; i<=n; i++{
as.XORKeyStream(ciphertext, plaintext)
}
t3e := time.Now()

sb, err := sm4.NewCipher(akey)
if (err != nil){
panic(err)
}
ss := cipher.NewCTR(sb, aiv)
t4 := time.Now()
for i:=0; i<=n; i++{
ss.XORKeyStream(ciphertext, plaintext)
}
t4e := time.Now()

fmt.Println(t1e.Sub(t1))
fmt.Println(t2e.Sub(t2))
fmt.Println(t3e.Sub(t3))
fmt.Println(t4e.Sub(t4))
cnt := float64(n * len(plaintext));
cnt /= 1024 * 1024;
fmt.Println(cnt)
fmt.Println("end")
}





3.548263042s
2.368485207s
1.549265953s
11.349872991s
1085.9998273849487



posted @   zJanly  阅读(173)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
点击右上角即可分享
微信分享提示