操作系统原理实验--生产者消费者问题

操作系统原理实验--生产者消费者问题
操作系统原理实验--生产者消费者问题

操作系统课程设计(一号黑体加粗)

用多进程同步方法解决生产者-消费者问题

(小二黑体加粗)

院系:小二黑体加粗

班级:

学号:

姓名:

同组者:

时间:

目录(小二黑体加粗)

一、题目:............................... 错误!未定义书签。

二、设计目的:........................... 错误!未定义书签。

三、总体设计思想概述:................... 错误!未定义书签。

四、说明:............................... 错误!未定义书签。

五、设计要求:........................... 错误!未定义书签。

六、设计方案:........................... 错误!未定义书签。

七、流程图:............................. 错误!未定义书签。

八、运行结果............................. 错误!未定义书签。

九、源程序............................... 错误!未定义书签。

十、总结................................. 错误!未定义书签。十一、参考文献........................... 错误!未定义书签。

四号黑体

一、题目:(标题2,即三号黑体加粗)

用多进程同步方法解决生产者-消费者问题。

二、设计目的:

通过研究Linux 的进程机制和信号量实现生产者消费者问题的并发控制。

三、总体设计思想概述:

1、生产者—消费者问题是一种同步问题的抽象描述。

2、计算机系统中的每个进程都可以消费或生产某类资源。当系统中某一进程使用某一

资源时,可以看作是消耗,且该进程称为消费者。

3、而当某个进程释放资源时,则它就相当一个生产者。

四、说明:

有界缓冲区内设有20个存储单元,放入/取出的数据项设定为1-20这20个整型数。

五、设计要求:

1、每个生产者和消费者对有界缓冲区进行操作后,即时显示有界缓冲区的全部内容,当前

指针位置和生产者/消费者进程的标识符。

2、生产者和消费者各有两个以上。

3、多个生产者或多个消费者之间须有共享对缓冲区进行操作的函数代码。

六、设计方案:

七、流程图:

八、运行结果

1、截图一:

2、截图二:

3、截图三:

4、截图四:

5、截图五:

九、源程序

十、总结

十一、参考文献

消费者行为学实训报告

江苏建筑职业技术学院 《消费者行为学》实训报告 题目:家庭消费行为决策 班级:营销11-1,2 小组成员:苗伟;张艳伟 指导教师:张忠新 报告日期:2012年6月20日

目录 一、实训时间 二、实训地点 三、实训目的 四、实训题目描述和要求 五、实训过程概述 六、实训内容 七、实训总结 八、附录(问卷调查)

一、实训时间 2012年6月18号~6月23号 二、实训地点 江苏建筑职业技术学院机房 徐州市铜山区文沃小区5栋103号 三、实训目的 了解群体、阶层、家族、年龄与消费者行为特点调查 四、实训题目描述和要求 选择一个家庭为调查单位,了解家庭的消费行为决策状况及行为特征

五、实训过程概述 四天的实训时间结束了,在老师的带领下,我们终于圆满完成了关于家庭消费行为决策的调查。我们通过对选择一个家庭为调查单位的方式,了解家庭的消费行为决策状况和主要特征,这些实践活动使我们大学生深入社区群众之间,与他们零距离接触,深入发现他们当前得消费状况,进行心灵上的沟通。并将理论与实践相结合,以小见大,从而来达到了解家庭消费行为决策的目的,诸如此类活动,使我们受益匪浅。 六、实训内容 第一天,我们按照实训安排准时到达实训地点学校机房,老师为我们分配了关于家庭消费行为决策的任务。首先我们通过从网上搜寻资料,了解到了: 1、家庭结构类型及功能 2、家庭生命周期及发展趋势 3、影响家庭消费决策的主要因素 4、家庭决策消费主要消费特征 接下来几天,我们又开始寻找某个家庭作为调查对象,经过重重阻碍,终于经允许我们走进了铜山新区文沃社区5栋103室的张先生家中,恰巧张先生一家三口都在家中,我们首先向张先

实验1:生产者消费者问题

福建农林大学金山学院实验报告 系(教研室):专业:计算机科学与技术年级: 实验课程:生产者与消费者实验姓名:学号: 实验室号:1#608 计算机号:实验时间:指导教师签字:成绩: 实验1:生产者消费者问题 一、实验目的 生产者消费者问题是操作系统中经典的同步和互斥问题。通过实验,要求学生掌握两者之间的同步信号量和互斥信号量的使用,更深刻了解临界资源、同步和互斥的概念。 二、实验要求 1.一组生产者通过一个具有N个缓冲区的缓冲池循环不断地向一组消费者提供产 品。 2.建一个队列, 队列的长度由n记录, 定义两个指针, 分别指向队列的头和尾消 费者从头指针读取数据,每读取一个数据把n--,生产者把数据写入尾指针, 每写入一个数据就n++,当n=N的时候生产者暂停写入数据。 3.注意:缓冲池队列,用互斥锁保护。 三、实验内容和原理 1.分别画出生产者和消费者的流程图

2.针对生产者和消费者问题,可以分为哪几种情况,使用了哪些原语?分别代表 什么意思?过程如何?阐述哪些进程之间存在同步,哪些进程之间存在互斥。 3.缓冲区是否为临界资源?是否可以循环使用?通过什么来实现?举例说明(可 画图) 四、实验环境 1. 硬件:PC机; 2. 软件:Windows操作系统、。 五、算法描述及实验步骤 #include <> #include const unsigned short SIZE_OF_BUFFER = 10; unsigned short ProductID = 0; unsigned short ConsumeID = 0;

