明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 604|回复: 2

[提问] 获得列表内指定索引范围内的列表,求优化

[复制链接]
发表于 2016-10-31 14:45:08 | 显示全部楼层 |阅读模式
  1. ;提取表         表 开始 结束索引值
  2. ;例:(setq a '(1 2 3 4 5 6 7 8 9))
  3. ;用法:(tiqulst a 3 6)
  4. ;当一个表是一个1M以上的文件的字符串,vl-string->list后就会很慢,半个小时都有
  5. (defun tiqulst (lst sta end / newpl num)
  6.   (if (< end (+ (length lst) 1))
  7.     (progn
  8.       (setq t1 (getvar "CDATE"));记录开始时间
  9.       (setq newpl '())
  10.       (repeat (- end sta)
  11.   (setq num (list (nth sta lst)))
  12.   (setq newpl (append  newpl num))
  13.   (setq sta (1+ sta))
  14.   )
  15.       )
  16.     ;else
  17.     (alert "tiqulst中end大于lst的长度")
  18.     )
  19.   (setq t2 (* (- (getvar "CDATE") t1) 1e6));秒
  20.   (princ "\ntiqulst用时")
  21.   (princ t2)
  22.   newpl
  23.   )
说白了,就是substr,但转成string之后会丢数据。如果是C语言就简单得多,1秒都不用。
"觉得好,就打赏"
还没有人打赏,支持一下
发表于 2016-11-3 12:07:03 | 显示全部楼层
  1. (defun tt (lst sta end / newpl num)
  2.   (setq t1 (getvar "CDATE"));记录开始时间
  3.   (repeat(-(min end(length lst))(setq sta(max 0 sta)))
  4.     (setq newpl(cons(nth sta lst)newpl)
  5.           sta(1+ sta)))
  6.   (princ "\ntt用时")
  7.   (princ (* (- (getvar "CDATE") t1) 1e6))
  8.   (reverse newpl))

好象没什么可优化的,差不多就只能这样了
 楼主| 发表于 2016-11-4 13:59:22 | 显示全部楼层
我用arx写的,1M的列表瞬间提取。
static int ads_subList(void)
{
//函数的参数 ((1 2 3 4 ..) start end)
struct resbuf *pArgs =acedGetArgs () ;
struct resbuf *ret;
//SHORT *buf =new SHORT[1048576];//最大1M
int count=0;
pArgs=pArgs->rbnext;
pArgs=pArgs->rbnext;//跳过RTLE
int start=pArgs->resval.rlong;
pArgs=pArgs->rbnext;
int end=pArgs->resval.rlong;
pArgs =acedGetArgs()->rbnext ;
int i=0;
while(i<start && pArgs->restype==RTSHORT)
{
pArgs=pArgs->rbnext;
i++;
}
ret=pArgs;
i=1;
while(i<end-start && pArgs->rbnext->restype==RTSHORT)
{
pArgs=pArgs->rbnext;
i++;
}
pArgs->rbnext=NULL;
return acedRetList(ret);
acutRelRb(ret);
}
您需要登录后才可以回帖 登录 | 注册

本版积分规则

小黑屋|手机版|CAD论坛|CAD教程|CAD下载|联系我们|关于明经|明经通道 ( 粤ICP备05003914号 )  
©2000-2023 明经通道 版权所有 本站代码,在未取得本站及作者授权的情况下,不得用于商业用途

GMT+8, 2025-5-20 04:34 , Processed in 0.147160 second(s), 26 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表