ostaskcreate(ucos 怎样确定任务堆栈大小)

2024-01-14 17:45:02 18

ostaskcreate(ucos  怎样确定任务堆栈大小)

这篇文章给大家聊聊关于ostaskcreate,以及ucos 怎样确定任务堆栈大小对应的知识点,希望对各位有所帮助,不要忘了收藏本站哦。

本文目录

ucos 怎样确定任务堆栈大小

1、首先需要知道,μC/OS-II中创建任务的函数有两个: OSTaskCreate()和OSTaskCreateExt()

(1)OSTaskCreate() //创建普通任务 

由于重点在下面的创建扩展任务函数,故本函数就不多说了!确实,要想实现检测目标任务栈实际使用情况的功能,是不能使用这个函数来创建目标任务的,必须使用OSTaskCreateExt() 。

(2)OSTaskCreateExt() //创建扩展任务

函数接口原型为:

#if OS_TASK_CREATE_EXT_EN 》 0INT8U OSTaskCreateExt

(

void (*task)(void *pd), //建立扩展任务(任务代码指针void *pdata, //传递参数指针OS_STK *ptos, //分配任务堆栈栈顶指针INT8U prio, //分配任务优先级INT16U id, //(未来的)优先级标识(与优先级相同)OS_STK *pbos, //分配任务堆栈栈底指针INT32U stk_size, //指定堆栈的容量(检验用)void *pext, //指向用户附加的数据域的指针INT16U opt //建立任务设定选项

)#endif

2、其次需要知道μC/OS-II中有这么个函数:OSTaskStkChk()

不错,检测任务堆栈实际使用情况正是用的这个函数,下面来本函数的接口原型:

INT8U OSTaskStkChk

(

INT8U prio,  //待测任务的优先级

OS_STK_DATA *pdata //指向一个类型为OS_STK_DATA的结构体

)

3、再次需要知道一个结构体:

#if OS_TASK_CREATE_EXT_EN 》 0typedef struct

