结果是觉得有点太大,在车上看简直扑街。。。
为了搞个下载机,买了个树莓派,结果还是坏的。。扑街。。
为了打游戏上了个电信,结果上传只有2mkbps,扑街。。。
总结是冲动消费不可取。。。。
结果是觉得有点太大,在车上看简直扑街。。。
为了搞个下载机,买了个树莓派,结果还是坏的。。扑街。。
为了打游戏上了个电信,结果上传只有2mkbps,扑街。。。
总结是冲动消费不可取。。。。
(totalrow+singlePageSize-1 )/singlePageSize
为什么说是个小trick呢
直观上我们做分页算法应该是这样的
return totalSize%singlePageSize!=0?totalSize/singlePageSize+1:totalSize/singlePageSize;
但是呢,最开始提到的算法,如果total/single有余数,由于int的直接截取的性质,所以totalrow/singlePageSize是向下取整了,但是这个余数加上(singlePageSize-1)再去除singlePagesize就刚好能够+1
否则因为(singePageSize-1)/SinglePageSize向下取整的性质,就变成了+0。所以说这里这个小Trick我还真没想到过,很巧妙
中央认证服务器:用于生成ticket
应用服务器:要约定一个页面用于接收ticket,并写入相同域名内的cookie
生成ticket的机制
ticket的失效机制
每次验证ticket都需要到中央服务器认证:增加内部流量
通过租约:会有失效时间,不能保证马上所有位置都失效
中央服务器push到业务端通知失效:中央服务器压力大
室友自杀,送医院,然后我被吓尿了。。。T_T。。。
真的要好好重视精神卫生健康啊
package main import "fmt" func main() { var nums = [] int{5, 4, 3, 2, 1, 4, 5, 3} sort(nums, len(nums)) fmt.Println(nums) } func sort(nums []int, length int) { for i := 0; i < length; i++ { for j := 0; j < length; j++ { if (nums[i] > nums[j]) { swap(&nums[i], &nums[j]) } } } } func swap(a *int, b *int) { *a, *b = *b, *a }
分别从用途,风险和好处来思考了下,只是很粗浅的思考,刚好我所在的项目就是做账号平台,才用来思考