请问如下的for循环还可以优化吗?花费时间过长50s 1C

public Form1()
{
InitializeComponent();
Stopwatch sw = new Stopwatch();
sw.Start();
//string filePath = @"D:\cp.bin";
string filePath = System.AppDomain.CurrentDomain.SetupInformation.ApplicationBase + @"cp.txt";//设置路径将文件保存在目标文件下

       using (FileStream fs = File.Create(filePath))//优化
       {

double t0 = 0, f0 = 100000d;
//double beta = (f1 - f0) / t1;
double beta = 900000d/4.194304d;
double chirp = 0;
for(int i=0; i<=167772160; i++)
{
t0 += 0.000000025;
chirp = Math.Cos(Math.PI * (2 * f0 + beta * t0) * t0);
chirp = Math.Round(chirp * 2046);
chirp = chirp*2 + 2046;
byte[] b=Encoding.Unicode.GetBytes(chirp.ToString());
fs.Write(b, 0, b.Length);
}
}
sw.Stop();
MessageBox.Show("耗时为: " + sw.ElapsedMilliseconds.ToString() + " ms");
}


5个回答

写文件应该是个很耗时的操作,把需要转换的数据先保存到内存中,循环完成后,再一次性把所有数据写到文件里;

wonderfuljoy
wonderfuljoy 这个循环次数多,产生的数据量也比较大,用memeryStream 保存的话会报outofmemory 异常。
2 年多之前 回复

http://blog.csdn.net/swjtu_yhz/article/details/72778811 写文件确实需要优化 看下对你有没帮助

For循环次数太多了,而且循环里面只有一个变量t0 需要累加 ,
分成多组分别计算chirp. 实测分16组的话,每组只需4s 出结果。
开16个线程同时分别跑。

图片说明

主要还是For循环里的数学计算这块的优化。
写文件的操作C#内部有优化,copy了一些注释如下(http://referencesource.microsoft.com/#mscorlib/system/io/filestream.cs,e23a38af5d11ddd3),
public override void Write(byte[] array, int offset, int count) {
...
// If our buffer has data in it, copy data from the user's array into
// the buffer, and if we can fit it all there, return. Otherwise, write
// the buffer to disk and copy any remaining data into our buffer.
// The assumption here is memcpy is cheaper than disk (or net) IO.
// (10 milliseconds to disk vs. ~20-30 microseconds for a 4K memcpy)
// So the extra copying will reduce the total number of writes, in
// non-pathological cases (ie, write 1 byte, then write for the buffer
// size repeatedly)

...
}

jiajia3407
jiajia3407 线程18耗时为:7403 ms 线程20耗时为:7748 ms 线程19耗时为:8681 ms 线程16耗时为:11982 ms 线程17耗时为:12178 ms 线程14耗时为:16794 ms 线程15耗时为:16855 ms 线程13耗时为:22189 ms 线程12耗时为:24302 ms 线程1耗时为:28049 ms 线程2耗时为:30756 ms 线程11耗时为:31204 ms 线程3耗时为:33524 ms 线程9耗时为:34392 ms 线程10耗时为:34902 ms 线程7耗时为:38401 ms 线程8耗时为:38643 ms 线程6耗时为:39493 ms 线程5耗时为:40116 ms 线程4耗时为:40679 ms
2 年多之前 回复
jiajia3407
jiajia3407 我试过多线程,开了20个线程,但是每个线程所花费的时间相差很大是怎么回事呢?
2 年多之前 回复
jiajia3407
jiajia3407 分成多组分别计算chirp是什么意思?具体该如何做呢?
2 年多之前 回复

io操作很耗资源
所以尽量把fs.Write(b, 0, b.Length);这块代码写到外面
另外由于循环次数比较多。乘法除法是运算里最耗资源的,所以建议循环内的乘法可以改为相应的位移操作。

jiajia3407
jiajia3407 double类型是不能用位操作的
2 年多之前 回复

图片说明


public void Thread9()
{
Stopwatch sw = new Stopwatch();
sw.Start();
string filePath1 = System.AppDomain.CurrentDomain.
SetupInformation.ApplicationBase + @"cp9.txt";
double t0 = 1.6577216d, f0 = 100000d;
double beta = 900000d / 4.194304d;
double chirp = 0;
using (FileStream fs1 = File.Open(filePath1, FileMode.OpenOrCreate, FileAccess.Write))
{
for (int i = 66308865; i <= 74597472; i++)
{
chirp = Math.Cos(Math.PI * (2 * f0 + beta * t0) * t0);
t0 += 0.000000025d;
chirp = Math.Round(chirp * 2046);
chirp = chirp * 2 + 2046;
byte[] b = Encoding.Unicode.GetBytes(chirp.ToString());
fs1.Write(b, 0, b.Length);
}
sw.Stop();
Console.WriteLine("线程9耗时为:{0} ms",
sw.ElapsedMilliseconds.ToString());
}
}


每个线程里的代码都是这样的,for循环的次数都相同,但时间完全不同

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
如何优化计算收益率算法?

