FreeRTOS 任务计数信号量,任务二值信号量,任务事件标志组,任务消息邮箱
以下基础内容转载自安富莱电子: http://forum.armfly.com/forum.php
本章节为大家讲解 FreeRTOS 计数信号量的另一种实现方式----基于任务通知(Task Notifications)
的计数信号量,这里我们将这种方式实现的计数信号量称之为任务计数信号量。 任务计数信号量效率更高,
需要的 RAM 空间更小。当然,缺点也是有的,它没有之前介绍的计数信号量实现的功能全面。
任务通知(Task Notifications)介绍
FreeRTOS 每个已经创建的任务都有一个任务控制块(task control block),任务控制块就是一个
结构体变量,用于记录任务的相关信息。 结构体变量中有一个 32 位的变量成员 ulNotifiedValue 是专门
用于任务通知的。
通过任务通知方式可以实现计数信号量,二值信号量,事件标志组和消息邮箱(消息邮箱就是消息队
列长度为 1 的情况)。 使用方法与前面章节讲解的事件标志组和信号量基本相同,只是换了不同的函数来
实现。 任务通知方式实现的计数信号量,二值信号量,事件标志组和消息邮箱是通过修改变量
ulNotifiedValue 实现的:
设置接收任务控制块中的变量 ulNotifiedValue 可以实现消息邮箱。
如果接收任务控制块中的变量 ulNotifiedValue 还没有被其接收到,也可以用新数据覆盖原有数据
,这就是覆盖方式的消息邮箱。
设置接收任务控制块中的变量 ulNotifiedValue 的 bit0-bit31 数值可以实现事件标志组。
设置接收任务控制块中的变量 ulNotifiedValue 数值进行加一或者减一操作可以实现计数信号量和二
值信号量。
介绍了这么多,那么问题来了,采用这种方式有什么优势呢?根据官方的测试数据,唤醒由于信号量
和事件标志组而处于阻塞态的任务,速度提升了 45%,而且这种方式需要的 RAM 空间更小。 但这种方式
实现的信号量和事件标志组也有它的局限性,主要表现在以下两个方面:
任务通知方式仅可以用在只有一个任务等待信号量,消息邮箱或者事件标志组的情况,不过实际项目
项目中这种情况也是最多的。
使用任务通知方式实现的消息邮箱替代前面章节讲解的消息队列时,发送消息的任务不支持超时等待,
即消息队列中的数据已经满了,可以等待消息队列有空间可以存新的数据,而任务通知方式实现的消
息邮箱不支持超时等待。
任务计数信号量
前面,我们对计数信号量进行了讲解,计数信号量就是对一个变量进行计数,变量的范围是
从 0 到用户创建计数信号量时所设置的大小。当计数变量大于 0 的时候计数信号量管理的资源才可以使用,
计数变量的具体数值就是可用的资源大小。
本章节讲解的任务计数信号量与前面章节讲解的计数信号量要实现的功能是一样的,不同的是调用的
函数和使用的计数变量:
任务计数信号量的计数变量是通过任务控制块中的一个 32 位变量 ulNotifiedValue 实现计数。 前面讲解的计数信号量创建后会有自己的计数变量。
任务计数信号量是通过函数 ulTaskNotifyTake()替代之前讲解的函数 xSemaphoreTake()实现
资源获取,即对计数信号量数值进行减一操作。
任务计数信号量是通过函数 xTaskNotifyGive() 和 vTaskNotifyGiveFromISR()替代前面讲解的
函数 xSemaphoreGive() 和 xSemaphoreGiveFromISR()实现资源释放,即对计数信号量的数值进
行加一操作。
实际项目中,如果使用计数信号量和任务计数信号量都能实现相应功能,强烈建议使用任务计数信号量。
任务计数信号量 API 函数
使用如下 9 个函数可以实现 FreeRTOS 的任务信号量(含任务计数信号量和任务二值信号量):
xTaskNotifyGive()
vTaskNotifyGiveFromISR()
ulTaskNotifyTake()
xTaskNotify()
xTaskNotifyAndQuery()
xTaskNotifyAndQueryFromISR()
xTaskNotifyFromISR()
xTaskNotifyWait()
xTaskNotifyStateClear()
关于这 9 个函数的讲解及其使用方法可以看 FreeRTOS 在线版手册 。
这里我们重点的说以下 3 个函数:
xTaskNotifyGive
vTaskNotifyGiveFromISR
ulTaskNotifyTake
因为本章节配套的例子使用的是这 3 个函数。
函数 xTaskNotifyGive
函数原型:
BaseType_t xTaskNotifyGive( TaskHandle_t xTaskToNotify ); /* 任务句柄 */
函数描述:
函数 xTaskNotifyGive 用于释放信号量(含任务二值信号量,任务计数信号量)。
第 1 个参数是任务句柄。
返回值,仅有一个返回值 pdPASS。
使用这个函数要注意以下问题:
1. 任务信号量的初始计数值是 0。 任务信号量不像前面章节讲解的信号量,无需单独创建即可使用。
2. 默认配置此函数可以使用的的宏定义已经在 FreeRTOS.h 文件中使能:
#define configUSE_TASK_NOTIFICATIONS 1
当然,如果用户不需要使用任务通知功能相关的函数,可以在 FreeRTOSConfig.h 文件中配置此宏定
义为 0 来禁止,这样创建的每个任务可以节省 8 个字节的需求。
3. 此函数是用于任务代码中调用的,故不可以在中断服务程序中调用此函数,中断服务程序中使用的是
vTaskNotifyGiveFromISR。
函数 vTaskNotifyGiveFromISR
函数原型:
void vTaskNotifyGiveFromISR(
TaskHandle_t xTaskToNotify, /* 任务句柄 */
BaseType_t * pxHigherPriorityTaskWoken ); /* 高优先级任务是否被唤醒的状态保存 */
函数描述:
函数 xTaskNotifyGive 用于释放信号量(含任务二值信号量,任务计数信号量)。
第 1 个参数是任务句柄。
第 2 个参数用于保存是否有高优先级任务准备就绪。如果函数执行完毕后,此参数的数值是 pdTRUE,
说明有高优先级任务要执行,否则没有。
使用这个函数要注意以下问题:
1. 任务信号量的初始计数值是 0。任务信号量不像前面章节讲解的信号量,无需单独创建即可使用。
2. 默认配置此函数可以使用的的宏定义已经在 FreeRTOS.h 文件中使能:
#define configUSE_TASK_NOTIFICATIONS 1
当然,如果用户不需要使用任务通知功能相关的函数,可以在 FreeRTOSConfig.h 文件中配置此宏定
义为 0 来禁止,这样创建的每个任务可以节省 8 个字节的需求。
3. 此函数是用于中断服务程序中调用的,故不可以在任务代码中调用此函数,任务代码中使用的是xTaskNotifyGive。
函数 ulTaskNotifyTake
函数原型:
uint32_t ulTaskNotifyTake( BaseType_t xClearCountOnExit, /* 选择是否清零用于任务通知的 ulNotifiedValue */
TickType_t xTicksToWait ); /* 等待信号量可用的最大等待时间 */
函数描述:
函数 ulTaskNotifyTake用于获取信号量(含任务二值信号量,任务计数信号量)。
第 1 个参数配置为 pdFALSE 表示函数返回前用于任务信号量的内部变量 ulNotifiedValue数值减一,这种方式用于任务计数信号量。 参数配置为 pdTRUE 表示函数返回前用于任务信号量的内部变量 ulNotifiedValue数值被清零,这种方式用于任务二值信号量。
第 2 个参数是没有任务信号量可用时,等待信号量可用的最大等待时间,单位系统时钟节拍。
返回值:任务的通知值在其递减或清除之前的值
使用这个函数要注意以下问题:
1. 任务信号量的初始计数值是 0。任务信号量不像前面章节讲解的信号量,无需单独创建即可使用。
2. 默认配置此函数可以使用的的宏定义已经在 FreeRTOS.h 文件中使能:
#define configUSE_TASK_NOTIFICATIONS 1
当然,如果用户不需要使用任务通知功能相关的函数可以在 FreeRTOSConfig.h 文件中配置此宏定义
为 0 来禁止,这样创建的每个任务可以节省 8 个字节的需求。
3. 如果用户将 FreeRTOSConfig.h 文件中的宏定义 INCLUDE_vTaskSuspend 配置为 1 且第 2 个参数配
置为 portMAX_DELAY,那么此函数会永久等待直到信号量可用。
实验展示台:
发送任务:值加1,默认为0
接受任务:值减1
实验输出:
中断方式发送:
接收函数还是不变,ulTaskNotifyTake函数中断和非中断方式都是它。
实验现象:按键按下之后,每隔500ms释放一次
注意中断方式,这里是定时器中断,定时器中断优先级的数学值要大于等于configLIBRARY_MAX_SYSCALL_INTERRUPT_PRIORITY配置的值,也就是定时器中断优先级的逻辑值要小于等于config.h中configLIBRARY_MAX_SYSCALL_INTERRUPT_PRIORITY这个宏的配置值,这样才可以强制上下文切换。
FreeRTOS 任务二值信号量
任务二值信号量
前面,我们对二值信号量进行了讲解,二值信号量只有两种数值 0 和 1。 本章节讲解的任务
二值信号量与前面章节讲解的二值信号量要实现的功能是一样的,不同的是调用的函数和使用的计数变量:
任务二值信号量的计数变量是通过任务控制块中的一个 32 位变量 ulNotifiedValue 实现计数。前面讲解的二值信号量创建后会有自己的计数变量。
任务二值信号量是通过函数 ulTaskNotifyTake()替代前面章节讲解的函数 xSemaphoreTake()实现
资源获取,即对二值信号量数值进行清零操作。
任务二值信号量是通过函数 xTaskNotifyGive() 和 vTaskNotifyGiveFromISR()替代第前面章节讲解的
函数 xSemaphoreGive() 和 xSemaphoreGiveFromISR()实现资源释放,即对二值信号量的数值进行加一操作。
多次调用函数 xTaskNotifyGive ()难免会出现计数值大于 1 的情况,用作任务二值信号量时,我们可
以将所有大于 1 的计数理解为一种情况,即二值信号量管理的资源可用。因此,不管当前的计数是多少,
大于 0 的计数在通过函数 ulTaskNotifyTake()获取二值信号量的时候统一清零,这样就实现了二值信号量的功能。
实际项目中,如果使用二值信号量和任务二值信号量都能实现相应功能,强烈建议使用任务二值信号量。
实验展示场:
发送:
接收:
实验现象:
由于接收端采用无限时间等待,那么按键按一次,才会接收到一次。虽然任务1一直在发送,但是接收一次之后就清零了计数值,这样就实现了任务二值信号量。中断方式和之前任务计数信号量类似,故不再展示实验现象了。
FreeRTOS 任务事件标志组
任务事件标志组
前面章节,我们对事件标志组进行了讲解。 本章节讲解的任务事件标志组与前面章节讲解的事件标
志组要实现的功能是一样的,不同的是调用的函数和支持的事件标志个数,任务事件标志组支持 32 个事
件标志设置,而之前章节介绍的事件标志组,每创建一个支持 24 个事件标志设置:
任务事件标志组的事件标志位是通过任务控制块中的一个 32 位变量 ulNotifiedValue 实现。前面
章节讲解的事件标志组创建后会有自己可以设置的事件标志位。
任务事件标志组是通过函数 xTaskNotifyWait()替代前面章节讲解的函数 xEventGroupWaitBits ()
实现等待事件标志位被设置。
任务事件标志组是通过函数 xTaskNotify() 和 xTaskNotifyFromISR()替代之前讲解的函数
xEventGroupSetBits() 和 xEventGroupSetBitsFromISR 实现对事件标志位的设置。
之前讲解的函数 xEventGroupSetBitsFromISR 是通过给 Daemon 任务(定时器任务)发消
息,在定时器任务中执行实际的操作,而我们本章节要介绍的函数 xTaskNotifyFromISR 是直接在
中断服务程序里面执行操作,效率要高很多。
函数 xTaskNotify
函数描述:
函数 xTaskNotify 通过设置任务控制块中的变量 ulNotifiedValue 可以在任务代码中实现任务事件标志组,
任务计数信号量,任务消息邮箱和任务二值信号量四种方式的消息通知。
第 1 个参数是任务句柄。
第 2 个参数是用来更新任务控制块中的 32 位变量 ulNotifiedValue。
第 3 个参数是任务通知模式设置,支持以下 5 个参数:
返回值,根据上面第 3 个参数的说明,将其设置为 eSetValueWithoutOverwrite,有可能返回
pdFALSE,其余所有情况都返回值 pdPASS。
使用这个函数要注意以下问题:
1. 任务创建后,任务控制块中的变量 ulNotifiedValue 初始计数值是 0。
2. 默认配置此函数可以使用的的宏定义已经在 FreeRTOS.h 文件中使能:
#define configUSE_TASK_NOTIFICATIONS 1
当然,如果用户不需要使用任务通知功能相关的函数,可以在 FreeRTOSConfig.h 文件中配置此宏定
义为 0 来禁止,这样创建的每个任务可以节省 8 个字节的需求。
3. 此函数是用于任务代码中调用的,故不可以在中断服务程序中调用此函数,中断服务程序中使用的是
xTaskNotifyFromISR。
4. 根据 FreeRTOS 的建议,实现二值信号量和计数信号量时使用函数 xTaskNotifyGive()替代此函数xTaskNotify()。
函数 xTaskNotifyFromISR
函数描述:
函数 xTaskNotifyFromISR 通过设置任务控制块中的变量 ulNotifiedValue 可以在中断服务程序中实现任
务事件标志组,任务计数信号量,任务消息邮箱和任务二值信号量四种方式的消息通知(见 26.1 说明)。
第 1 个参数是任务句柄。
第 2 个参数是用来更新任务控制块中的 32 位变量 ulNotifiedValue。
第 3 个参数是任务通知模式设置,支持5 个参数,如上面5个参数一样:
第 4 个参数用于保存是否有高优先级任务准备就绪。如果函数执行完毕后,此参数的数值是 pdTRUE,
说明有高优先级任务要执行,否则没有。
返回值,根据上面第 3 个参数的说明,将其设置为 eSetValueWithoutOverwrite,有可能返回
pdFALSE,其余所有情况都返回值 pdPASS。
使用这个函数要注意以下问题:
1. 任务创建后,任务控制块中的变量 ulNotifiedValue 初始计数值是 0。
2. 默认配置此函数可以使用的的宏定义已经在 FreeRTOS.h 文件中使能:
#define configUSE_TASK_NOTIFICATIONS 1
当然,如果用户不需要使用任务通知功能相关的函数,可以在 FreeRTOSConfig.h 文件中配置此宏定
义为 0 来禁止,这样创建的每个任务可以节省 8 个字节的需求。
3. 此函数是用于中断服务程序中调用的,故不可以在任务代码中调用此函数,任务代码中使用的是xTaskNotify。
4. 根据 FreeRTOS 的建议,实现二值信号量和计数信号量时使用函数 vTaskNotifyGiveFromISR ()替代此函数 xTaskNotifyFromISR ()。
函数 xTaskNotifyWait
函数描述:
函数 xTaskNotifyWait 可以在任务代码中实现任务事件标志组,任务计数信号量,任务消息邮箱和任务二
值信号量四种方式的消息获取。
第 1 个参数 ulBitsToClearOnEntry 用于函数执行之前,将任务控制块中的变量 ulNotifiedValue 进
行如下操作 :
ulNotifiedValue &= ~ulBitsToClearOnEntry
简单的说就是参数 ulBitsToClearOnEntry 哪个位是 1,那么变量 ulNotifiedValue 的那个位就会被
清零。 比如 ulBitsToClearOnEntry = 0x01 表示将变量 ulNotifiedValue 的 bit0 清零,又比如
ulBitsToClearOnEntry = 0xffffffff 表示将变量 ulNotifiedValue 的所有位清零。
第 2 个参数 ulBitsToClearOnExit 用于函数退出前,将任务控制块中的变量 ulNotifiedValue 进行如下操作 :
简单的说就是参数 ulBitsToClearOnExit 哪个位是 1,那么变量 ulNotifiedValue 的那个位就会被清
零。 比如 ulBitsToClearOnExit= 0x01 表示将变量 ulNotifiedValue 的 bit0 清零,又比如
ulBitsToClearOnExit= 0xffffffff 表示将变量 ulNotifiedValue 的所有位清零。
第 3 个参数用于将任务控制块中的变量 ulNotifiedValue 保存到此参数指针所指向的存储单元。 如果
此参数没有用上,可以将其设置为 NULL。
第 4 个参数是没有消息时,等待消息的最大等待时间,单位系统时钟节拍。
返回值,如果成功接收到消息返回 pdTRUE,否则返回 pdFALSE,比如在设置的超时时间内没有收
到消息。
使用这个函数要注意以下问题:
1. 任务创建后,任务控制块中的变量 ulNotifiedValue 初始计数值是 0。
2. 默认配置此函数可以使用的的宏定义已经在 FreeRTOS.h 文件中使能:
#define configUSE_TASK_NOTIFICATIONS 1
当然,如果用户不需要使用任务通知功能相关的函数,可以在 FreeRTOSConfig.h 文件中配置此宏定
义为 0 来禁止,这样创建的每个任务可以节省 8 个字节的需求。
3. 如果用户将 FreeRTOSConfig.h 文件中的宏定义 INCLUDE_vTaskSuspend 配置为 1 且第 2 个参数配
置为 portMAX_DELAY,那么此函数会永久等待直到消息可用。
4. 根据 FreeRTOS 的建议,实现二值信号量和计数信号量时使用函数 ulTaskNotifyTake ()替代此函数
xTaskNotifyWait ()。
实验练兵场:
发送:
接收端:
void vTaskBeep(void *pvParameters)
{
BaseType_t xResult;
const TickType_t xMaxBlockTime = pdMS_TO_TICKS(); /* 设置最大等待时间为500ms */
uint32_t ulValue; while()
{
/*
第一个参数 ulBitsToClearOnEntry的作用(函数执行前):
ulNotifiedValue &= ~ulBitsToClearOnEntry
简单的说就是参数ulBitsToClearOnEntry那个位是1,那么notification value
的那个位就会被清零。 这里ulBitsToClearOnEntry = 0x00000000就是函数执行前保留所有位。 第二个参数 ulBitsToClearOnExit的作用(函数退出前):
ulNotifiedValue &= ~ulBitsToClearOnExit
简单的说就是参数ulBitsToClearOnEntry那个位是1,那么notification value
的那个位就会被清零。 这里ulBitsToClearOnExi = 0xFFFFFFFF就是函数退出前清除所有位。 注:ulNotifiedValue表示任务vTaskBeep的任务控制块里面的变量。
*/ xResult = xTaskNotifyWait(0x00000000,
0xFFFFFFFF,
&ulValue, /* 保存ulNotifiedValue到变量ulValue中 */
xMaxBlockTime); /* 最大允许延迟时间 */ if( xResult == pdPASS )
{
/* 接收到消息,检测那个位被按下 */
if((ulValue & BIT_0) != )
{
printf("接收到K1按键按下消息, ulNotifiedValue = 0x%08x\r\n", ulValue); } if((ulValue & BIT_1) != )
{
printf("接收到K2按键按下消息, ulNotifiedValue = 0x%08x\r\n", ulValue);
}
}
else
{
/* 超时 */
BEEP_TOGGLE;
}
}
}
实验现象:
中断方式不再演示,只是API函数不同。注意其中一个C语言知识点,printf输出十六进制数据,如何操作设置成只显示八位的。
任务消息邮箱
本章节为大家讲解 FreeRTOS 消息队列(消息队列长度固定为 1)的另一种实现方式----基于任务通
知(Task Notifications)的消息队列,这里我们将这种方式实现的消息队列(消息队列长度固定为 1)称
之为任务消息邮箱。 这种方式实现的消息队列效率更高,需要的 RAM 空间更小。当然,缺点也是有的,
它没有前面章节介绍的消息队列实现的功能全面(消息邮箱就是将消息队列长度设置为 1 的情况)。
任务消息邮箱
前面章节,我们对消息队列进行了讲解,而消息邮箱就是将消息队列的长度设置为 1 的情况。 本
章节讲解的任务消息邮箱与前面章节讲解的消息队列长度是 1 时要实现的功能是一样的,不同的是调用的
函数和消息存储的位置:
任务消息邮箱是通过任务控制块中的一个 32 位变量 ulNotifiedValue 对数据进行存取。 前面章节讲
解的消息队列创建后会有自己可以存取数据的空间。
任务消息邮箱是通过函数 xTaskNotifyWait()替代之前讲解的函数 xQueueReceive ()实现从消
息邮箱获取数据。
任务消息邮箱是通过函数 xTaskNotify() 和 xQueueSendFromISR ()替代之前讲解的函数
xQueueSend () 和 xEventGroupSetBitsFromISR 实现向消息邮箱存入数据。
任务消息邮箱通过函数 xTaskNotify 向消息邮箱中发送数据时,如果消息邮箱中上次的数据还没有
处理,不支持超时等待,而消息队列的函数 xQueueSend 是支持超时等待的。
实际项目中,如果使用任务消息邮箱和消息队列都能实现相应功能,强烈建议使用任务消息邮箱。
这个实验和上面的只是在xTaskNotify 函数时的参数设置不同而已,其他使用完全相同,故不再演示。
有个地方的API需要注意一下,队列集的操作,可能会用到:
具体解释,看官网说明。
最后强调一下:
上面表格的5个参数,决定了是用于事件标志组,还是信号量,还是消息邮箱。
FreeRTOS 任务计数信号量,任务二值信号量,任务事件标志组,任务消息邮箱的更多相关文章
- FreeRTOS 事件标志组
以下转载自安富莱电子: http://forum.armfly.com/forum.php 为什么要使用事件标志事件标志组是实现多任务同步的有效机制之一.也许有不理解的初学者会问采用事件标志组多麻烦, ...
- FreeRTOS 事件标志组 ——提高篇
假设你已经看过FreeRTOS 事件标志组这篇随笔了. 之前的基础篇,真的就只是简单了解一下,相当于大学实验室的实验,但是,我们实际公司项目中,需要更多地思考,就算我们之前只是学习了基础概念以及基础语 ...
- FreeRTOS 任务通知模拟事件标志组
实验 //设置事件位的任务 void eventsetbit_task(void *pvParameters) { u8 key; while(1) { if(EventGroupTask_Handl ...
- FreeRTOS 任务通知模拟二值信号量
FreeRTOS官方统计,使用任务通知替代二值信号量的时候,任务解除阻塞的时间要快45%,并且需要的RAM也更少 举例 void DataProcess_task(void *pvParameters ...
- freertos知识点笔记——队列、二值信号量、计数信号量
队列1.队列queue通常用于任务之间的通信,一个任务写缓存,另一个任务读缓存.队列还会有等待时间,2.阻塞超时时间.如果在发送时队列已满,这个时间即是任务处于阻塞态等待队列空间有效的最长等待时间.如 ...
- FreeRTOS 二值信号量,互斥信号量,递归互斥信号量
以下转载自安富莱电子: http://forum.armfly.com/forum.php 本章节讲解 FreeRTOS 任务间的同步和资源共享机制,二值信号量. 二值信号量是计数信号量的一种特殊形式 ...
- ucos中信号量 事件标志 消息队列都怎么用
信号量 事件标志和消息队列分别应用于什么场景(反正我学的时候有点闹不清,现在总结一下): 信号量和事件标志用于任务同步.详细来说,这个功能可以替代以前裸机中你打一个标记的功能,比如使用了一个定时器,5 ...
- FreeRTOS二值信号量
API函数 #if( configSUPPORT_DYNAMIC_ALLOCATION == 1 ) #define xSemaphoreCreateBinary() xQueueGenericCre ...
- μC/OS-III---I笔记5---多值信号量
多值信号量 操作系统中利用信号量解决进程间的同步和互斥(互斥信号量)的问题,在多道程序环境下,操作系统如何实现进程之间的同步和互斥显得极为重要.比如对同一部分资源的访问是要互斥,不能在另一个进程A在访 ...
随机推荐
- Pycharm 2018 激活 亲测有效
下载 https://share.weiyun.com/5NVc5U3 并将 JetbrainsCrack-3.1-release-enc.jar 放置到 pycharm安装目录的\bin目录下( ...
- 直播 背景 技术体系 乐视云直播Demo
背景 最近工作需要做一款直播APP,恩是的,从RTMP协议的实现开始到处理服务器高并发.负载均衡.客户端播放器实现等等等..... 估计全部写完我也到而立之年了吧...... BOSS们估计也是发现了 ...
- 小议使用“完整”的CSS的缺点
1.浏览器支持的不一致性 浏览器的漏洞或缺乏支持的CSS功能,导致不同的浏览器显示出不同的CSS版面编排.例如在微软Internet Explorer6.0的旧版本 ,执行了许多自己的CSS2.0属性 ...
- Thinkphp错误-phpMyAdmin 尝试连接到 MySQL 服务器,但服务器拒绝连
phpMyAdmin 尝试连接到 MySQL 服务器,但服务器拒绝连接.您应该检查配置文件中的主机.用户名和密码,并确认这些信息与 MySQL 服务器管理员所给出的信息一致. 原因有可能是因为修改了m ...
- html5-video视频播放
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/ ...
- Linux shell 提取文件名和目录名
${}用于字符串的读取,提取和替换功能,可以使用${} 提取字符串 1.提取文件名 [root@localhost log]# var=/dir1/dir2/file.txt [root@localh ...
- 转adb Shell root 权限
永久root带文件 因为开发需要,我经常会用到adb这个工具(Android Debug Bridge),我们都知道adb shell默认是没有root权限的,修改系统文件就很不方便了,adb pus ...
- binlog的几种复制形式
binlog的几种复制形式 MySQL 5.5 中对于二进制日志 (binlog) 有 3 种不同的格式可选:Mixed,Statement,Row,默认格式是 Statement.总结一下这三种格式 ...
- Android 使用ORMLite 操作数据库
参考:http://blog.csdn.net/cjjky/article/details/7096987 ormlite 方法查询:http://ormlite.com/javadoc/ormlit ...
- 锁Lock的概念
并发访问同一资源的功能,需要引入锁Lock的概念,也就是说,某个时刻,当有一个访问类访问这个数据对象时,这个数据对象必须上锁Locked,用完后就立即解锁unLocked,再供其它访问类访问.