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
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 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编程运行原理