算法不够准确 存在问题 1. 没有计算手续费 2. 权重不应该相同 3. 持有20天的股票收益不应看作在当天就实现。 ``` stock_list = ts.get_sz50s().code print(stock_list.head()) ``` 输出: 0 600000 1 600016 2 600019 3 600028 4 600029 Name: code, dtype: object 决定每只股票收益率的决定方法: ``` red_3_s = list() for stock in stock_list: data = daily_data[stock] red3s = pd.Series(0.0, index=range(len(data))) for i in range(len(data)): if is_red_3_soldier(data, i, 3, 0.01, 0.8): red3s[i] = 0.01 else: red3s[i] = 0.00 red_3_s.append(red3s) `````` 优化该算法: ``` rtn = list() for stock in stock_list: data = daily_data[stock] r = pd.Series(0.0, index=range(len(data))) for i in range(20, len(data)): if data.close[i] > 0: r[i] = data.close[i - 20] / data.close[i] - 1 rtn.append(r) ```

如何为简单的Web和数据库应用程序优化响应时间

<div class="post-text" itemprop="text"> <p>I'm new to golang and also to database optimizations. </p> <p>I have simple app written on go and mysql database where send queries initialised through the web.</p> <p>For receiving requests it take around 5s or little bit more? Is it possible somehow to optimize it?</p> <p>Also if refreshing several times, then response could be already 50s and even more, exceptions with "invalid memory address or nil pointer dereference" or "Error 1040: Too many connections could appear".</p> <p>How to avoid this and have all requests to be managiable in a efficient time frame?</p> <p>This is table structure</p> <pre><code> CREATE TABLE sportsmen ( sp_no int(11) NOT NULL, birth_date date NOT NULL, first_name varchar(14) NOT NULL, last_name varchar(16) NOT NULL, gender enum('M','F') NOT NULL, start_date date NOT NULL, PRIMARY KEY (sp_no) ) ENGINE=InnoDB DEFAULT CHARSET=latin1 CREATE TABLE points ( sp_no INT NOT NULL, point INT NOT NULL, date DATE NOT NULL ); </code></pre> <p>Number of records is around 300000 for sportsmen and 1 000 000 for their points.</p> <p>this is function which is called on every request</p> <pre><code>var db *sql.DB func init() { db, _ = sql.Open("mysql", "&lt;connection&gt;?charset=utf8") //checkErr(errcon) err := db.Ping() checkErr(err) yt := reflect.TypeOf(db).Kind() fmt.Printf("%T: %s ", yt, yt) } func sportsmanPoints(w http.ResponseWriter, r *http.Request) { start := time.Now() sportsmen, err := db.Query("SELECT sp_no, first_name FROM sportsmen LIMIT ?,20", rand.Intn(100000)) checkErr(err) for sportsmen.Next() { var spNo string var firstName string err = sportsmen.Scan(&amp;spNo, &amp;firstName) checkErr(err) spPoints, err := db.Query("SELECT max(point) FROM points WHERE sp_no =" + spNo) for spPoints.Next() { var spPoint int err = spPoints.Scan(&amp;spPoint) checkErr(err) points.Data = ​append​(points.Data, Point{Name: firstName, Point: spPoint}) } } data, err := json.Marshal(points.Data) if​ err != ​nil​ { log.Fatal(err) } fmt.Fprintln(w, ​string​(data)) elapsed := time.Since(start) fmt.Println(​"Date:"​, time.Now(), ​"Response time:"​, elapsed) points.Data = ​nil data = ​nil } func​ ​checkErr​(err error) { if​ err != ​nil​ { panic​(err) } } func​ ​main​() { http.HandleFunc(​"/"​, sportsmanPoints) err := http.ListenAndServe(​":9090"​, ​nil​) if​ err != ​nil​ { log.Fatal(​"ListenAndServe: "​, err) } } </code></pre> <p>Thank you.</p> </div>

倒计时交通灯。。。。。

综合作业1:倒计时交通灯 用单片机模拟十字路口的交通灯,采用自动红绿黄交通灯控制,具有固定的红灯、绿灯转换时间间隔,自动切换,每个方向具有倒计时功能。 功能要求: 1)要求南北方向车道和东西方向车道2条交叉道路上的车辆自动交替运行,东西和南北方向各有一组红、绿、黄灯用于指挥交通; 2)红灯的持续时间为55s,绿灯持续时间为50s,闪烁时间为3s; 3)黄灯在绿灯转为红灯之前亮2s; 4)每一种灯亮的时间都用LED数码管进行倒计时显示; 5)如有紧急情况,系统可以禁止普通车辆通行,南北、东西方向都为红灯,时间持续20s,当紧急情况结束后,继续正常工作。 (AT89C51,中断)

一千万数据,查询优化

数据结构 Id ShopId GoodsId 1 1 1 2 1 2 3 1 3 4 1 4 5 1 5 6 2 1 7 2 2 8 2 4 9 2 5 有一千万记录,需要取出拥有商品 2,3,4 的所有店铺 现在直接sql里面筛选,速度50s左右,请各位大神给个优化思路

执行比较大数据量的时候 mysql总是丢失链接 请问怎么处理啊

我要做的是把一张表中所有的utc字段转换成年月日的格式,这张表中大概有四百多万条数据。 我在执行 ``` UPDATE shipxy_out SET date = FROM_UNIXTIME(utc, '%Y年%m月%d日') ``` 的时候总是会出现这样的错误![图片说明](https://img-ask.csdn.net/upload/202002/20/1582206813_381546.png) 请问有什么解决办法吗?

使用短时傅里叶变换分析chirp信号,感觉得到的频率不对

想利用短时傅里叶变换得到chirp信号的时间频率图,有一些疑问。 chirp信号在50s处的频率为4Hz(我觉得终止时间为50s,此时频率为4Hz,那么说明产生的信号在0-50s内对应的频率为0-4Hz,不知道这么理解对不对?),但是经过短时傅里叶变换出来的时频谱如图,明显在50s处频率偏大,请问是我哪里理解错了呢? ![图片说明](https://img-ask.csdn.net/upload/201908/01/1564638842_965862.jpg) 代码如下: ``` fs=40; T=0:1/fs:50; X=chirp(t,0,50,4); [S,F,T,P] = spectrogram(X,256,250,256,1E3); surf(T,F,10*log10(P),'edgecolor','none'); axis tight; view(0,90); xlabel('Time (Seconds)'); ylabel('Hz'); ```

没使用Docker,也没有用fabric-ca,但是区块链超级账本项目fabric创建通道失败,请问怎么解决?

错误如下: gary@Hyperledger:~$ cd /opt/hyperledger/peer gary@Hyperledger:/opt/hyperledger/peer$ export set CORE_PEER_LOCALMSPID=Org1MSP gary@Hyperledger:/opt/hyperledger/peer$ export set CORE_PEER_MSPCONFIGPATH=/opt/hyperledger/fabricconfig/crypto-config/peerOrganizations/org1.qklszzn.com/users/Admin@org1.qklszzn.com/msp/admincerts gary@Hyperledger:/opt/hyperledger/peer$ sudo peer channel create -t 50s -o orderer.qklszzn.com:7050 -c roberttestchannel -f /opt/hyperledger/order/roberttestchannel.tx 2018-10-28 20:36:30.874 CST [channelCmd] InitCmdFactory -> INFO 001 Endorser and orderer connections initialized Error: got unexpected status: BAD_REQUEST -- error authorizing update: error validating DeltaSet: policy for [Group] /Channel/Application not satisfied: Failed to reach implicit threshold of 1 sub-policies, required 1 remaining

关于java程序在linux服务器和windows机器运行效率问题

同样的java程序在linux服务器上要比在windows服务器上慢很多,jdk都是1.7版本。 linux服务器是4U,64核,128G,windows服务器是i7,16G。 写了一个小的demo测试了一下: ``` public static void main(String[] args) { Date date=new Date(); DateFormat format=new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); String time1=format.format(date); System.out.println("开始时间:"+time1); long begin = System.currentTimeMillis(); for(int i=0;i<100000;i++){ for(int j=0;j<100000;j++){ for(int k=0;k<100000;k++){ int a = i+j+k; } } } long end = System.currentTimeMillis(); Date date1=new Date(); String time2=format.format(date1); System.out.println("结束时间:"+time2); System.out.println("运行时间:"+(end-begin)+"ms"); } ``` 在windows机器上运行时间是25s,打成jar包在linux服务器上运行的时间是50s。

ARM 应用开发,在多线程中,定时的功能,求解

问题: 目前程序是,有一个线程实时不断的处理外部来的数据,另一个线程将处理后数据封装组包后发送(主要功能是数据累加),但是发送时间有要求,每隔50s,和每隔10分钟(例如不断读取本地时间0分,10、20、30........分) 目前想到的只有线程一被调用就立即读取本地时间 //数据累加处理代码 ... if(检测整分的是否完成) { //发送整分该发送的数据 ... } else { // 发送要求 50s发送一次的 ... sleep(50); } 但这样的问题,sleep会一直阻塞这个线程,导致该线程数据累加不运行。 请问大虾们,有没有什么好的方法来解决,类似于单片机中断那样,时间到设个标志位,然后去运行该运行的程序

Python运行vibe算法过慢

现在在做毕设,有一部分要用到前景目标提取,我打算用VIBE算法来做,但是同样的算法,Python运行时初始化都要20-50s,我朋友用matlab基本就是1s内最多1s多一点就能完成初始化,虽然Python运行慢,但是也不至于慢这么多吧,而且理论上vibe算法的运行速度应该是比较快的,大佬们看一下是不是写的代码的问题。。。 ``` def initial_background(I_gray, N): t1 = cv2.getTickCount() I_pad = np.pad(I_gray, 1, 'symmetric')#对称填充 height = I_pad.shape[0] width = I_pad.shape[1] samples = np.zeros((height, width, N)) t2 = cv2.getTickCount() time = (t2 - t1) * 1000 / cv2.getTickFrequency() print(time) for i in range(1, height - 1): for j in range(1, width - 1): for n in range(N): x, y = 0, 0 while (x == 0 and y == 0): x = np.random.randint(-1, 1) y = np.random.randint(-1, 1) ri = i + x rj = j + y samples[i, j, n] = I_pad[ri, rj] t3 = cv2.getTickCount() time2 = (t3 - t1) * 1000 / cv2.getTickFrequency() print(time2) samples = samples[1:height - 1, 1:width - 1] return samples ``` 上面是Python的初始化部分代码,大佬们帮忙看看这部分代码有哪些可以优化的。matlab代码我看不懂,也不知道该发哪个,第一次在CSDN上问问题,不知道会不会有人回答。。。