unsigned short in = 0; unsigned short out = 0; int g_buffer[SIZE_OF_BUFFER]; bool g_continue = true; HANDLE g_hMutex; HANDLE g_hFullSemaphore; HANDLE g_hEmptySemaphore; DWORD WINAPI Producer(LPVOID); DWORD WINAPI Consumer(LPVOID); int main() { g_hMutex = CreateMutex(NULL,FALSE,NULL); g_hFullSemaphore = CreateSemaphore(NULL,SIZE_OF_BUFFER-1,SIZE_OF_BUFFER-1,NULL); g_hEmptySemaphore = CreateSemaphore(NULL,0,SIZE_OF_BUFFER-1,NULL); const unsigned short PRODUCERS_COUNT = 3; const unsigned short CONSUMERS_COUNT = 1; const unsigned short THREADS_COUNT = PRODUCERS_COUNT+CONSUMERS_COUNT; HANDLE hThreads[PRODUCERS_COUNT]; DWORD producerID[CONSUMERS_COUNT]; DWORD consumerID[THREADS_COUNT]; for (int i=0;i

操作系统实验报告生产者消费者问题

操作系统课程设计 一.实验目标 完成N个生产者和M个消费者线程之间的并发控制,N、M不低于30,数据发送和接收缓冲区尺寸不小于20个(每个产品占据一个)。 其中生产者线程1、3、5、7、9生产的产品供所有奇数编号的消费者线程消费,只有所有奇数编号的消费者线程都消费后,该产品才能从缓冲区中撤销。 其中生产者线程2、4、6、8、10生产的产品所有偶数编号的消费者线程都可消费,任一偶数编号消费者线程消费该消息后,该产品都可从缓冲区中撤销。 其中11-20号生产者线程生产的产品仅供对应编号的消费者线程消费。 其他编号生产者线程生产的产品可由任意的消费者线程消费。 每个生产线程生产30个消息后结束运行。如果一个消费者线程没有对应的生产者线程在运行后,也结束运行。所有生产者都停止生产后,如果消费者线程已经

没有可供消费的产品,则也退出运行。 二.实验原理 2.1原理 生产者与消费者线程采用posix互斥锁机制进行互斥进入各自的代码段,只有采用互斥锁临界区代码段才可以不被打扰的执行;同步机制采用的是posix条件变量pthread_cond_wait和pthraed_cond_signal进行同步的。 线程间的通信采用的是共享内存机制。(注:所有的共享内存块是在进程里建立的,线程只需链接上各自的共享内存块即可,每一块共享内存的大小是100). 在这里共享内存设置成一个100的数组。 具体实施:(1)为1.3.5.7.9建立一个共享内存1号,1.3.5.7.9生产者线程生产的产品都放入这块共享内存缓冲区,所有奇数的消费者线程要消费的话,只需在消费者线程中链接上这块共享内存,就可以直接消费1.3.5.7.9生产者线程生产的产品。 (2)为2.4.6.8.10建立一块共享内存2号。2.4.6.8.10生产的产品都放入2号共享内存缓冲区,所有的偶数的消费者线程只要链接上2号缓冲区,就可以消费2.4.6.8.10生产的产品。当偶数消费者线程消费产品后,产品即可从缓冲区撤销,方法是在消费线程里将消费的产品在共享内存数组里置0。 (3)为11--20的每一对生产者消费者线程建立一块共享内存,编号11--20. 11--20号的消费者线程能链接各自的共享内存缓冲区或奇数或偶数共享内存缓冲区,即11--20号的生产者生产的产品只能被对应的消费者消费而11-20的奇数消费者可以消费缓冲区1的产品,偶数消费者可消费缓冲区2的产品。 (4)为21--30号的生产者消费者线程只建立一块共享内存21号,21--30号生产者生产的产品都放入21号缓冲区,所有的消费者线程只要链接上21号共享内存,就可以消费21--30号生产者生产的产品。 用于控制线程是否结束的方法是:设置一个全局变量t,在生产者线程里进行t++,在生产者线程里当t达到10时(注:为了很好的测试程序,本应该在生产者生产30个产品时菜结束线程,这里设置成了10),就break跳出while()循环,这样线程自然就终止。同样在消费者线程里,当t达到10时,这里不用t++,就跳出while()循环,消费者线程自然就终止。这样设计满足了,当生产者生产30个产品时就终止生产者线程,生产者线程终止消费者线程也得终止的要求。 生产者从文件so.txt读取数据进行生产,这个文件里的数据是一连串的字符从a--z的组合,没有空格或其他字符。文件内容的格式没有特殊要求。

操作系统生产者与消费者问题实验报告

《操作系统》实验报告 生产者和消费者的问题 一、实验目的 1.掌握基本的同步与互斥的算法,理解基本的生产者与消费者的模型。 2.学习使用Windows 2000/XP中基本的同步对象,掌握相关的API的使用方法。 3.了解Windows 2000/XP中多线程的并发执行机制,线程间的同步和互斥。 二、实验的内容及其要求 1.实验内容 以生产者/消费者模型为根据,在Windows 2000环境下创建一个控制台进程,在改进程中创建n个线程模拟生产者和消费者,实现进程(线程)的同步与互斥。 2.实验要求 ①学习并理解生产者/消费者模型及其同步/互斥规则 ②学习了解Windows同步对象及其特性 ③熟悉实验环境,掌握相关API的使用方法 ④设计程序,实现生产者/消费者进程(线程)的同步与互斥 ⑤提交实验报告 三、实验的时间安排 1.实验前,先到图书馆或上网百度了解有关生产者/消费者模型的相关知识,建立生产者/消费者模型的基本概念。 2.利用13周、15周、17周的上机时间编写和调试程序代码。 3.利用其他课余时间来分析实验的最终结果并完成相关的实验报告。 四、实验的环境 1.硬件条件:普通计算机一台 2.软件条件:①操作系统:Windows 2000/XP ②开发语言:VC++ 本实验是在Windows 2000+VC6.0环境下实现的,利用Windows SDK提供的系统接口(API)完成程序的功能。实验在Windows下安装VC后进行,因为VC是一个集成开发环境,其中包含了Windows SDK所有工具和定义,所以安装了VC后就不用特意安装SDK了。实验中所用的API(应用程序接口),是操作系统提供的用来进行应用程序设计的系统功能接口。要使用这些API,需要包含对这些函数进行说明的SDK 头文件,最常见的就是windows.h。一些特殊的API调用还需要包含其他的头文件。 五、正文 1.程序结构图:

操作系统原理-进程调度实验报告

一、实验目的 通过对进程调度算法的设计,深入理解进程调度的原理。 进程是程序在一个数据集合上运行的过程,它是系统进行资源分配和调度的一个独立单位。 进程调度分配处理机,是控制协调进程对CPU的竞争,即按一定的调度算法从就绪队列中选中一个进程,把CPU的使用权交给被选中的进程。 进程通过定义一个进程控制块的数据结构(PCB)来表示;每个进程需要赋予进程ID、进程到达时间、进程需要运行的总时间的属性;在RR中,以1为时间片单位;运行时,输入若干个进程序列,按照时间片输出其执行序列。 二、实验环境 VC++6.0 三、实验内容 实现短进程优先调度算法(SPF)和时间片轮转调度算法(RR) [提示]: (1) 先来先服务(FCFS)调度算法 原理:每次调度是从就绪队列中,选择一个最先进入就绪队列的进程,把处理器分配给该进程,使之得到执行。该进程一旦占有了处理器,它就一直运行下去,直到该进程完成或因发生事件而阻塞,才退出处理器。 将用户作业和就绪进程按提交顺序或变为就绪状态的先后排成队列,并按照先来先服务的方式进行调度处理,是一种最普遍和最简单的方法。它优先考虑在系统中等待时间最长的作业,而不管要求运行时间的长短。 按照就绪进程进入就绪队列的先后次序进行调度,简单易实现,利于长进程,CPU繁忙型作业,不利于短进程,排队时间相对过长。 (2) 时间片轮转调度算法RR

原理:时间片轮转法主要用于进程调度。采用此算法的系统,其程序就绪队列往往按进程到达的时间来排序。进程调度按一定时间片(q)轮番运行各个进程. 进程按到达时间在就绪队列中排队,调度程序每次把CPU分配给就绪队列首进程使用一个时间片,运行完一个时间片释放CPU,排到就绪队列末尾参加下一轮调度,CPU分配给就绪队列的首进程。 固定时间片轮转法: 1 所有就绪进程按 FCFS 规则排队。 2 处理机总是分配给就绪队列的队首进程。 3 如果运行的进程用完时间片,则系统就把该进程送回就绪队列的队尾,重新排队。 4 因等待某事件而阻塞的进程送到阻塞队列。 5 系统把被唤醒的进程送到就绪队列的队尾。 可变时间片轮转法: 1 进程状态的转换方法同固定时间片轮转法。 2 响应时间固定,时间片的长短依据进程数量的多少由T = N × ( q + t )给出的关系调整。 3 根据进程优先级的高低进一步调整时间片,优先级越高的进程,分配的时间片越长。 多就绪队列轮转法: (3) 算法类型 (4)模拟程序可由两部分组成,先来先服务(FCFS)调度算法,时间片轮转。流程图如下:

消费者行为学课内实验三

《消费者行为学》课实验三 项目名称:创新产品扩散影响因素的调查分析报告 专业: 姓名: 学号: 撰写时间:

目录 1.创新产品扩散相关理论 (3) 1.1创新产品 (3) 1.2创新产品扩散式 (3) 1.3影响创新产品扩散的因素 (3) 2. 研究设计 (4) 2.1 研究目的 (4) 2.2 研究对象 (4) 2.3 研究法 (4) 3. 创新产品扩散因素分析 (4) 3.1产品特征 (4) 3.2目标市场的特性 (6) 3.3市场营销活动 (8) 4. 创新产品扩散式预测 (8) 附录:防雾霾口罩扩散影响因素调查问卷

1.创新产品扩散相关理论 1.1创新产品 创新包括多个面如产品创新、工艺创新、市场创新和管理创新等;从消费者行为研究角度,我们将创新主要限定在“产品创新”这一意义来使用。产品创新是指新进导入市场且被消费者视为较现有产品更为新颖的产品。按照联邦贸易委员会规定,如果一种产品在广告中宣称为新产品,则该产品的市场导入时间不能超过6个月。一种产品能否被视为创新产品,取决于该产品在多大程度上引起消费者行为的改变。 1.2创新产品扩散式 创新扩散式或类型大致可分为三种,即正常型、快速扩散型、缓慢扩散型。 1.3影响创新产品扩散的因素 扩散过程成种类型,或者说扩散曲线具体呈种形状,取决于很多的影响因素。主要影响因素包括:(1)产品特征。如相对优点、兼容性、可观察性、可适用性、低复杂性等都将影响创新产品被采用的速度,因而影响创新扩散曲线的形状。(2)目标市场的特性。例如,面向年轻、受过良好教育和更富流动性的消费群体销售的产品,被采用的速度更快,同时产品进入衰退期的时距也更短。(3)市场营销活动。企业能够通过有效的营销策略,如更高的品质、大规模的宣传等影响创新产品扩散的进程。

生产者与消费者实验报告

生产者和消费者实验报告 【实验目的】 1.加深对进程概念的理解,明确进程和程序的区别。 2.进一步认识并发执行的实质。 3.验证用信号量机制实现进程互斥的方法。 4.验证用信号量机制实现进程同步的方法。 【实验要求】 用c语言编程搭建“生产者和消费者”经典进程通信问题的环境。要求程序运行时,按任意键停止,显示当前系统的各个参数的值。提交实验报告,以及相关程序列表。打包成附件上传。 【实验环境】 Visual C++6.0 【实验内容】 1.了解经典同步问题“生产者和消费者” 生产者与消费者可以通过一个环形缓冲池联系起来,环形缓冲池由几个大小相等的缓冲块组成,每个缓冲块容纳一个产品。每个生产者可不断地每次往缓冲池中送一个生产产品,而每个消费者则可不断地每次从缓冲池中取出一个产品。指针i和指针j分别指出当前的第一个空缓冲块和第一个满缓冲块。 2.分析和理解 (1)既存在合作同步问题,也存在临界区互斥问题 合作同步:当缓冲池全满时,表示供过于求,生产者必须等待,同时唤醒消费者;当缓冲池全空时,表示供不应求,消费者应等待,同时唤醒生产者。 互斥:缓冲池显然是临界资源,所在生产者与消费都要使用它,而且都要改变它的状态。 (2)基于环形缓冲区的生产者与消费者关系形式描述: 公用信号量mutex:初值为1,用于实现临界区互斥 生产者私用信号量empty:初值为n,指示空缓冲块数目 消费者私用信号量full:初值为0,指示满缓冲块数目 整型量i和j初值为0,i指示首空缓冲块序号,j指示首满缓冲块序号 (3)PV原语 var mutex,empty,full:semaphore; i,j:integer;buffer:array[0...n-1] of item; i:=j:=1; Procedure producer; begin while true do begin

操作系统原理实验-系统内存使用统计5

上海电力学院 计算机操作系统原理 实验报告 题目:动态链接库的建立与调用 院系:计算机科学与技术学院 专业年级:信息安全2010级 学生姓名:李鑫学号:20103277 同组姓名:无 2012年11 月28 日上海电力学院

实验报告 课程名称计算机操作系统原理实验项目线程的同步 姓名李鑫学号20103277 班级2010251班专业信息安全 同组人姓名无指导教师姓名徐曼实验日期2012/11/28 实验目的和要求: (l)了解Windows内存管理机制,理解页式存储管理技术。 (2)熟悉Windows内存管理基本数据结构。 (3)掌握Windows内存管理基本API的使用。 实验原理与内容 使用Windows系统提供的函数和数据结构显示系统存储空间的使用情况,当内存和虚拟存储空间变化时,观察系统显示变化情况。 实验平台与要求 能正确使用系统函数GlobalMemoryStatus()和数据结构MEMORYSTATUS了解系统内存和虚拟空间使用情况,会使用VirtualAlloc()函数和VirtualFree()函数分配和释放虚拟存储空间。 操作系统:Windows 2000或Windows XP 实验平台:Visual Studio C++ 6.0 实验步骤与记录 1、启动安装好的Visual C++ 6.0。 2、选择File->New,新建Win32 Console Application程序, 由于内存分配、释放及系统存储 空间使用情况均是Microsoft Windows操作系统的系统调用,因此选择An application that support MFC。单击确定按钮,完成本次创建。 3、创建一个支持MFC的工程,单击完成。

消费者行为学(1)

消费者行为学 题型:名词解释、单选、多选、判断、简答题、案例题(①2006年春节黄金周香港迪斯尼拒客事件②企业市场营销与消费者行为,即最后一章,会出案例题) 名词解释 1、面子消费和象征消费(二者选一) 面子消费:指在消费中更重视别人的看法和意见,更关注戈恩消费的社会群体效应。 象征消费:指的是消费具有符号象征。即消费不仅是物理或物质的消费,而且也是象征的消费。 2、参考群体和意见领袖(二者选一) 参考群体:消费者在个体形成购买决策时,作为参考、比较的个人或群体。 意见领袖:是指那些更频繁或更多地向其他消费者提供信息,从而在更大程度上影响他人的态度和行为的消费者。 简答题: 1、简述消费者行为学的演进和发展 (1)萌芽与初创时期:20世纪20年代以前,这一时期研究的重点是促进企业的产品销售,而非满足消费者需求;1901年,美国斯科特《广告心理学》被任务标志这消费心理学前身的出现。 (2)应用与发展时期:①20世纪30年代世界性经济危机,商品市场完全转变为买方市场;企业纷纷奉行“市场观念”,研究消费者心理趋势逐渐形成。其中首先取得进展的是消费者动机的研究。一些工程师、制造商发现产品外观、造型、性能等对消费者心理有重要影响,为消费者心理与行为开辟了一个新的领域;②20世纪60年代蓬勃发展:1960年美国心理学会成立——独立学科正式产生;1968年第一部消费者行为学教材诞生;③1969年每个消费者研究协会诞生。 (3)变革与创新时期:①20世纪70年代以来,有关消费者心理与行为的研究进入全名发展和成熟的阶段;②20世纪80年代后出现了新的研究领域主题,如顾客满意度、品牌、客户关系等。而我国直到20世纪80年代才引入研究:不成熟、前景广阔。 2、简述消费者行为学多学科研究视野 学科间的借鉴、沟通、联系、整合,增加消费者行为理论的时代感与解释力。消费者行为是一个非常复杂的现象,它隐含了心理、社会、经济、文化等多个层面的含义,具有多维度多层次的特点。 (1)经济学视角:理性的消费者 对于消费者而言,经济学首先假定:消费者具有完全理性,即消费者完全了解自己消费的物品,自觉把效用最大化为目标;存在消费者主权,即由消费者决定自己的消费,当然也间接决定生产;效用仅仅来源于物品的消费。 (2)心理学视角:感性而又理性的消费者 心理学认为,消费者是一个心理、意识和行为融为一体的个体。消费者行为进行的过程,也是消费心理和消费需求不断满足的过程。 ①动力派:需求、动机——马斯洛需求理论 ②行为派:外显行为+内隐行为(黑箱);研究外显,拒绝心理。

1实验1:生产者消费者问题

1实验1:生产者消费者问 题 -标准化文件发布号:(9556-EUATWK-MWUB-WUNN-INNUL-DDQTY-KII

福建农林大学金山学院实验报告 系(教研室):专业:计算机科学与技术年级: 实验课程:生产者与消费者实验姓名:学号: 实验室号:1#608 计算机号:实验时间:指导教师签字:成绩: 实验1:生产者消费者问题 一、实验目的 生产者消费者问题是操作系统中经典的同步和互斥问题。通过实验,要求学生掌握两者之间的同步信号量和互斥信号量的使用,更深刻了解临界资源、同步和互斥的概念。 二、实验要求 1.一组生产者通过一个具有N个缓冲区的缓冲池循环不断地向一组消费者提供 产品。 2.建一个队列, 队列的长度由n记录, 定义两个指针, 分别指向队列的头和尾消费 者从头指针读取数据,每读取一个数据把n--,生产者把数据写入尾指针, 每写 入一个数据就n++,当n=N的时候生产者暂停写入数据。 3.注意:缓冲池队列,用互斥锁保护。 三、实验内容和原理 1.分别画出生产者和消费者的流程图

2.针对生产者和消费者问题,可以分为哪几种情况,使用了哪些原语分别代表什 么意思过程如何阐述哪些进程之间存在同步,哪些进程之间存在互斥。 3.缓冲区是否为临界资源是否可以循环使用通过什么来实现举例说明(可画图) 四、实验环境 1. 硬件:PC机; 2. 软件:Windows操作系统、。 五、算法描述及实验步骤 #include <> #include const unsigned short SIZE_OF_BUFFER = 10; unsigned short ProductID = 0; unsigned short ConsumeID = 0; unsigned short in = 0;

消费者行为学实验课程大纲1

《消费者行为学实验》课程教学大纲 一、课程基本信息 课程代码:B04030660 课程名称:消费者行为学实验 课程性质:专业课 适用专业:工商管理各专业 开课学期:春季学期 总学时:8学时 总学分:0.5学分 预修课程:管理学、市场营销学 课程简介:实践教学是应用性学科教学方式的生命线。鉴于本门课程的性质和其在专业中的重要地位,消费者行为学课程实验教学的内容主要包括两大方面:一是进行各种以体验与加深消费者行为分析理论的理解为目的的实践活动;二是各种培养学生进行实际消费者行为分析的技能的实践活动。 推荐教材:《消费者行为学》,甘瑁琴主编,北京大学出版社、中国农业大学出版社,2008年 参考书目: [1] 符国群编,《消费者行为学》,武汉大学出版社, 2005 年出版 [2]龚振编,《消费者行为学》,广东高等教育出版社, 2004 年出版 二、课程总目标 本课程实践教学的目的是为了加深学生对消费者行为理论的理解,培养学生从事消费者行为研究的能力和创新思维能力,同时提高学生将消费者行为研究的发现应用于营销决策的实践能力。 三、实践教学内容与目标(含学时分配) 1.消费者行为认知(0.5学时): 通过对某一产品或某一行业的消费者行为的分析,加深对消费者行为的认识。实验内容:(1)访问一位商人,要求他或她为消费者行为下一个定义,同时请她或他谈谈了解消费者行为在改善其工作绩效方面所起的作用。这些回答在多大程度上反映了现代市场营销观念?(2)访问一位经理或店主,询问那些变量是营销消费者行为的重要因素。将这些因素与书中介绍的影响变量作比较,你从中可得出什么结论? 2.测量消费者的购买动机并制定相应营销策略(1学时): 掌握测量消费者购买动机的方法并如何利用动机知识吸引目标消费者。实验内容:(1)总结出测量显性动机和隐性动机的方法,并找出一个直接迎合显性动机、间接迎合隐性动机的广告,解释该广告是怎样和为什么使用这两种方法。以调查购买手机的大学生为对象进行研究。(2)找出一则重点体现自我实现需要的广告和一则重点体现安全需要的广告,解释这两则广告是如何分别体现这两种需要以及企业为什么要迎合这两种需要。 3.利用消费者知觉制定营销策略(0.5学时): 掌握如何利用消费者知觉制定营销策略。实验内容:(1)访问1 0名同学,询问他们在电视或电台播放广告时在干什么?你能从中得出什么结论?(2)选择三则印刷品广告,找出用来吸引受众注意力的所有可能的刺激物因素。(3)找出三个你认为设计得比较好的三个你认为涉及有问题的品牌名,解释你如此选择的理由。 4.利用学习理论来教育消费者(1学时): 掌握如何利用学习理论来教育消费者。实验内容:分别找三个利用了经典条件反射、操作条件反射、认知学习理论的广告,并分析广告运用得是否成功。 5.测量态度并改变消费者的态度(1学时): 掌握如何测量态度的方法以及改变态度的营销策略。实验内容:访问5名外班同学,运用语意差别法测量他们对两个熟悉的大型商场的态度。根据你的调查结果,为这两家商场提出改进建议。 6.基于目标消费者的个性心理特征来制定相应的营销策略(1学时): 掌握如何基于目标消费者的个性心理特征来制定相应的营销策略。(1)找出并复印或描述针对VALS2每一细分

操作系统原理实验四

实验4 进程控制 1、实验目的 (1)通过对WindowsXP进行编程,来熟悉和了解系统。 (2)通过分析程序,来了解进程的创建、终止。 2、实验工具 (1)一台WindowsXP操作系统的计算机。 (2)计算机装有Microsoft Visual Studio C++6.0专业版或企业版。 3、预备知识 (3)·CreateProcess()调用:创建一个进程。 (4)·ExitProcess()调用:终止一个进程。 4、实验编程 (1)编程一利用CreateProcess()函数创建一个子进程并且装入画图程序(mspaint.exe)。阅读该程序,完成实验任务。源程序如下: # include < stdio.h > # include < windows.h > int main(VOID) ﹛STARTUPINFO si; PROCESS INFORMA TION pi; ZeroMemory(&si,sizeof(si)); Si.cb=sizeof(si); ZeroMemory(&pi,sizeof(pi)); if(!CreateProcess(NULL, “c: \ WINDOWS\system32\ mspaint.exe”, NULL, NULL, FALSE, 0, NULL, NULL, &si,&pi)) ﹛fprintf(stderr,”Creat Process Failed”); return—1; ﹜ WaitForSingleObject(pi.hProcess,INFINITE); Printf(“child Complete”); CloseHandle(pi.hProcess); CloseHandle(pi hThread); ﹜

操作系统生产者消费者问题实验报告

实验报告二 实验名称:一、生产者-消费者问题的多线程解决方案 二、设计一个执行矩阵乘法的多线程程序 日期:2015-10-22 班级:13级计科学号:姓名: 一、实验目的 1.掌握线程的同步与互斥 2.掌握生产者消费者的实现问题 3.掌握多线程的编程方法 4.掌握矩阵乘法的基本计算原理以及实现 二、实验内容 1.生产者-消费者问题的多线程解决方案 2.设计一个执行矩阵乘法的多线程程序 三、项目要求与分析 1.请查阅资料,掌握线程创建的相关知识以及矩阵乘法的相关知识,了解java语言程序编写的相关知识 2.理解线程的实验步骤 在本次试验中,以“生产者-消费者”模型为依据,提供了一个多线程的“生产者-消费者”实例,编写java代码调试运行结果,得出相应的结论。 理解矩阵乘法的实验步骤 四、具体实现 1.生产者-消费者实例 (1)创建一个缓冲信息发送接收通道接口,并创建邮箱盒子类实现,主要代码如下: ength; j++) { ength; j++)

{ " "); } ""); } ""); } (1)创建多线程类,并实现Runnable接口同步对矩阵进行分行计算,主要代码如下: etName()+"\t开始计算第 "+(task+1)+"行"); for(int i=0; i<; i++) { for(int j=0; j<; j++) { [task][i] += [task][j] * [j][i]; } } } ; } (2)通过不断改变矩阵大小,线程数目,,调试程序,运行结果: 五、所遇问题与解决方法 1.在生产者-消费者多线程试验中,刚开始没有考虑到使用线程睡眠,运行结 果速度之快,没法观看数据变化,后面定义了睡眠控制,使得问题得以解决2.在多线程矩阵开发实验中,刚开始定义矩阵太小,测试结果不太明显,后面 通过把矩阵改大,并且线程数目不断变化使得结果明显。 六、实验总结 深刻了解了生产者消费者多线程,进一步理解了“生产者-消费者”模型。同时也掌握了一些java编程语言相关知识。多线程矩阵实验中,发现矩阵小时,线程越少,运行时间越长;而矩阵过大时,线程数量与运行时间成反比。