{INT32U OSFree; //堆栈中未使用的字节数INT32U OSUsed; //堆栈中已使用的字节数} OS_STK_DATA;#endif

参数: prio 为指定要获取堆栈信息的任务优先级,也可以指定参数OS_PRIO_SELF,获取调用任务本身的信息。pdata 指向一个类型为OS_STK_DATA的数据结构,其中包含如下信息:INT32U OSFree; // 堆栈中未使用的字节数INT32U OSUsed; // 堆栈中已使用的字节数

4、有了上述三个知识点后就可以啦,具体方法为:

(1)将函数的最后一个参数opt 设置为:OS_TASK_OPT_STK_CHK | OS_TASK_OPT_STK_CLR

(2)定义一个变量:OS_STK_DATA  StackBytes;

(3)调用函数OSTaskStkChk(TestTaskPRIO, &StackBytes)

(4)StackBytes.OSFree的值即为被测任务堆栈未使用的字节数,

StackBytes.OSUsed的值即为被测任务堆栈已使用的字节数。

5、需要设置宏:OS_TASK_OPT_STK_CLR为1

6、最后一点建议:

(1)将被测任务经历最坏的堆栈使用状态,测出来的使用率才可靠

(2)堆栈使用率最好在%50~%80之间,太小浪费空间,太大不安全

(3)最好在工程中单独建立一个优先级较低延时较长的任务来测试其它任务的堆栈使用情况,不用时可以挂起该任务

有时候决定任务实际所需的堆栈空间大小是很有必要的。因为这样用户就可以避免为任务分配过多的堆栈空间,从而减少自己的应用程序代码所需的RAM(内存)数量。?C/OS-Ⅱ提供的OSTaskStkChk()函数可以为用户提供这种有价值的信息。

在图4.2中,笔者假定堆栈是从上往下递减的(即OS_STK_GROWTH被置为1),但以下的讨论也同样适用于从下往上长的堆栈。在任务建立的时候,BOS的位置及堆栈的这两个值储存在任务的OS_TCB中。

为了使用?C/OS-Ⅱ的堆栈检验功能,用户必须要做以下几件事情:

l  在OS_CFG.H文件中设OS_TASK_CREATE_EXT为1。

l  用OSTaskCreateExt()建立任务,并给予任务比实际需要更多的内存空间。

l  在OSTaskCreateExt()中,将参数opt设置为OS_TASK_OPT_STK_CHK+OS_TASK_OPT_STK_

CLR。注意如果用户的程序启动代码清除了所有的RAM,并且从未删除过已建立了的任务,那么用户就不必设置选项OS_TASK_OPT_STK_CLR了。这样就会减少OSTaskCreateExt()的执行时间。

l  将用户想检验的任务的优先级作为OSTaskStkChk()的参数并调用之。

图 4.2          堆栈检验

OSTaskStkChk()顺着堆栈的栈底开始计算空闲的堆栈空间大小,具体实现方法是统计储存值为0的连续堆栈入口的数目,直到发现储存值不为0的堆栈入口。每次在调用OSTaskStkChk()的时候,用户也可能会因为任务还没触及堆栈的最深处而得到不同的堆栈的空闲空间数。

用户应该使自己的应用程序运行足够长的时间,并且经历最坏的堆栈使用情况,这样才能得到正确的数。一旦OSTaskStkChk()提供给用户最坏情况下堆栈的需求,用户就可以重新设置堆栈的最后容量了。为了适应系统以后的升级和扩展,用户应该多分配10%-100%的堆栈空间。在堆栈检验中,用户所得到的只是一个大致的堆栈使用情况,并不能说明堆栈使用的全部实际情况。

OSTaskStkChk()函数的代码如程序清单 L4.10所示。0S_STK_DATA(参看?COS_Ⅱ.H)数据结构用来保存有关任务堆栈的信息。笔者打算用一个数据结构来达到两个目的。第一,把OSTaskStkChk()当作是查询类型的函数,并且使所有的查询函数用同样的方法返回,即返回查询数据到某个数据结构中。第二,在数据结构中传递数据使得笔者可以在不改变OSTaskStkChk()的API(应用程序编程接口)的条件下为该数据结构增加其它域,从而扩展OSTaskStkChk()的功能。现在,0S_STK_DATA只包含两个域:OSFree和OSUsed。从代码中用户可看到,通过指定执行堆栈检验的任务的优先级可以调用OSTaskStkChk()。如果用户指定0S_PRIO_SELF。注意函数所确定的是堆栈的实际空闲字节数和已被占用的字节数,而不是堆栈的总字节数。当然,堆栈的实际大小(用字节表示)就是该两项之和。

程序清单 L 4.10   堆栈检验函数

INT8U OSTaskStkChk (INT8U prio, OS_STK_DATA *pdata)

{

OS_TCB  *ptcb;

OS_STK  *pchk;

INT32U   free;

INT32U   size;

pdata-》OSFree = 0;

pdata-》OSUsed = 0;

if (prio 》 OS_LOWEST_PRIO && prio != OS_PRIO_SELF) {

return (OS_PRIO_INVALID);

}

OS_ENTER_CRITICAL();

if (prio == OS_PRIO_SELF) {                                              (1)

prio = OSTCBCur-》OSTCBPrio;

}

ptcb = OSTCBPrioTbl;

if (ptcb == (OS_TCB *)0) {                                               (2)

OS_EXIT_CRITICAL();

return (OS_TASK_NOT_EXIST);

}

if ((ptcb-》OSTCBOpt & OS_TASK_OPT_STK_CHK) == 0) {                   (3)

OS_EXIT_CRITICAL();

return (OS_TASK_OPT_ERR);

}

free = 0;                                                                  (4)

size = ptcb-》OSTCBStkSize;

pchk = ptcb-》OSTCBStkBottom;

OS_EXIT_CRITICAL();

#if OS_STK_GROWTH == 1

while (*pchk++ == 0) {

free++;

}

#else

while (*pchk-- == 0) {

free++;

}

#endif

pdata-》OSFree = free * sizeof(OS_STK);                                 (5)

pdata-》OSUsed = (size - free) * sizeof(OS_STK);

return (OS_NO_ERR);

}

uCOS-III任务堆栈溢出检测及统计任务堆栈使用量的方法 

1. 在操作系统任务设计的时候,通常会遇到一个比较麻烦的问题,也就是任务 堆 栈大小设定的问题,为此我们我需要知道一些问题 :

1.1. 任务堆栈一但溢出,意味着系统的崩溃,在有MMU或者MPU的系统中,对堆栈溢出的检测十分简单,因为这是MMU和MPU必备的功能之一。(uCOS-II/uCOS-III中均有针对没有MMU和MPU的处理器对堆栈溢出检测的策略)

1.2. 堆栈的大小取决于该任务的需求。设定堆栈大小时,你就需要考虑:所有可能被堆栈调用的函数及其函数的嵌套层数,相关局部变量的大小,中断服务程序所需要的空间。另外,堆栈还需存入CPU寄存器,如果处理器有浮点数单元FPU寄存器的话还需存入FPU寄存器。(PS:出于这点,所以在嵌入式系统中有个潜规则,避免写递归函数)

1.3. 虽然任务堆栈大小可以通过人工计算出来,但是要考虑的太多,而且不能十分精确的计算。比如逐级嵌套被调用的函数的参数使用,上下文切换时候的CPU寄存器空间的保存,中断时CPU寄存器空间的保存和中断处理函数的堆栈空间等等,未免太过麻烦。特别的,当任务中使用了printf()之类参数可变的函数,那么统计起来就更困难了。所以这种方式怎么看怎么不现实。囧  。

1.4. 建议在不是很精确的确定任务堆栈使用大小(stk_size)的情况下,还是采取stk_size乘以1.5或者2.0的做法,以保证任务的正常运行。

2. uCOS-III任务堆栈溢出检测原理

每个任务都有自己的TCB(Task Control Block 任务控制块), TCB结构定义在uCOS-III源码(我使用的是V3.03.00版本)中的os.h中。 TCB中有个 StkLimitPtr成员。

假设在切换到任务S前,代码会检测将要被载入CPU堆栈指针的值是否超出该任务S的TCB中StkLimitPtr限制。因为软件不能在溢出时就迅速地做出反应,所以应该设置StkLimitPtr的值尽可能远离&MyTaskStk,保证有足够的溢出缓冲。如下图。软件检测不会像硬件检测那样有效,但也可以防止堆栈溢出。 当uC/OS-III从一个任务切换到另一个任务的时候,它会调用一个 hook函数OSTaskSwHook(),它允许用户扩展上下文切换时的功能。 所以,如果处理器没有硬件支持溢出检测功能,就可以在该hook函 数中添加代码软件模拟该能。

不过我个人的做法是,通常设置StkLimitPtr指向任务栈大小的90%处,然后获取任务堆栈使用量,如果栈使用率大于90%时就必须做出警告了!下面就来介绍任务栈使用量的获取。

图1

3. uCOS-III任务堆栈使用量统计的原理和方法

3.1 原理

原理其实很简单,就是统计连续为0的区域的大小就可以知道空闲栈free的大小,而任务在创建时任务栈总量TaskStkSize是确定的,那么使用了的栈大小used =  TaskStkSize  - free。见图2。

图2 

首先,当任务创建时其堆栈被清零。然后,通过一个低优先级任务,计算该任务整个堆栈中值为0的内存大小。如果发现都不为0,那么就需要扩展堆栈的大小。然后,调整堆栈为的相应大小。这是一种非常有效的方法。注意的是,程序需用运行很长的时间以让堆栈达到其需要的最大值。 

3.2 方法 

uC/OS-III提供了一个函数OSTaskStkChk()用于实现这个计算功能。那么就来看看具体怎么做吧。 

3.2.1 首先创建一个任务来运行任务堆栈统计工作,值得注意的是,这个任务的优先级建议设置为系统所有任务中最低的一个!

#define  SystemDatasBroadcast_PRIO            12 // 统计任务优先级最低,我这里是12,已经低于其他任务的优先级了#define  SystemDatasBroadcast_STK_SIZE       100 // 任务的堆栈大小,做统计一般够了,统计结果出来后不够再加..OS_TCB  SystemDatasBroadcast_TCB; // 定义统计任务的TCBCPU_STK SystemDatasBroadcast_STK ;// 开辟数组作为任务栈给任务使用static  void  AppTaskCreate(void){  // .....// 这是系统创建任务的函数,还有其他任务创建的代码,这里就不贴出了// .....OSTaskCreate( (OS_TCB     *)&SystemDatasBroadcast_TCB,(CPU_CHAR   *)"SystemDatasBroadcast",(OS_TASK_PTR ) SystemDatasBroadcast,(void       *) 0,(OS_PRIO     ) SystemDatasBroadcast_PRIO,(CPU_STK    *)&SystemDatasBroadcast_STK,(CPU_STK_SIZE) SystemDatasBroadcast_STK_SIZE/10,/*栈溢出临界值我设置在栈大小的90%处*/(CPU_STK_SIZE) SystemDatasBroadcast_STK_SIZE,(OS_MSG_QTY  ) 0,(OS_TICK     ) 0,(void       *) 0,(OS_OPT      )(OS_OPT_TASK_STK_CHK | OS_OPT_TASK_STK_CLR),(OS_ERR     *) &err);}

3.2.2 然后在任务函数SystemDatasBroadcast()中开始统计各个任务 (其他任务的代码就不贴了, 跟

SystemDatasBroadcast 创建代码的方法是一模一样的,大家根据自己的需求照葫芦画瓢即可 )的栈使用,代码如下:

void  SystemDatasBroadcast (void *p_arg){OS_ERR err;CPU_STK_SIZE free,used;(void)p_arg;  while(DEF_TRUE){OSTaskStkChk (&SystemDatasBroadcast_TCB,&free,&used,&err);printf("SystemDatasBroadcast  used/free:%d/%d  usage:%%%d\r\n",used,free,(used*100)/(used+free));OSTaskStkChk (&Core_Page_TCB,&free,&used,&err);printf("Core_Page             used/free:%d/%d  usage:%%%d\r\n",used,free,(used*100)/(used+free));OSTaskStkChk (&GUIActive_TCB,&free,&used,&err);printf("GUIActive             used/free:%d/%d  usage:%%%d\r\n",used,free,(used*100)/(used+free));OSTaskStkChk (&KeyCheck_Process_TCB,&free,&used,&err);printf("KeyCheck              used/free:%d/%d  usage:%%%d\r\n",used,free,(used*100)/(used+free));OSTaskStkChk (&Light_Adjust_TCB,&free,&used,&err);printf("Light_Adjust          used/free:%d/%d  usage:%%%d\r\n",used,free,(used*100)/(used+free));OSTaskStkChk (&Calibrate_Process_TCB,&free,&used,&err);printf("Calibrate             used/free:%d/%d  usage:%%%d\r\n",used,free,(used*100)/(used+free));OSTaskStkChk (&Data_Process_TCB,&free,&used,&err);printf("Data_Process          used/free:%d/%d  usage:%%%d\r\n",used,free,(used*100)/(used+free));printf("\r\n\r\n\r\n");OSTimeDlyHMSM(0,0,5,0,(OS_OPT)OS_OPT_TIME_DLY,(OS_ERR*)&err);}}

3.2.3实验结果

上述代码的实验结果如下图所示,可以清楚的看到每个任务的堆栈的使用状况。

但是请遵循一个原则:必须让系统运行足够久,比如尽量让系统处于不同的运行状态下,然后观察任务堆栈使用的变化,找到堆栈的最高使用率,然后根据上文所说的原则按需重新分配新的任务堆栈大小。

ostaskcreateext后会立即运行该任务吗

id参数为要建立的任务创建一个特殊的标识符。该参数在µC/OS以后的升级版本中可能会用到,但在µC/OS-Ⅱ中还未使用。这个标识符可以扩展µC/OS-Ⅱ功能,使它可以执行的任务数超过目前的64个。但在这里,用户只要简单地将任务的id设置成与任务的优先级一样的值就可以了。 pbos是指向任务的堆栈栈底的指针,用于堆栈的检验。 stk_size用于指定堆栈成员数目的容量。也就是说,如果堆栈的入口宽度为4字节宽,那么stk_size为10000是指堆栈有40000个字节。该参数与pbos一样,也用于堆栈的检验。

怎样判断ucos ii ostaskcreate任务的 堆栈是否溢出

1.1. 任务堆栈一但溢出,意味着系统的崩溃,在有MMU或者MPU的系统中,对堆栈溢出的检测十分简单,因为这是MMU和MPU必备的功能之一。(uCOS-II/uCOS-III中均有针对没有MMU和MPU的处理器对堆栈溢出检测的策略)1.2. 堆栈的大小取决于该任务的需求。设定堆栈大小时,你就需要考虑:所有可能被堆栈调用的函数及其函数的嵌套层数,相关局部变量的大小,中断服务程序所需要的空间。另外,堆栈还需存入CPU寄存器,如果处理器有浮点数单元FPU寄存器的话还需存入FPU寄存器。(PS:出于这点,所以在嵌入式系统中有个潜规则,避免写递归函数)1.3. 虽然任务堆栈大小可以通过人工计算出来,但是要考虑的太多,而且不能十分精确的计算。比如逐级嵌套被调用的函数的参数使用,上下文切换时候的CPU寄存器空间的保存,中断时CPU寄存器空间的保存和中断处理函数的堆栈空间等等,未免太过麻烦。特别的,当任务中使用了printf()之类参数可变的函数,那么统计起来就更困难了。所以这种方式怎么看怎么不现实。囧 。1.4. 建议在不是很精确的确定任务堆栈使用大小(stk_size)的情况下,还是采取stk_size乘以1.5或者2.0的做法,以保证任务的正常运行。

以上就是我们为大家找到的有关“ostaskcreate(ucos 怎样确定任务堆栈大小)”的所有内容了,希望可以帮助到你。如果对我们网站的其他内容感兴趣请持续关注本站。

ostaskcreate(ucos  怎样确定任务堆栈大小)

本文编辑:admin
: ostaskcreate,uc,

更多文章:


彩票缩水软件(买双色球怎样能中一等奖)

彩票缩水软件(买双色球怎样能中一等奖)

各位老铁们好,相信很多人对彩票缩水软件都不是特别的了解,因此呢,今天就来为大家分享下关于彩票缩水软件以及买双色球怎样能中一等奖的问题知识,还望可以帮助大家,解决大家的一些困惑,下面一起来看看吧!本文目录买双色球怎样能中一等奖开彩票站的人自己

2023年12月8日 21:25

本地连接连不上(笔记本连不上本地连接)

本地连接连不上(笔记本连不上本地连接)

大家好,今天小编来为大家解答以下的问题,关于本地连接连不上,笔记本连不上本地连接这个很多人还不知道,现在让我们一起来看看吧!本文目录笔记本连不上本地连接电脑连不上本地连接怎么办电脑本地连接无法连接到internet电脑网络连接不上怎么回事本

2024年1月9日 05:20

胆汁其实由人体的哪一个器官分泌的(胆汁是由人体的什么内脏器官分泌出来的)

胆汁其实由人体的哪一个器官分泌的(胆汁是由人体的什么内脏器官分泌出来的)

大家好,胆汁其实由人体的哪一个器官分泌的相信很多的网友都不是很明白,包括胆汁是由人体的什么内脏器官分泌出来的也是一样,不过没有关系,接下来就来为大家分享关于胆汁其实由人体的哪一个器官分泌的和胆汁是由人体的什么内脏器官分泌出来的的一些知识点,

2024年4月2日 10:20

qq手机管家官方下载2012(安卓QQ手机管家官方下载 QQ手机管家下载地址)

qq手机管家官方下载2012(安卓QQ手机管家官方下载 QQ手机管家下载地址)

这篇文章给大家聊聊关于qq手机管家官方下载2012,以及安卓QQ手机管家官方下载 QQ手机管家下载地址对应的知识点,希望对各位有所帮助,不要忘了收藏本站哦。本文目录安卓QQ手机管家官方下载 QQ手机管家下载地址手机管家老版本下载在哪下腾讯手

2024年6月10日 11:18

汽车报价查询(北京汽车销售价格在哪里能查询到)

汽车报价查询(北京汽车销售价格在哪里能查询到)

大家好,今天小编来为大家解答以下的问题,关于汽车报价查询,北京汽车销售价格在哪里能查询到这个很多人还不知道,现在让我们一起来看看吧!本文目录北京汽车销售价格在哪里能查询到怎样在汽车报价大全上看在一个地方的价格购车app排名如何查到汽车最准确

2024年2月4日 05:30

qq安全中心申诉(QQ安全中心怎样申诉)

qq安全中心申诉(QQ安全中心怎样申诉)

各位老铁们好,相信很多人对qq安全中心申诉都不是特别的了解,因此呢,今天就来为大家分享下关于qq安全中心申诉以及QQ安全中心怎样申诉的问题知识,还望可以帮助大家,解决大家的一些困惑,下面一起来看看吧!本文目录QQ安全中心怎样申诉怎么在QQ安

2024年6月13日 21:58

qq列表大全(如何清除手机QQ的消息列表)

qq列表大全(如何清除手机QQ的消息列表)

大家好,今天小编来为大家解答以下的问题,关于qq列表大全,如何清除手机QQ的消息列表这个很多人还不知道,现在让我们一起来看看吧!本文目录如何清除手机QQ的消息列表在哪能看到自己QQ历史全部加好友列表qq怎么清空消息列表如何快速清理手机QQ消

2024年5月18日 10:57

免费全本阅读(真正不收费的看书软件)

免费全本阅读(真正不收费的看书软件)

其实免费全本阅读的问题并不复杂,但是又很多的朋友都不太了解真正不收费的看书软件,因此呢,今天小编就来为大家分享免费全本阅读的一些知识,希望可以帮助到大家,下面我们一起来看看这个问题的分析吧!本文目录真正不收费的看书软件苹果手机有免费阅读全本

2024年5月28日 17:31

排队叫号管理系统(排队叫号机的工作原理)

排队叫号管理系统(排队叫号机的工作原理)

大家好,排队叫号管理系统相信很多的网友都不是很明白,包括排队叫号机的工作原理也是一样,不过没有关系,接下来就来为大家分享关于排队叫号管理系统和排队叫号机的工作原理的一些知识点,大家可以关注收藏,免得下次来找不到哦,下面我们开始吧!本文目录排

2024年1月31日 11:15

windows phone 8 应用(Windows Phone 8.1还能获得应用更新吗)

windows phone 8 应用(Windows Phone 8.1还能获得应用更新吗)

大家好,关于windows phone 8 应用很多朋友都还不太明白,不过没关系,因为今天小编就来为大家分享关于Windows Phone 8.1还能获得应用更新吗的知识点,相信应该可以解决大家的一些困惑和问题,如果碰巧可以解决您的问题,还

2024年1月25日 11:50

怎样把U盘图标改为自定义的图片?如何更换手机桌面图标

怎样把U盘图标改为自定义的图片?如何更换手机桌面图标

其实图标图片的问题并不复杂,但是又很多的朋友都不太了解怎样把U盘图标改为自定义的图片,因此呢,今天小编就来为大家分享图标图片的一些知识,希望可以帮助到大家,下面我们一起来看看这个问题的分析吧!本文目录怎样把U盘图标改为自定义的图片如何更换手

2024年9月17日 23:30

财达证券手机版下载(财达证劵炒股软件如何下载)

财达证券手机版下载(财达证劵炒股软件如何下载)

大家好,如果您还对财达证券手机版下载不太了解,没有关系,今天就由本站为大家分享财达证券手机版下载的知识,包括财达证劵炒股软件如何下载的问题都会给大家分析到,还望可以解决大家的问题,下面我们就开始吧!本文目录财达证劵炒股软件如何下载河北财达证

2024年11月6日 13:45

有什么好玩的竞技游戏(有什么好玩点的竞技类游戏)

有什么好玩的竞技游戏(有什么好玩点的竞技类游戏)

各位老铁们,大家好,今天由我来为大家分享有什么好玩的竞技游戏,以及有什么好玩点的竞技类游戏的相关问题知识,希望对大家有所帮助。如果可以帮助到大家,还望关注收藏下本站,您的支持是我们最大的动力,谢谢大家了哈,下面我们开始吧!本文目录有什么好玩

2023年10月31日 16:45

什么是服务器托管(服务器托管什么意思)

什么是服务器托管(服务器托管什么意思)

其实什么是服务器托管的问题并不复杂,但是又很多的朋友都不太了解服务器托管什么意思,因此呢,今天小编就来为大家分享什么是服务器托管的一些知识,希望可以帮助到大家,下面我们一起来看看这个问题的分析吧!本文目录服务器托管什么意思服务器托管是什么意

2024年7月7日 11:47

如何剪辑音乐然后合成(怎么把剪辑的音乐连在一起 怎样把两首歌合并在一起)

如何剪辑音乐然后合成(怎么把剪辑的音乐连在一起 怎样把两首歌合并在一起)

大家好,如果您还对如何剪辑音乐然后合成不太了解,没有关系,今天就由本站为大家分享如何剪辑音乐然后合成的知识,包括怎么把剪辑的音乐连在一起 怎样把两首歌合并在一起的问题都会给大家分析到,还望可以解决大家的问题,下面我们就开始吧!本文目录怎么把

2024年10月6日 12:20

全国火车查询(怎么查火车票)

全国火车查询(怎么查火车票)

大家好,全国火车查询相信很多的网友都不是很明白,包括怎么查火车票也是一样,不过没有关系,接下来就来为大家分享关于全国火车查询和怎么查火车票的一些知识点,大家可以关注收藏,免得下次来找不到哦,下面我们开始吧!本文目录怎么查火车票安卓什么软件能

2024年6月21日 18:00

极品飞车13 变速(极品飞车13变速如何进入游戏)

极品飞车13 变速(极品飞车13变速如何进入游戏)

本篇文章给大家谈谈极品飞车13 变速,以及极品飞车13变速如何进入游戏对应的知识点,文章可能有点长,但是希望大家可以阅读完,增长自己的知识,最重要的是希望对各位有所帮助,可以解决了您的问题,不要忘了收藏本站喔。本文目录极品飞车13变速如何进

2024年7月9日 02:54

win10激活密匙(密钥激活win10的方法都是什么啊)

win10激活密匙(密钥激活win10的方法都是什么啊)

大家好,关于win10激活密匙很多朋友都还不太明白,不过没关系,因为今天小编就来为大家分享关于密钥激活win10的方法都是什么啊的知识点,相信应该可以解决大家的一些困惑和问题,如果碰巧可以解决您的问题,还望关注下本站哦,希望对各位有所帮助!

2024年6月5日 06:05

开通qq空间(如何开通qq空间)

开通qq空间(如何开通qq空间)

大家好,今天小编来为大家解答以下的问题,关于开通qq空间,如何开通qq空间这个很多人还不知道,现在让我们一起来看看吧!本文目录如何开通qq空间如何开通QQ空间怎么开通QQ空间怎么开通qq空间怎样开通QQ空间如何申请开通qq空间QQ空间怎么开

2024年7月15日 03:30

无毒单机游戏下载基地(求几个无毒的单机游戏下载网站!!!)

无毒单机游戏下载基地(求几个无毒的单机游戏下载网站!!!)

大家好,无毒单机游戏下载基地相信很多的网友都不是很明白,包括求几个无毒的单机游戏下载网站!!!也是一样,不过没有关系,接下来就来为大家分享关于无毒单机游戏下载基地和求几个无毒的单机游戏下载网站!!!的一些知识点,大家可以关注收藏,免得下次来

2024年7月11日 05:20

近期文章

本站热文

电脑包尺寸对照表(电脑包要多大)
2024-07-23 11:15:58 浏览:3912
e10000(皖E10000是什么车)
2024-07-17 11:22:25 浏览:3508
ati radeon hd 5650(电脑的显卡是ATI Mobility Radeon HD 5650 (MADION PRO) ( 1 GB ) 这个显卡)
2024-07-07 05:01:37 浏览:3103
华为mate20pro版本区别(mate20pro有必要买ud版吗)
2024-07-24 08:26:42 浏览:2631
ipad买蜂窝版还是wifi版(ipad air 5买蜂窝好不好)
2024-07-17 14:35:19 浏览:2241
标签列表

热门搜索