如何优化选择300.000行+的SQl代码

<div class="post-text" itemprop="text"> <p>I need to make XML files for a table that contains 300k+ records.</p> <p>The code takes around 3~4s to finish (Is this acceptable?).</p> <p>Add to that the data retrieval from MySQL, which takes around ~32s to finish (Is this acceptable?):</p> <h3>Query</h3> <pre><code>SELECT `id`, `join_at` FROM girls g WHERE g.del_flg = 0 ORDER BY g.join_at, g.id ASC </code></pre> <p>If I run this single query from the navicat mysql side it still takes around ~20s.</p> <h3>What I tried:</h3> <ol> <li><p>At first, the select query did not work because of a "memory exhausted" error (php.ini - memory_limit = 128M)</p></li> <li><p>After that I changed <code>memory_limit</code> to -1. But I see that many people tell it's bad to change <code>memory_limit</code> into -1</p></li> </ol> <p>So how to optimize the <code>select</code> query for 300k+ records in case of: </p> <ol> <li><p>using PHP, sql, DOMDocument code only</p></li> <li><p>Use options from #1 combined with an indexed column in the database</p></li> <li><p>anything else that you know ...</p></li> </ol> <h3>PHP code with SQL query:</h3> <pre><code>public function getInfo() { MySQL::connect(); try { $select = 'SELECT `id`, `join_at`'; $sql = ' FROM girls g'; $sql .= ' WHERE g.del_flg = 0'; $sql .= ' ORDER BY g.join_at, g.id ASC'; $sql = sprintf($sql, $this-&gt;table); MySQL::$sth = MySQL::$pdo-&gt;prepare($select . $sql); MySQL::$sth-&gt;execute(); while($rows = MySQL::$sth-&gt;fetch(\PDO::FETCH_ASSOC)) { $values[] = array('id' =&gt; $rows['id'], 'join_at' =&gt; $rows['join_at']); } // $rows = MySQL::$sth-&gt;fetchAll(\PDO::FETCH_ASSOC); } catch (\PDOException $e) { return null; } return $values; } </code></pre> <p>I found out that <code>ORDER BY g.join_at, g.id ASC</code> part impacts the execution time. When I remove it, and use PHP instead for sorting, the execution time decreases from ~50s total to ~5s.</p> <p>One more thing is that if I set <code>memory_limit</code> to 128M it leads to a "memory exhausted" error (512M will work). Is there any other solution for this problem?</p> <p>Here are the indexes I currently have on the table:</p> <p><img src="https://i.stack.imgur.com/uFIvE.png" alt="Index"></p> </div>

http 服务器 流文件读取问题

对http这块不了解,请教下各位大神。 情况是这样的: 1,我用C#的一个media player控件播放http服务器的mp3,给控件设置MP3的url路径后,控件会发送一个http请求给服务器,服务器将整首mp3文件下发给控件;这个正常运行; 2,这个下发的过程,一个6M的MP3,控件用了50s才下载完成;是在同一台电脑,http服务器是用IIS。出现50s下载完成的情况,我估计是这个控件接收慢,并不是网络慢,我自己写测试代码读取服务器上的mp3文件,1s都不用就好了。我自己写了服务器测试,我将整个mp3文件用socket的send方法一次写入。情况还是一样,我的测试客户端,瞬间收到整个mp3数据,但是MP3控件还是用了50s; 3,这个50s的时间,我是确定的。我用了抓包软件查看了;所以,我基本确定,是控件本身的设定,导致50s才下载接收完成;这点我想问下,如何设置一个socket的接收速度?? 4,还有一个疑问:这个MP3控件,可以在播放的过程中,拖动进度条,播放后面的数据。如果50s才下载完整首mp3,那么在10s内,拖动到本该20s才能加载的数据,那么这个mp3控件会再次发送网络请求,请求20s后的数据,这点也没问题。我就想问,我在第一次收到mp3控件的请求时,已经将整首mp3文件都写入socket了,但是控件接收了10s后,又再次发送请求了,那么这个socket的后面数据,MP3控件一般是怎么处理的(我估计是丢弃后面的数据)?而我这个socket又需要怎么处理?因为我接收到新的请求是请求20s后的数据,我需要重新创建一个socket去发送20s后的数据了。