实验报告五 生产者和消费者问题

实验报告五 ——生产者和消费者问题 姓名:丛菲学号:20100830205 班级:信息安全二班一、实习内容 ?1、模拟操作系统中进程同步和互斥 ?2、实现生产者和消费者问题的算法实现 二、实习目的 ?1、熟悉临界资源、信号量及PV操作的定义与物理意义 ?2、了解进程通信的方法 ?3、掌握进程互斥与进程同步的相关知识 ?4、掌握用信号量机制解决进程之间的同步与互斥问题 ?5、实现生产者-消费者问题,深刻理解进程同步问题 三、实习题目 ?在Linux操作系统下用C实现经典同步问题:生产者—消费者,具体要求如下: (1)一个大小为10的缓冲区,初始状态为空。 (2)2个生产者,随机等待一段时间,往缓冲区中添加数据,若缓冲区已满,等待消 费者取走数据之后再添加,重复10次。 (3)2个消费者,随机等待一段时间,从缓冲区中读取数据,若缓冲区为空,等待生 产者添加数据之后再读取,重复10次。 ?提示 本实验的主要目的是模拟操作系统中进程同步和互斥。在系统进程并发执行异步推进的过程中,由于资源共享和进程间合作而造成进程间相互制约。进程间的相互制约有两种不同的方式。 (1)间接制约。这是由于多个进程共享同一资源(如CPU、共享输入/输出设备)而引起的,即共享资源的多个进程因系统协调使用资源而相互制约。 (2)直接制约。只是由于进程合作中各个进程为完成同一任务而造成的,即并发进程各自的执行结果互为对方的执行条件,从而限制各个进程的执行速度。 生产者和消费者是经典的进程同步问题,在这个问题中,生产者不断的向缓冲区中写入数据,而消费者则从缓冲区中读取数据。生产者进程和消费者对缓冲区的操作是互斥,即当前只能有一个进程对这个缓冲区进行操作,生产者进入操作缓冲区之前,先要看缓冲区是否已满,如果缓冲区已满,则它必须等待消费者进程将数据取出才能写入数据,同样的,消费者进程从缓冲区读取数据之前,也要判断缓冲

