全局的一个问题?

Sylix 2004-07-26 06:50:14
象memcpy等这样的函数好象并没有考虑多线程同步的问题?
不知同时有多个线程访问memcpy等这样的函数会有什么情况?
...全文
182 11 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
11 条回复
切换为时间正序
请发表友善的回复…
发表回复
zjxiaoyu 2004-07-28
  • 打赏
  • 举报
回复
是个问题。
不过windows有2个库,一个是单线程的,一个是多线程的库。最后链接的时候不一样。。
Sylix 2004-07-28
  • 打赏
  • 举报
回复
to wanamaker()

函数的返回值不会受多线程的影响, 不对吧.
peter9606 2004-07-27
  • 打赏
  • 举报
回复
mark
groock 2004-07-27
  • 打赏
  • 举报
回复
那个可能是编写可重入代码的问题了
wanamaker 2004-07-27
  • 打赏
  • 举报
回复
to Sylix(Sylix) :函数有返回值, 当然有写操作, 不知自己写的函数是不是要考虑同步?

函数的返回值通常都是由寄存器(eax)返回的,而在cpu切换thread时当前寄存器将保存下来,
所以,函数的返回值不会受多线程的影响,不知对否?
Sylix 2004-07-27
  • 打赏
  • 举报
回复
Sylix 2004-07-27
  • 打赏
  • 举报
回复
to lbaby(自尊啊,我可怜的自尊),
访问的函数代码可以共享,也可以各自有一个副本
再一个,每次的访问只是一个读操作,即使访问的是共享的函数代码,也不用加锁.


访问的如memcpy, 可以编译码为这些标准函数做了处理, 如VC编译器有这方面的多线程选项,
不知是不是?

函数有返回值, 当然有写操作, 不知自己写的函数是不是要考虑同步?
renheihei 2004-07-26
  • 打赏
  • 举报
回复
用lock(),unlock()?
freefalcon 2004-07-26
  • 打赏
  • 举报
回复
记得在哪里看到过,系统能够保证malloc在多线程下正确运行

我们编过、用过这么多程序,没有人说需要对malloc加锁吧,它们不都运行得好好的
lbaby 2004-07-26
  • 打赏
  • 举报
回复
如果你说的是访问同一部分的数据的话,
刚写的部分要加锁,这是程序员的责任
lbaby 2004-07-26
  • 打赏
  • 举报
回复
?
呵呵,访问的函数代码可以共享,也可以各自有一个副本
再一个,每次的访问只是一个读操作,即使访问的是共享的函数代码,也不用加锁

70,020

社区成员

发帖
与我相关
我的任务
社区描述
C语言相关问题讨论
社区管理员
  • C语言
  • 花神庙码农
  • 架构师李肯
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