大神帮忙看下下面的切片命令有没有什么问题,ffmpeg对mp3文件加密切片问题

1、同样的切片命令,当mp3文件有封面图片时,切片就会失败,下面是切片命令: ffmpeg -y -i E:\音视频转换后文件\没有封面.mp3 -hls_time 50 -hls_list_size 0 -hls_key_info_file E:\音视频转换后文件\key_info_mp4_1 -hls_playlist_type vod -hls_segment_filename E:\音视频转换后文件\a_%d.ts E:\音视频转换后文件\playlist.m3u8 2、没有封面图片的mp3切片后,m3u8文件内容(正常的),如图: ![图片说明](https://img-ask.csdn.net/upload/201901/13/1547366057_165629.png) 3、有封面图片的mp3文件(该文件总时长26分钟,切片时长50s)切片后,m3u8文件内容(不正常,而且ts文件始终只有一个),如图: ![图片说明](https://img-ask.csdn.net/upload/201901/13/1547366217_119069.png) 请问大神如何写加密切片命令才能对所有mp3文件(不管是否有封面图片)正常切片,拜谢大神。

Mybatis执行insert all 的时候 越来越慢是什么原因

情况描述: 数据库是Oracle 每次从表里取出10000条数据 进行计算 结果大概500~1000条 然后把这几百条数据批量插入数据库中 插入的表没有索引 就是很简单的几个字段 第一次执行 大概3S左右就插入成功了 第二次执行一下要50S左右 再往下越来越长。。不知道什么原因 有大佬遇到过吗 还有就是 当这个insert all变慢之后 对数据库进行 ddl操作都会卡死。。。而dml没有影响~ java这边数据库连接池用的druid ![这是第一次](https://img-ask.csdn.net/upload/201808/22/1534902304_166443.png) ![这是第二次](https://img-ask.csdn.net/upload/201808/22/1534902180_574360.png) sql如下 ``` <insert id="batchInsertArriveInfo" parameterType="java.util.List" useGeneratedKeys="false"> insert all <foreach collection="list" item="info" index="index"> into T_ARRIVAL_STATION_INFORMATION (BUS_PATH_ID,STATION_SN,TASK_STATUS,ARR_TIME,BUS_PATH_NAME,RUN_FLAG,VEHICLE_ID,station_name,station_id) values ( #{info.busPathId},#{info.stationSn},#{info.taskStatus}, #{info.arrTime},#{info.busPathName},#{info.runFlag}, #{info.vehicleId},#{info.stationName},#{info.stationId} ) </foreach> select 1 from dual </insert> ```

Oracle中重复率很高的字段创建B树索引,为什么性能可以得到大幅提升

请教一个让我不解的问题: 我有一张表TT,数据大概是240W,其中的一个字段COL1的值只有‘0’和‘1’两个。现在有如下查询:SELECT COL2,SUM(NVL(COL3,0) * nvl(COL4,0)) FROM TT WHERE COL1 = '0' GROUP BY COL2; 在查询耗时大概是 50s。 为了提高性能,在TT表的COL1字段上创建了位图索引,查询耗时变为 2s 但是由于我需要对TT表做大量的Insert和Update操作,位图索引锁表的风险很大,所以只能放弃使用。 因为TT表的数据量还在增大,我们的DBA建议我把这个表修改为分区表,但是,我自己又不想动生产的数据库。所以在COL1上建了一个普通B树索引试了下,发现性能大幅提升,耗时也是2s左右,B树索引起了很大作用。 在我的概念里,重复率高的字段是肯定不适合建B树索引的,强制使用B树索引反而会因为增加索引开销,比全表扫描还要慢些。所以请教各位高手,在COL1字段上建B树索引为什么可以起到这样的效果?

请问mpandroidchart如何实现动画连续不断的重载,动画如何暂停

新手程序员一枚,现在需要我要做一个连续不断的波形图,因为要实现手势操作,所以采用了mpandroidchart ,我在示例代码上面进行改动的,但是我无论如何只能实现一次动画效果。求大神们帮助,现在附上代码 public class LineWaveActivity extends DemoBase implements OnSeekBarChangeListener, OnChartGestureListener, OnChartValueSelectedListener { private LineChart mChart; private SeekBar mSeekBarX, mSeekBarY; private TextView tvX, tvY; // -----------------波形曲线可能会用到的参数(尖波)-------------- private List<Map<String, Object>> month = new ArrayList<Map<String, Object>>(); private List<Map<String, Object>> data = new ArrayList<Map<String, Object>>(); // 数据 // x轴数据——单位秒(s) private String[] mTimes = new String[] { "00:00s", "00:10s", "00:20s", "00:30s", "00:40s", "00:50s", "00:60s", "00:70s", "00:80s", "00:90s", "00:10s", "01:10s", "01:20s", "01:30s", "01:40s", "01:50s", "01:60s", "01:70s", "01:80s", "01:90s", "02:00s", "02:10s", "02:20s", "02:30s", "02:40s", "02:50s", "02:60s", "02:70s", "02:80s", "02:90s", "03:00s", "03:10s", "03:20s", "03:30s", "03:40s", "03:50s", "03:60s", "03:70s", "03:80s", "03:90s", "04:00s", "04:10s", "04:20s", "04:30s", "04:40s", "04:50s", "04:60s", "04:70s", "04:80s", "04:90s", "05:00s", "05:10s", "05:20s", "05:30s", "05:40s", "05:50s", "05:60s", "05:70s", "05:80s", "05:90s", "06:00s" }; // y轴数据——单位(n/m^2) private int[] arrs = { 0, 0, 0, 0, 0, 0, 5, -10, 15, -20, 25, -25, 20, -15, 10, -5, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 5, -10, 15, -20, 25, -25, 20, -15, 10, -5, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 5, -10, 15, -20, 25, -25, 20, -15, 10, -5, 0, 0, 0, 0, 0 }; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); // 设置窗体全屏 getWindow().setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN, WindowManager.LayoutParams.FLAG_FULLSCREEN); setContentView(R.layout.activity_linechart); // ---------------波形曲线操作代码块---------------------- Map<String, Object> map = null; for (int i = 0; i < mTimes.length; i++) { map = new HashMap<String, Object>(); map.put("times", mTimes[i]); month.add(map); } Map<String, Object> dataMap = null; for (int i = 0; i < arrs.length; i++) { dataMap = new HashMap<String, Object>(); dataMap.put("ranges", arrs[i]); data.add(dataMap); } // ---------------波形曲线操作代码块---------------------- tvX = (TextView) findViewById(R.id.tvXMax); tvY = (TextView) findViewById(R.id.tvYMax); mSeekBarX = (SeekBar) findViewById(R.id.seekBar1); mSeekBarY = (SeekBar) findViewById(R.id.seekBar2); mSeekBarX.setProgress(250); mSeekBarY.setProgress(100); mSeekBarY.setOnSeekBarChangeListener(this); mSeekBarX.setOnSeekBarChangeListener(this); mChart = (LineChart) findViewById(R.id.chart1); // ChartGestureListener手势监听器,可以使得 chart与手势操作进行交互。 mChart.setOnChartGestureListener(this); // 设置表格上的点,被点击的时候,的回调函数 mChart.setOnChartValueSelectedListener(this); // 设置图表内格子背景是否显示,默认是false mChart.setDrawGridBackground(false); // 数据描述 // 如果没有数据的时候,会显示这个"You need to provide data for the chart.",类似listview的emtpyview mChart.setDescription(""); mChart.setNoDataTextDescription("你需要为图表添加必要的数据!"); // 设置点击value的时候,是否高亮显示 mChart.setHighlightEnabled(true); // 设置是否可以手势操作 mChart.setTouchEnabled(true); // 启用/禁用拖动(平移)图表。 mChart.setDragEnabled(true); // 启用/禁用缩放图表上的两个轴。 mChart.setScaleEnabled(true); // 启用/禁用x轴缩放 mChart.setScaleXEnabled(true); // 启用/禁用y轴缩放 mChart.setScaleYEnabled(true); // 如果设置为false,那么x轴,y轴可以分别放大 mChart.setPinchZoom(false); // 设置背景颜色 // mChart.setBackgroundColor(Color.GRAY); MyMarkerView mv = new MyMarkerView(this, R.layout.custom_marker_view); mChart.setMarkerView(mv); // 设置x轴相关参数 LimitLine llXAxis = new LimitLine(10f, "警戒线"); llXAxis.setLineWidth(4f); llXAxis.enableDashedLine(10f, 10f, 10f); llXAxis.setLabelPosition(LimitLabelPosition.RIGHT_BOTTOM); llXAxis.setTextSize(10f); XAxis xAxis = mChart.getXAxis(); // xAxis.setValueFormatter(new MyCustomXAxisValueFormatter()); // xAxis.addLimitLine(llXAxis); // add x-axis limit line Typeface tf = Typeface.createFromAsset(getAssets(), "OpenSans-Regular.ttf"); LimitLine ll1 = new LimitLine(50f, "Upper Limit"); // 设置警戒线粗细 ll1.setLineWidth(10f); // 设置警戒线间隔大小(间隔宽度,线段位置,线段宽度) ll1.enableDashedLine(40f, 40f, 40f); ll1.setLabelPosition(LimitLabelPosition.RIGHT_TOP); ll1.setTextSize(10f); // 设置字体样式 ll1.setTypeface(tf); LimitLine ll2 = new LimitLine(-50f, "Lower Limit"); ll2.setLineWidth(10f); ll2.enableDashedLine(40f, 40f, 40f); ll2.setLabelPosition(LimitLabelPosition.RIGHT_BOTTOM); ll2.setTextSize(10f); ll2.setTypeface(tf); YAxis leftAxis = mChart.getAxisLeft(); leftAxis.removeAllLimitLines(); // reset all limit lines to avoid // overlapping lines leftAxis.addLimitLine(ll1); leftAxis.addLimitLine(ll2); // 设置y轴最大值 leftAxis.setAxisMaxValue(50f); // 设置y轴最小值 leftAxis.setAxisMinValue(-50f); // 设置y轴起始点是否为0 leftAxis.setStartAtZero(false); // leftAxis.setYOffset(20f); // 设置横向表格为虚线 leftAxis.enableGridDashedLine(10f, 10f, 0f); leftAxis.setDrawLimitLinesBehindData(true); // 设置隐藏右边的坐标轴 mChart.getAxisRight().setEnabled(false); // 设置相对于x,y的放大倍率 // mChart.getViewPortHandler().setMaximumScaleY(20f); // mChart.getViewPortHandler().setMaximumScaleX(20f); // mChart.setVisibleXRange(20);//设置频幕能显示点的数量,要和MAX和Min结合起来使用 // mChart.setVisibleYRange(20f, AxisDependency.LEFT); // mChart.centerViewTo(20, 50, AxisDependency.LEFT); //设置绘图事件,单位——毫秒,绘图程序入口!!!!!!!!!!!!! setData(45, 100); mChart.animateX(6000, Easing.EasingOption.EaseInOutQuart); mChart.invalidate();// 界面刷新 Legend l = mChart.getLegend(); // l.setPosition(LegendPosition.LEFT_OF_CHART);//设置中轴线向右移 l.setForm(LegendForm.LINE);// 设置图表最下面显示的类型 } @Override public void onProgressChanged(SeekBar seekBar, int progress, boolean fromUser) { tvX.setText("" + (mSeekBarX.getProgress())); tvY.setText("" + (mSeekBarY.getProgress())); setData(mSeekBarX.getProgress(), mSeekBarY.getProgress()); // 刷新图标 mChart.invalidate(); } // 进度条拖动开始时候调用 @Override public void onStartTrackingTouch(SeekBar seekBar) { // TODO Auto-generated method stub } // 进度条拖动完成之后调用 @Override public void onStopTrackingTouch(SeekBar seekBar) { // TODO Auto-generated method stub } private void setData(int count1, int count2) { count1 = month.size(); count2 = data.size(); ArrayList<String> xVals = new ArrayList<String>(); ArrayList<Entry> yVals = new ArrayList<Entry>(); // x轴显示数据操作 for (int i = 0; i < count1; i++) { Map<String, Object> data = month.get(i); xVals.add(data.get("times").toString()); } // y轴显示数据操作 for (int i = 0; i < count2; i++) { Map<String, Object> data2 = data.get(i); yVals.add(new Entry(Integer .parseInt(data2.get("ranges").toString()), i)); } // create a dataset and give it a type LineDataSet set1 = new LineDataSet(yVals, "——————"); set1.setFillAlpha(110);// 设置填充颜色透明度 set1.setFillColor(Color.RED); // 设置线的样式 set1.enableDashedLine(10f, 5f, 0f); // set1.enableDashedHighlightLine(10f, 5f, 0f); set1.setColor(Color.BLACK); set1.setCircleColor(Color.BLACK); set1.setLineWidth(1f); set1.setCircleSize(4f); set1.setDrawCircleHole(true);// 点的圆圈样式,true为空心点,flase为实心点 set1.setValueTextSize(9f); set1.setFillAlpha(65); set1.setFillColor(Color.BLACK); // set1.setDrawFilled(true); // set1.setShader(new LinearGradient(0, 0, 0, mChart.getHeight(), // Color.BLACK, Color.WHITE, Shader.TileMode.MIRROR)); ArrayList<LineDataSet> dataSets = new ArrayList<LineDataSet>(); dataSets.add(set1); // add the datasets // create a data object with the datasets LineData data = new LineData(xVals, dataSets); // set data Log.i("SumLog", "开始为图形设置数据"); mChart.setData(data); } @Override public void onChartGestureStart(MotionEvent me, ChartTouchListener.ChartGesture lastPerformedGesture) { Log.i("Gesture", "START"); } @Override public void onChartGestureEnd(MotionEvent me, ChartTouchListener.ChartGesture lastPerformedGesture) { Log.i("Gesture", "END, lastGesture: " + lastPerformedGesture); if (lastPerformedGesture != ChartTouchListener.ChartGesture.SINGLE_TAP) mChart.highlightValues(null); } @Override public void onChartLongPressed(MotionEvent me) { Log.i("LongPress", "Chart longpressed."); } @Override public void onChartDoubleTapped(MotionEvent me) { Log.i("DoubleTap", "Chart double-tapped."); } @Override public void onChartSingleTapped(MotionEvent me) { Log.i("SingleTap", "Chart single-tapped."); } @Override public void onChartFling(MotionEvent me1, MotionEvent me2, float velocityX, float velocityY) { Log.i("Fling", "Chart flinged. VeloX: " + velocityX + ", VeloY: " + velocityY); } @Override public void onChartScale(MotionEvent me, float scaleX, float scaleY) { Log.i("Scale / Zoom", "ScaleX: " + scaleX + ", ScaleY: " + scaleY); } @Override public void onChartTranslate(MotionEvent me, float dX, float dY) { Log.i("Translate / Move", "dX: " + dX + ", dY: " + dY); } @Override public void onValueSelected(Entry e, int dataSetIndex, Highlight h) { Log.i("Entry selected", e.toString()); Log.i("", "low: " + mChart.getLowestVisibleXIndex() + ", high: " + mChart.getHighestVisibleXIndex()); } @Override public void onNothingSelected() { Log.i("Nothing selected", "Nothing selected."); } } 请问各位,如何实现一个可用按钮控制的连续不断的波形效果,比较急额,卡了四天了

使用PHP创建大型xml文件的最佳方法是什么?

<div class="post-text" itemprop="text"> <p>I try to create a xml file with php.</p> <p>As file is an extract of mySQL database, the recordset may contain around 90000 rows. So generate the xml file is slow, around 50s.</p> <p>I don't want to make a dump, but only create a file to send to Flashbuilder to create a dataprovider.</p> <p>I try to use several process:</p> <pre><code>DOMDocument XmlWriter SimpleXMLElement </code></pre> <p>But with those methods, time to create file is the same.</p> <p>I made another test on server side, with this directive : <code>ini_set('memory_limit','-1');</code></p> <p>Do you know another approach, to write large xml file too speed.</p> <p>Thanks for helping.</p> </div>

hyperledger fabric 1.1.0 solo模式多机部署问题

在部署peer 结点并且创建channel(peer channel create -o orderer.example.com:7050 -t 50s -c mychannel -f ./channel-artifacts/mychannel.tx)时,报错如下 2018-09-16 04:00:35.140 UTC [msp] setupSigningIdentity -> DEBU 035 Signing identity expires at 2028-09-13 03:27:21 +0000 UTC 2018-09-16 04:00:35.140 UTC [msp] Validate -> DEBU 036 MSP Org1MSP validating identity 2018-09-16 04:00:35.140 UTC [msp] GetDefaultSigningIdentity -> DEBU 037 Obtaining default signing identity 2018-09-16 04:00:35.140 UTC [grpc] Printf -> DEBU 038 parsed scheme: "" 2018-09-16 04:00:35.141 UTC [grpc] Printf -> DEBU 039 scheme "" not registered, fallback to default scheme 2018-09-16 04:00:35.141 UTC [grpc] Printf -> DEBU 03a ccResolverWrapper: sending new addresses to cc: [{orderer.example.com:7050 0 <nil>}] 2018-09-16 04:00:35.141 UTC [grpc] Printf -> DEBU 03b ClientConn switching balancer to "pick_first" 2018-09-16 04:00:35.141 UTC [grpc] Printf -> DEBU 03c pickfirstBalancer: HandleSubConnStateChange: 0xc4201e87f0, CONNECTING 2018-09-16 04:00:35.142 UTC [grpc] Printf -> DEBU 03d pickfirstBalancer: HandleSubConnStateChange: 0xc4201e87f0, READY 2018-09-16 04:00:35.142 UTC [channelCmd] InitCmdFactory -> INFO 03e Endorser and orderer connections initialized 2018-09-16 04:00:35.142 UTC [msp] GetDefaultSigningIdentity -> DEBU 03f Obtaining default signing identity 2018-09-16 04:00:35.143 UTC [msp] GetDefaultSigningIdentity -> DEBU 040 Obtaining default signing identity 2018-09-16 04:00:35.143 UTC [msp/identity] Sign -> DEBU 041 Sign: plaintext: 0AA2060A074F7267314D53501296062D...53616D706C65436F6E736F727469756D 2018-09-16 04:00:35.143 UTC [msp/identity] Sign -> DEBU 042 Sign: digest: DC3500D168C423A486C0F683F5DF55BFE21B7EA850AA349C0D007546157C15AC 2018-09-16 04:00:35.143 UTC [msp] GetDefaultSigningIdentity -> DEBU 043 Obtaining default signing identity 2018-09-16 04:00:35.143 UTC [msp] GetDefaultSigningIdentity -> DEBU 044 Obtaining default signing identity 2018-09-16 04:00:35.143 UTC [msp/identity] Sign -> DEBU 045 Sign: plaintext: 0AD9060A1508021A0608E3AAF7DC0522...4A549260CA04773C47CF17A70D57D107 2018-09-16 04:00:35.144 UTC [msp/identity] Sign -> DEBU 046 Sign: digest: D717D2150B425501D954A480D4A4DFE4D0861F3E3AE76791722755A46BB07707 2018-09-16 04:00:35.144 UTC [grpc] Printf -> DEBU 047 parsed scheme: "" 2018-09-16 04:00:35.144 UTC [grpc] Printf -> DEBU 048 scheme "" not registered, fallback to default scheme 2018-09-16 04:00:35.144 UTC [grpc] Printf -> DEBU 049 ccResolverWrapper: sending new addresses to cc: [{orderer.example.com:7050 0 <nil>}] 2018-09-16 04:00:35.144 UTC [grpc] Printf -> DEBU 04a ClientConn switching balancer to "pick_first" 2018-09-16 04:00:35.144 UTC [grpc] Printf -> DEBU 04b pickfirstBalancer: HandleSubConnStateChange: 0xc4201e9120, CONNECTING 2018-09-16 04:00:35.145 UTC [grpc] Printf -> DEBU 04c pickfirstBalancer: HandleSubConnStateChange: 0xc4201e9120, READY Error: got unexpected status: BAD_REQUEST -- error authorizing update: error validating DeltaSet: invalid mod_policy for element [Policy] /Channel/Application/Admins: mod_policy not set 求大神解答

Mysql表插入性能

<div class="post-text" itemprop="text"> <p>I have table with following schema: <a href="http://i.imgur.com/jn2nrFT.png" rel="nofollow">http://i.imgur.com/jn2nrFT.png</a></p> <p>Its MySQL, running on InnoDB, on basic Digital Ocean host ( 512 MB, 1 CPU ). I am using <strong>PHP/Doctrine</strong>, and in my code, i do something like</p> <pre><code>for( $i = 0; $i &lt; 5000; ++$i ) { $row = findRowInTable(); if (! $row ) { insertNewRow(); } } $em-&gt;flush(); </code></pre> <p>It's slow, it takes something like 20s when table is empty, and 50s when table have 5000 rows. </p> <p>How can I optimize it? I will be adding at most 5K rows, but I need to get this process under 120 secs even if table will be 200K rows long</p> </div>

在中国程序员是青春饭吗?

今年,我也32了 ,为了不给大家误导,咨询了猎头、圈内好友,以及年过35岁的几位老程序员……舍了老脸去揭人家伤疤……希望能给大家以帮助,记得帮我点赞哦。 目录: 你以为的人生 一次又一次的伤害 猎头界的真相 如何应对互联网行业的「中年危机」 一、你以为的人生 刚入行时,拿着傲人的工资,想着好好干,以为我们的人生是这样的: 等真到了那一天,你会发现,你的人生很可能是这样的: ...

程序员请照顾好自己,周末病魔差点一套带走我。

程序员在一个周末的时间,得了重病,差点当场去世,还好及时挽救回来了。

和黑客斗争的 6 天!

互联网公司工作,很难避免不和黑客们打交道,我呆过的两家互联网公司,几乎每月每天每分钟都有黑客在公司网站上扫描。有的是寻找 Sql 注入的缺口,有的是寻找线上服务器可能存在的漏洞,大部分都...

搜狗输入法也在挑战国人的智商!

故事总是一个接着一个到来...上周写完《鲁大师已经彻底沦为一款垃圾流氓软件!》这篇文章之后,鲁大师的市场工作人员就找到了我,希望把这篇文章删除掉。经过一番沟通我先把这篇文章从公号中删除了...

总结了 150 余个神奇网站,你不来瞅瞅吗?

原博客再更新,可能就没了,之后将持续更新本篇博客。

副业收入是我做程序媛的3倍,工作外的B面人生是怎样的?

提到“程序员”,多数人脑海里首先想到的大约是:为人木讷、薪水超高、工作枯燥…… 然而,当离开工作岗位,撕去层层标签,脱下“程序员”这身外套,有的人生动又有趣,马上展现出了完全不同的A/B面人生! 不论是简单的爱好,还是正经的副业,他们都干得同样出色。偶尔,还能和程序员的特质结合,产生奇妙的“化学反应”。 @Charlotte:平日素颜示人,周末美妆博主 大家都以为程序媛也个个不修边幅,但我们也许...

MySQL数据库面试题(2020最新版)

文章目录数据库基础知识为什么要使用数据库什么是SQL?什么是MySQL?数据库三大范式是什么mysql有关权限的表都有哪几个MySQL的binlog有有几种录入格式?分别有什么区别?数据类型mysql有哪些数据类型引擎MySQL存储引擎MyISAM与InnoDB区别MyISAM索引与InnoDB索引的区别?InnoDB引擎的4大特性存储引擎选择索引什么是索引?索引有哪些优缺点?索引使用场景(重点)...

如果你是老板,你会不会踢了这样的员工?

有个好朋友ZS,是技术总监,昨天问我:“有一个老下属,跟了我很多年,做事勤勤恳恳,主动性也很好。但随着公司的发展,他的进步速度,跟不上团队的步伐了,有点...

我入职阿里后,才知道原来简历这么写

私下里,有不少读者问我:“二哥,如何才能写出一份专业的技术简历呢?我总感觉自己写的简历太烂了,所以投了无数份,都石沉大海了。”说实话,我自己好多年没有写过简历了,但我认识的一个同行,他在阿里,给我说了一些他当年写简历的方法论,我感觉太牛逼了,实在是忍不住,就分享了出来,希望能够帮助到你。 01、简历的本质 作为简历的撰写者,你必须要搞清楚一点,简历的本质是什么,它就是为了来销售你的价值主张的。往深...

优雅的替换if-else语句

场景 日常开发,if-else语句写的不少吧??当逻辑分支非常多的时候,if-else套了一层又一层,虽然业务功能倒是实现了,但是看起来是真的很不优雅,尤其是对于我这种有强迫症的程序"猿",看到这么多if-else,脑袋瓜子就嗡嗡的,总想着解锁新姿势:干掉过多的if-else!!!本文将介绍三板斧手段: 优先判断条件,条件不满足的,逻辑及时中断返回; 采用策略模式+工厂模式; 结合注解,锦...

离职半年了,老东家又发 offer,回不回?

有小伙伴问松哥这个问题,他在上海某公司,在离职了几个月后,前公司的领导联系到他,希望他能够返聘回去,他很纠结要不要回去? 俗话说好马不吃回头草,但是这个小伙伴既然感到纠结了,我觉得至少说明了两个问题:1.曾经的公司还不错;2.现在的日子也不是很如意。否则应该就不会纠结了。 老实说,松哥之前也有过类似的经历,今天就来和小伙伴们聊聊回头草到底吃不吃。 首先一个基本观点,就是离职了也没必要和老东家弄的苦...

2020阿里全球数学大赛:3万名高手、4道题、2天2夜未交卷

阿里巴巴全球数学竞赛( Alibaba Global Mathematics Competition)由马云发起,由中国科学技术协会、阿里巴巴基金会、阿里巴巴达摩院共同举办。大赛不设报名门槛,全世界爱好数学的人都可参与,不论是否出身数学专业、是否投身数学研究。 2020年阿里巴巴达摩院邀请北京大学、剑桥大学、浙江大学等高校的顶尖数学教师组建了出题组。中科院院士、美国艺术与科学院院士、北京国际数学...

男生更看重女生的身材脸蛋,还是思想?

往往,我们看不进去大段大段的逻辑。深刻的哲理,往往短而精悍,一阵见血。问:产品经理挺漂亮的,有点心动,但不知道合不合得来。男生更看重女生的身材脸蛋,还是...

程序员为什么千万不要瞎努力?

本文作者用对比非常鲜明的两个开发团队的故事,讲解了敏捷开发之道 —— 如果你的团队缺乏统一标准的环境,那么即使勤劳努力,不仅会极其耗时而且成果甚微,使用...

为什么程序员做外包会被瞧不起?

二哥,有个事想询问下您的意见,您觉得应届生值得去外包吗?公司虽然挺大的,中xx,但待遇感觉挺低,马上要报到,挺纠结的。

当HR压你价,说你只值7K,你该怎么回答?

当HR压你价,说你只值7K时,你可以流畅地回答,记住,是流畅,不能犹豫。 礼貌地说:“7K是吗?了解了。嗯~其实我对贵司的面试官印象很好。只不过,现在我的手头上已经有一份11K的offer。来面试,主要也是自己对贵司挺有兴趣的,所以过来看看……”(未完) 这段话主要是陪HR互诈的同时,从公司兴趣,公司职员印象上,都给予对方正面的肯定,既能提升HR的好感度,又能让谈判气氛融洽,为后面的发挥留足空间。...

面试:第十六章:Java中级开发(16k)

HashMap底层实现原理,红黑树,B+树,B树的结构原理 Spring的AOP和IOC是什么?它们常见的使用场景有哪些?Spring事务,事务的属性,传播行为,数据库隔离级别 Spring和SpringMVC,MyBatis以及SpringBoot的注解分别有哪些?SpringMVC的工作原理,SpringBoot框架的优点,MyBatis框架的优点 SpringCould组件有哪些,他们...

面试阿里p7,被按在地上摩擦,鬼知道我经历了什么?

面试阿里p7被问到的问题(当时我只知道第一个):@Conditional是做什么的?@Conditional多个条件是什么逻辑关系?条件判断在什么时候执...

面试了一个 31 岁程序员,让我有所触动,30岁以上的程序员该何去何从?

最近面试了一个31岁8年经验的程序猿,让我有点感慨,大龄程序猿该何去何从。

大三实习生,字节跳动面经分享,已拿Offer

说实话,自己的算法,我一个不会,太难了吧

程序员垃圾简历长什么样?

已经连续五年参加大厂校招、社招的技术面试工作,简历看的不下于万份 这篇文章会用实例告诉你,什么是差的程序员简历! 疫情快要结束了,各个公司也都开始春招了,作为即将红遍大江南北的新晋UP主,那当然要为小伙伴们做点事(手动狗头)。 就在公众号里公开征简历,义务帮大家看,并一一点评。《启舰:春招在即,义务帮大家看看简历吧》 一石激起千层浪,三天收到两百多封简历。 花光了两个星期的所有空闲时...

《Oracle Java SE编程自学与面试指南》最佳学习路线图2020年最新版(进大厂必备)

正确选择比瞎努力更重要!

《Oracle Java SE编程自学与面试指南》最佳学习路线图(2020最新版)

正确选择比瞎努力更重要!

都前后端分离了,咱就别做页面跳转了!统统 JSON 交互

文章目录1. 无状态登录1.1 什么是有状态1.2 什么是无状态1.3 如何实现无状态1.4 各自优缺点2. 登录交互2.1 前后端分离的数据交互2.2 登录成功2.3 登录失败3. 未认证处理方案4. 注销登录 这是本系列的第四篇,有小伙伴找不到之前文章,松哥给大家列一个索引出来: 挖一个大坑,Spring Security 开搞! 松哥手把手带你入门 Spring Security,别再问密...

字节跳动面试官竟然问了我JDBC?

轻松等回家通知

面试官:你连SSO都不懂,就别来面试了

大厂竟然要考我SSO,卧槽。

阿里面试官让我用Zk(Zookeeper)实现分布式锁

他可能没想到,我当场手写出来了

终于,月薪过5万了!

来看几个问题想不想月薪超过5万?想不想进入公司架构组?想不想成为项目组的负责人?想不想成为spring的高手,超越99%的对手?那么本文内容是你必须要掌握的。本文主要详解bean的生命...

自从喜欢上了B站这12个UP主,我越来越觉得自己是个废柴了!

不怕告诉你,我自从喜欢上了这12个UP主,哔哩哔哩成为了我手机上最耗电的软件,几乎每天都会看,可是吧,看的越多,我就越觉得自己是个废柴,唉,老天不公啊,不信你看看…… 间接性踌躇满志,持续性混吃等死,都是因为你们……但是,自己的学习力在慢慢变强,这是不容忽视的,推荐给你们! 都说B站是个宝,可是有人不会挖啊,没事,今天咱挖好的送你一箩筐,首先啊,我在B站上最喜欢看这个家伙的视频了,为啥 ,咱撇...

代码注释如此沙雕,会玩还是你们程序员!

某站后端代码被“开源”,同时刷遍全网的,还有代码里的那些神注释。 我们这才知道,原来程序员个个都是段子手;这么多年来,我们也走过了他们的无数套路… 首先,产品经理,是永远永远吐槽不完的!网友的评论也非常扎心,说看这些代码就像在阅读程序员的日记,每一页都写满了对产品经理的恨。 然后,也要发出直击灵魂的质问:你是尊贵的付费大会员吗? 这不禁让人想起之前某音乐app的穷逼Vip,果然,穷逼在哪里都是...

立即提问
相关内容推荐