消费者行为学课内实验三

《消费者行为学》课内实验三 项目名称:创新产品扩散影响因素的调查分析报告 专业: 姓名: 学号: 撰写时间:

目录 1.创新产品扩散相关理论 (3) 1.1创新产品 (3) 1.2创新产品扩散方式 (3) 1.3影响创新产品扩散的因素 (3) 2. 研究设计 (4) 2.1 研究目的 (4) 2.2 研究对象 (4) 2.3 研究方法 (4) 3. 创新产品扩散因素分析 (4) 3.1产品特征 (4) 3.2目标市场的特性 (6) 3.3市场营销活动 (8) 4. 创新产品扩散方式预测 (8) 附录:防雾霾口罩扩散影响因素调查问卷

1.创新产品扩散相关理论 1.1创新产品 创新包括多个方面如产品创新、工艺创新、市场创新和管理创新等;从消费者行为研究角度,我们将创新主要限定在“产品创新”这一意义来使用。产品创新是指新进导入市场且被消费者视为较现有产品更为新颖的产品。按照联邦贸易委员会规定,如果一种产品在广告中宣称为新产品,则该产品的市场导入时间不能超过6个月。一种产品能否被视为创新产品,取决于该产品在多大程度上引起消费者行为的改变。 1.2创新产品扩散方式 创新扩散方式或类型大致可分为三种,即正常型、快速扩散型、缓慢扩散型。 1.3影响创新产品扩散的因素 扩散过程成何种类型,或者说扩散曲线具体呈何种形状,取决于很多的影响因素。主要影响因素包括:(1)产品特征。如相对优点、兼容性、可观察性、可适用性、低复杂性等都将影响创新产品被采用的速度,因而影响创新扩散曲线的形状。(2)目标市场的特性。例如,面向年轻、受过良好教育和更富流动性的消费群体销售的产品,被采用的速度更快,同时产品进入衰退期的时距也更短。(3)市场营销活动。企业能够通过有效的营销策略,如更高的品质、大规模的宣传等影响创新产品扩散的进程。

