V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX  ›  a132811  ›  全部回复第 1 页 / 共 20 页
回复总数  387
1  2  3  4  5  6  7  8  9  10 ... 20  
不用梯子的话,找一个国内大模式 api 封装一个就是了。
deepseek 、doubao 、GLM 、通义千问、文心一言都有 api
@guanzhangzhang
python3.5 以后就支持类型注解了,习惯了类型、单测后,没有它们我都不敢发代码了。

比 ts 好一点是内置支持,不需要像 ts 一样编译成 js 。
比 ts 差的一点是类型系统不强大,没有类型体操(某种意义上这其实算优点)
37 天前
回复了 anky 创建的主题 分享创造 自己搭了一个在线听广播电台的网站
不知道有没有收录台湾的电台 https://radios.tw/i-bcc-music-network/
102 天前
回复了 sleepybear1113 创建的主题 macOS 来说说 Mac 比起 Windows 笔记本好在哪里
有没有性价,要看你个人需求。

对我来说是省心不折腾:统一的 unix 环境 > 命令行(一键操作、自动化) > 全局 readline 快捷键 > 触摸板(十年没再用鼠标) > 续航。

我很多年前折腾各类 linux desktop 、升级、各类 gui 软件的 bug ,浪费了太多时间。后来换到 mac osx 后,整个世界都安静了。

帮人折腾过几次 wsl 、wsl2 ,体验不太好(可能现在 issue   bug 有改善了?)
另外 sub 子系统与母系统是割裂的(比如 wsl 中用脚本自动种自签名证书就很麻烦)。我现在写自动工具、脚本,一般都不会特别考虑 windows 环境。
我习惯和想法跟你类似,我也写了 10 年的笔记,都是放 git markdown.

不过我没有你这些烦恼。

- 编辑:我使用的 vscode + 自带的 markdown preview + Paste Image 插件,表格用 markdown table 的写法,附件就存其它地方只放链接(不过小文件直接放 git )
- 存储同步:多个 git   repo 备份
- 阅读/分享:vscode 、自己用 katex(latex)+marked.js 写的纯静态(连编译都省了)
- 搜索查找:各类 shell tool(主要是 ag + regex ),由于文章目录本身就是按知识树分门别类,所以搜索很方便
136 天前
回复了 jlz52z 创建的主题 Vim 关于 vim 中一次复制粘贴的询问
我的方法是使用 map 按键映射: 将 command+c 映射到 "+y 复制到系统粘贴板,command+s 映射到保存

