请问如下的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个回答

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 年多之前 回复

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

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

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

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

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

图片说明


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'); ```

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

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

没使用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。

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> ```

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文件(不管是否有封面图片)正常切片,拜谢大神。

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树索引为什么可以起到这样的效果?

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 求大神解答

请问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>

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

Java基础知识面试题(2020最新版)

文章目录Java概述何为编程什么是Javajdk1.5之后的三大版本JVM、JRE和JDK的关系什么是跨平台性?原理是什么Java语言有哪些特点什么是字节码?采用字节码的最大好处是什么什么是Java程序的主类?应用程序和小程序的主类有何不同?Java应用程序与小程序之间有那些差别?Java和C++的区别Oracle JDK 和 OpenJDK 的对比基础语法数据类型Java有哪些数据类型switc...

我以为我学懂了数据结构,直到看了这个导图才发现,我错了

数据结构与算法思维导图

技术大佬:我去,你写的 switch 语句也太老土了吧

昨天早上通过远程的方式 review 了两名新来同事的代码,大部分代码都写得很漂亮,严谨的同时注释也很到位,这令我非常满意。但当我看到他们当中有一个人写的 switch 语句时,还是忍不住破口大骂:“我擦,小王,你丫写的 switch 语句也太老土了吧!” 来看看小王写的代码吧,看完不要骂我装逼啊。 private static String createPlayer(PlayerTypes p...

和黑客斗争的 6 天!

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

Linux 会成为主流桌面操作系统吗?

整理 |屠敏出品 | CSDN(ID:CSDNnews)2020 年 1 月 14 日,微软正式停止了 Windows 7 系统的扩展支持,这意味着服役十年的 Windows 7,属于...

讲一个程序员如何副业月赚三万的真实故事

loonggg读完需要3分钟速读仅需 1 分钟大家好,我是你们的校长。我之前讲过,这年头,只要肯动脑,肯行动,程序员凭借自己的技术,赚钱的方式还是有很多种的。仅仅靠在公司出卖自己的劳动时...

学习总结之HTML5剑指前端(建议收藏,图文并茂)

前言学习《HTML5与CSS3权威指南》这本书很不错,学完之后我颇有感触,觉得web的世界开明了许多。这本书是需要有一定基础的web前端开发工程师。这本书主要学习HTML5和css3,看...

女程序员,为什么比男程序员少???

昨天看到一档综艺节目,讨论了两个话题:(1)中国学生的数学成绩,平均下来看,会比国外好?为什么?(2)男生的数学成绩,平均下来看,会比女生好?为什么?同时,我又联想到了一个技术圈经常讨...

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

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

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

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

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

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

新一代神器STM32CubeMonitor介绍、下载、安装和使用教程

关注、星标公众号,不错过精彩内容作者:黄工公众号:strongerHuang最近ST官网悄悄新上线了一款比较强大的工具:STM32CubeMonitor V1.0.0。经过我研究和使用之...

记一次腾讯面试,我挂在了最熟悉不过的队列上……

腾讯后台面试,面试官问:如何自己实现队列?

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

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

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

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

冒泡排序动画(基于python pygame实现)

本项目效果初始截图如下 动画见本人b站投稿:https://www.bilibili.com/video/av95491382 本项目对应github地址:https://github.com/BigShuang python版本:3.6,pygame版本:1.9.3。(python版本一致应该就没什么问题) 样例gif如下 ======================= 大爽歌作,mad

Redis核心原理与应用实践

Redis核心原理与应用实践 在很多场景下都会使用Redis,但是到了深层次的时候就了解的不是那么深刻,以至于在面试的时候经常会遇到卡壳的现象,学习知识要做到系统和深入,不要把Redis想象的过于复杂,和Mysql一样,是个读取数据的软件。 有一个理解是Redis是key value缓存服务器,更多的优点在于对value的操作更加丰富。 安装 yum install redis #yum安装 b...

现代的 “Hello, World”,可不仅仅是几行代码而已

作者 |Charles R. Martin译者 | 弯月,责编 | 夕颜头图 |付费下载自视觉中国出品 | CSDN(ID:CSDNnews)新手...

带了6个月的徒弟当了面试官,而身为高级工程师的我天天修Bug......

即将毕业的应届毕业生一枚,现在只拿到了两家offer,但最近听到一些消息,其中一个offer,我这个组据说客户很少,很有可能整组被裁掉。 想问大家: 如果我刚入职这个组就被裁了怎么办呢? 大家都是什么时候知道自己要被裁了的? 面试软技能指导: BQ/Project/Resume 试听内容: 除了刷题,还有哪些技能是拿到offer不可或缺的要素 如何提升面试软实力:简历, 行为面试,沟通能...

!大部分程序员只会写3年代码

如果世界上都是这种不思进取的软件公司,那别说大部分程序员只会写 3 年代码,恐怕就没有程序员这种职业。

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

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

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

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

为什么你不想学习?只想玩?人是如何一步一步废掉的

不知道是不是只有我这样子,还是你们也有过类似的经历。 上学的时候总有很多光辉历史,学年名列前茅,或者单科目大佬,但是虽然慢慢地长大了,你开始懈怠了,开始废掉了。。。 什么?你说不知道具体的情况是怎么样的? 我来告诉你: 你常常潜意识里或者心理觉得,自己真正的生活或者奋斗还没有开始。总是幻想着自己还拥有大把时间,还有无限的可能,自己还能逆风翻盘,只不是自己还没开始罢了,自己以后肯定会变得特别厉害...

HTTP与HTTPS的区别

面试官问HTTP与HTTPS的区别,我这样回答让他竖起大拇指!

程序员毕业去大公司好还是小公司好?

虽然大公司并不是人人都能进,但我仍建议还未毕业的同学,尽力地通过校招向大公司挤,但凡挤进去,你这一生会容易很多。 大公司哪里好?没能进大公司怎么办?答案都在这里了,记得帮我点赞哦。 目录: 技术氛围 内部晋升与跳槽 啥也没学会,公司倒闭了? 不同的人脉圈,注定会有不同的结果 没能去大厂怎么办? 一、技术氛围 纵观整个程序员技术领域,哪个在行业有所名气的大牛,不是在大厂? 而且众所...

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

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

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

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

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

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

立即提问
相关内容推荐