操作系统实验报告生产者与消费者问题模拟

操作系统上机实验报告 实验名称: 生产者与消费者问题模拟 实验目的: 通过模拟生产者消费者问题理解进程或线程之间的同步与互斥。 实验内容: 1、设计一个环形缓冲区,大小为10,生产者依次向其中写入1到20,每个缓冲区中存放一个数字,消费者从中依次读取数字。 2、相应的信号量; 3、生产者和消费者可按如下两种方式之一设计; (1)设计成两个进程; (2)设计成一个进程内的两个线程。 4、根据实验结果理解信号量的工作原理,进程或线程的同步\互斥关系。 实验步骤及分析: 一.管道 (一)管道定义 所谓管道,是指能够连接一个写进程和一个读进程的、并允许它们以生产者—消费者方式进行通信的一个共享文件,又称为pipe文件。由写进程从管道的写入端(句柄1)将数据写入管道,而读进程则从管道的读出端(句柄0)读出数据。(二)所涉及的系统调用 1、pipe( ) 建立一无名管道。 系统调用格式 pipe(filedes) 参数定义 int pipe(filedes); int filedes[2]; 其中,filedes[1]是写入端,filedes[0]是读出端。 该函数使用头文件如下: #include #inlcude #include 2、read( ) : 系统调用格式 read(fd,buf,nbyte) 功能:从fd所指示的文件中读出nbyte个字节的数据,并将它们送至由指针buf 所指示的缓冲区中。如该文件被加锁,等待,直到锁打开为止。 参数定义:

int read(fd,buf,nbyte); int fd; char *buf; unsigned nbyte; 3、write( ) 系统调用格式 read(fd,buf,nbyte) 功能:把nbyte 个字节的数据,从buf所指向的缓冲区写到由fd所指向的文件中。如文件加锁,暂停写入,直至开锁。 参数定义同read( )。 (三)参考程序 #include #include #include int pid1,pid2; main( ) { int fd[2]; char outpipe[100],inpipe[100]; pipe(fd); /*创建一个管道*/ while ((pid1=fork( ))==-1); if(pid1==0) { lockf(fd[1],1,0); /*把串放入数组outpipe中*/ sprintf(outpipe,child 1 is using pipe!); /* 向管道写长为50字节的串*/ write(fd[1],outpipe,50); sleep(5); /*自我阻塞5秒*/ lockf(fd[1],0,0); exit(0); } else { while((pid2=fork( ))==-1); if(pid2==0) { lockf(fd[1],1,0); /*互斥*/ sprintf(outpipe,child 2 is using pipe!); write(fd[1],outpipe,50); sleep(5); lockf(fd[1],0,0);

操作系统原理实验五

实验五线程的同步 1、实验目的 (1)进一步掌握Windows系统环境下线程的创建与撤销。 (2)熟悉Windows系统提供的线程同步API。 (3)使用Windows系统提供的线程同步API解决实际问题。 2、实验准备知识:相关API函数介绍 ①等待对象 等待对象(wait functions)函数包括等待一个对象(WaitForSingleObject ())和等待多个对象(WaitForMultipleObject())两个API函数。 1)等待一个对象 WaitForSingleObject()用于等待一个对象。它等待的对象可以为以下对象 之一。 ·Change ontification:变化通知。 ·Console input: 控制台输入。 ·Event:事件。 ·Job:作业。 ·Mutex:互斥信号量。 ·Process:进程。 ·Semaphore:计数信号量。 ·Thread:线程。 ·Waitable timer:定时器。 原型: DWORD WaitForSingleObject( HANDLE hHandle, // 对象句柄 DWORD dwMilliseconds // 等待时间 ); 参数说明: (1)hHandle:等待对象的对象句柄。该对象句柄必须为SYNCHRONIZE访问。 (2)dwMilliseconds:等待时间,单位为ms。若该值为0,函数在测试对象的状态后立即返回,若为INFINITE,函数一直等待下去,直到接收到 一个信号将其唤醒,如表2-1所示。 返回值: 如果成功返回,其返回值说明是何种事件导致函数返回。

Static HANDLE hHandlel = NULL; DWORD dRes; dRes = WaitForSingleObject(hHandlel,10); //等待对象的句柄为hHandlel,等待时间为10ms 2)等待对个对象 WaitForMultiple()bject()在指定时间内等待多个对象,它等待的对象与 WaitForSingleObject()相同。 原型: DWORD WaitForMultipleObjects( DWORD nCount, //句柄数组中的句柄数 CONST HANDLE * lpHandles, //指向对象句柄数组的指针 BOOL fWaitAll, //等待类型 DWORD dwMilliseconds //等待时间 ); 参数说明: (1)nCount:由指针 * lpHandles指定的句柄数组中的句柄数,最大数是MAXIMUM WAIT OBJECTS。 (2)* lpHandles:指向对象句柄数组的指针。 (3)fWaitAll:等待类型。若为TRUE,当由lpHandles数组指定的所有对象被唤醒时函数返回;若为FALSE,当由lpHandles数组指定的某一个 对象被唤醒时函数返回,且由返回值说明是由于哪个对象引起的函数 返回。 (4)dwMilliseconds:等待时间,单位为ms。若该值为0,函数测试对象的状态后立即返回;若为INFINITE,函数一直等待下去,直到接收到 一个信号将其唤醒。 返回值:、 如果成功返回,其返回值说明是何种事件导致函数返回。 各参数的描述如表2-2所示。

消费者行为学习题及答案

消费者行为学习题及答案

单项选择题 1. 关于消费者行为的专门研究,开始于()。 A)19世纪30年代 B)20世纪30年代 C)19世纪末20世纪初 D)20世纪40年代 2.在消费者品牌选择规则中,允许品牌中较劣的属性与较优的属性相互补偿的是()。 A)期望值选择规则 B)联结式规则 C)重点选择规则 D)编纂式规则 3.将赫兹伯格的双因素理论运用于消费者动机分析,具有多重价值和意义。下列厂商给消费者提供的各种利益和价值中,不能使消费者对其产生满意感的因素是()。 A)商品具有的独特形象 B)商品具备了一定的基本功能 C)商品的外形美观 D)品牌良好的声誉 4. 消费者的绝对感觉阈限值越大,其感受性()。 A)越小 B)因人而异 C)越大 D)不受绝对阈限值的影响 5. 人的大脑对外部信息的知觉,包含相互联系的两种加工:数据驱动加工和概念驱动加工。对于数据驱动的加工形式,下列叙述不正确的是()。 A)数据驱动的加工通常是先对小的知觉单元进行分析 B)数据驱动的加工特别强调外界刺激的作用,强调外部输入信息对加工过程的驱动 C)数据驱动的加工又称为自上而下的加工,是从有关知觉对象的一般知识开始的 D)数据驱动的加工是从较低水平迈向较高水平的 6. 关于消费者的记忆,下列描述正确的是()。 A)消费者的记忆包括识记、再认或回忆三个基本环节 B)消费者的短时记忆是指信息保持在2分钟以内的记忆 C)消费者经过复述,可以将感觉记忆中的信息转移到长时记忆中 D)消费者的长时记忆与短时记忆相比,其容量是相当大的,甚至被认为是无限的 7. 下列关于消费者态度测量的观点,不正确的一项是()。 A)任务完成法属于常用的行为反应测量方法 B)生理反应测量法属于常用的行为反应测量方法 C)距离测量法属于常用的行为反应测量方法 D)消费者态度中的情感成分一般用语意差别量表来进行测量 8. 如果一个消费者的教条性倾向较小,他会()。 A)对不熟悉的事物持开放立场 B)更愿意选择已经成名的产品 C)更容易接受带有“权威诉求”的新产品广告 D)对陌生事物非常不安并怀有戒心 9. 消费者对于文化的学习有两种类型,其中文化移入()。 A)指学习外来新文化 B)指学习本民族的文化 C)保持了民族文化的延续 D)形成了独特的民族个性10. 科尔曼社会地位指数法中,采用的测量指标包括()。 A)社会互动 B)价值取向 C)个人业绩 D)居住的区域

相关文档
最新文档