""""""""""""""""""
" Copy Quit Save Select
" config iTerm2 keys: Esc+Ac, Esc+As, Esc+Aa
" (注意:mac iterm2 中必须要改键,否则 vim/nvim 无法响应 command+c command+s )
" mac vim 参考: https://stackoverflow.com/questions/23606892/vim-keyboard-mapping-problems-on-mac-osx
"""""""""""""""""""""
" Quit
nnoremap <C-q> :qa<CR>

" Copy
vnoremap <M-A>c "+y

" Save
nnoremap <M-A>s :up<CR>
inoremap <M-A>s <C-o>:up<CR>

" Select whole content
nnoremap <M-A>a ggVG

--------------------------------------
不想改键的话,就映射到其它 vim 能响应的按键

nnoremap <F2> "+p
inoremap <F2> <C-o>"+p
vnoremap <F2> "+y
----------------------------
这样做了后,visual 模式选中、鼠标选中后,都可以按 command+c 复制到系统粘贴板
---------------------------------------------------------------------------------------------------
BTW:
楼上提到的`:set paste`  每次要敲一下命令我觉得麻烦,操作完后还要恢复`:set nopaste`( paste 模式下自动编辑缩进会被关闭).
即使使用`:set pastetoggle=<F10> ` 也只是还是麻烦,况且 nvim 还不支持这个选项
144 天前
回复了 qW7bo2FbzbC0 创建的主题 Go 编程语言 被 go 语言的 json.Marshal 恶心到了
楼主已经自己确认了答案了:是这个 sql 库本身实现得有问题,跟 go 、json.Marshal 都无关。

在某种意义上还是 json 的表达能力不足导致的

## 不同语言的 json 库对[]byte 的处理
json  本身无法区分 string 和 `[]byte`,只有 string 。

1. php 自己本身就没有`[]byte`,甚至连 dict/array 都不区分。直接回避了问题
2. python  有`[]byte`, 但是不能 json 序列化, 如果是 utf8 就需要用 data.decode('utf-8') 要先转成 str
3. golang  序列化`[]byte` 时用 base64 将它转成 string, json 反序列时则用相应的类型去关联`[]byte`类型
4. java , c sharp 跟 golang 处理方式一样的。

## golang 对 json 的支持

json.Marshal 方法:

1. json.Marshal 本身是使用了内置的 json encoder 默认使用 base64 处理 bytes, eacapHTML 默认为 true
2. 但是 json.RawMessage 本身带的 json encoder ,不会对 bytes 做任何处理,如果 bytes 不是 json 格式,就会报编码出错

某些 golang  库实现,可能出于减少值复制,会用 bytes 去表达 string ,但序列化时就只能是 base64   string 了。

如果接收者不要 base64 string json, 解决办法有:

1. 自己先定义一个相应 string struct ,再将 bytes struct 转成 string struct ,最后 json  序列化自然就不是 base64 了
2. 通过反射将 string struct/map 等 转成  string map 再 json. 参考: https://github.com/ahuigo/golib/tree/main/spec/object/convert/objbytes2string_test.go
149 天前
回复了 iorilu 创建的主题 Rust rust 用来开发一些命令行程序是不是神器
@w568w go 也有 urfave/cli 等工具提供一键生成 help message 、config 、type checking 。golang 算是 rust+python 的折中方案。

@sagaxu go 泛型库 lo 可避免写 for 、interface 转换。如果想用函数式的话,可试试 ibm 的 fp-go 库。

错误处理避免 if err 的话,可以像 bufio scan 的方法那样避免 if err 。不过平时开发一般还是 if err 简单顺手。另外错误 chain 是一定要支持,方便定位错误的调用栈
我是主力用 vscode 写 js/ts/go/python 好多年了,偶尔用来写 python/rust/java 。

最开始 java/python 的插件都遇到过很影响开发的 bug ,发 issue 后经过很长时间才解决的,不过目前使用良好(轻度使用)
323 天前
回复了 heroisuseless 创建的主题 分享创造 还在用 JS?过来看看 GS
这是逆 ECMA/TC39  标准而行呀。es 不是不想简化,是要兼容,而且这些年语法上渐近的精进了不少了。

Deno 走 web 标准,做得很好,但是就因为跟 node/npm 不兼容,推广起来老费劲了
感觉 rust 的痛是暂时,zig 的痛是长期的
338 天前
回复了 awesomePower 创建的主题 程序员 前端求教,有没有懂 flex 布局的
338 天前
回复了 awesomePower 创建的主题 程序员 前端求教,有没有懂 flex 布局的
@a132811 chrome version 120 默认 line-height 1.15
338 天前
回复了 awesomePower 创建的主题 程序员 前端求教,有没有懂 flex 布局的
你的例子中:分上下两个 flex row. 在 chrome version 120 下:

第一个 row ,最大的 block 身高= 35px*1.15 + margin(70px) = 110px
第二个 row ,最大的 block 身高= 190px

纵轴剩余: 500px - 110px - 190px = 200px, 两者平分各 100px 。

第一个 row:110+100 = 210px
第二个 row:190+100 = 290px (强制指定 item 的 190px 则不受影响)

---------
BTW ,这个类似主轴分配规则,比如:

```html
<div style="width:400px;display:flex">
<div style="width:100px;flex-grow:1">item-a</div>
<div style="width:100px;flex-grow:2">item-b</div>
</div>
item-a, item-b 会根据 flex-grow 值,分割剩余的 200px(仅当存在剩余空间时)
item-a: 100 + 200px*(1/3) = 166.66
item-b: 100 + 200px*(2/3) = 233.33
```
我一直用的 vscode 自带的快捷键 go forward / go back
mac 的话,按 cmd k cmd+s 看一下你的快捷键是什么
360 天前
回复了 CarlJ9 创建的主题 商业模式 免费浏览器扩展的出路只有被收购吗?
chrome extension 的权限控制太水了,默认就是 On all sites 模式
不知道为什么不改成默认每个 extension 是 when you click extension 模式。
364 天前
回复了 a132811 创建的主题 Go 编程语言 利用泛型实现的 golang 缓存装饰器
@keakon 嗯。
我主要是想确认否有简单优雅的实现(对调用方要简单/直接/安全)、以及更通用的 cache 库。

库本身的复杂性对用户是透明的,内部是否反射+泛型都 ok ,实际上本库的内部就是反射+泛型结合的
2023-12-12 12:40:56 +08:00
回复了 a132811 创建的主题 Go 编程语言 利用泛型实现的 golang 缓存装饰器
@keakon 如果输入用反射而不用泛型,那类型检查就没有了; 输出同理。

或许我没有 get 到你的意思?你是否可以给个伪代码,或者 demo ?

ps: 反射损失的性能很多场景可以忽略不计
1  2  3  4  5  6  7  8  9  10 ... 20  
关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1152 人在线   最高记录 6679   ·     Select Language
创意工作者们的社区
World is powered by solitude
VERSION: 3.9.8.5 · 42ms · UTC 23:45 · PVG 07:45 · LAX 15:45 · JFK 18:45
Developed with CodeLauncher
♥ Do have faith in what you're doing.