C#与JAVA线程间同步实现比较

简介:

    C#与JAVA二者是对标下的产物,无论设计思想还是语法格式都非常相似,相恨相杀一路走来各自拥有一群拥趸,思想理念都传承自面向对象的C++,不过要说血缘关系还是C#更近一些,保留了比较多的C++的影子让人多了几分熟悉的味道,IDE上VS也比MyEclipse用户体验好很多,不用idea去比明显偏心眼VS,好吧你说对了。

    C#和C++都提供了良好完备的线程间同步机制,C#保留了更多的C++烙印,JAVA则干练的多让开发者省心不少。过去在面向过程的编程思路上,锁的操作基本都是基于语句的,锁的范围从加锁开始到解锁终止,代码编写的过程中各种小心锁区间的逻辑处理,一个异常就可能导致万劫不复的死锁。C#和JAVA把更多面向底层的锁操作封装起来,通过赋予对象实例一个修饰词的方法,极大的简化了步骤,当然也可以对语句块加锁,省略了显式的繁琐操作。


C# JAVA C++
获取

Monitor.Enter(object);

Monitor.TryEnter(object);


休眠 Monitor.Wait(object); final void wait();

pthread_cond_wait(_cond, _mutex);

pthread_cond_timewait(_cond, _mutex, _abstime);
唤醒

Monitor.Pulse(object);

Monitor.PulseAll(object);

final void notify();

final void notifyAll();

pthread_cond_signal(_cond);

pthread_cond_broadcast (_cond);
释放 Monitor.Exit(object);

    上表显示了C#和JAVA语言基于监视器的同步方法的函数,C#比JAVA多了对监视器的获取和释放操作,二者都提供休眠等待时间,唤醒操作都提供单播和多播两种方式,在明确被唤醒对象且预知其执行方法及结果的前提下建议单播方式唤醒,否则多播唤醒后再逐个投入睡眠导致的惊群上下文切换会造成比较大的系统开销。需要特别注意的地方是按照甲骨文的推荐把wait()方法放到一个循环中可以有效避免假唤醒(spurious wakeup)情况的发生,虽然Oralce强调这种情况发生的概率极小,其实意思是说:我可告诉你,不听是你的事情,出了问题别找我。表中用C++做陪衬说明是为了更好的比较这种机制的适用场景,那就是并不是简单的粗暴加锁解锁,而是有条件有尺度的以最小开销获取独占操作。

public void CSharpFunc(int v)
{
	Monitor.Enter(this);
	if (flag)
	{
		try
		{
			Monitor.Wait(this);
		}
		catch(SynchironizationLockException e)
		{
			Console.WriteLine(e);
		}
	}
	Console.Write("Value {0}", v);
	flag = true;
	Monitor.Pulse(this);
	Monitor.Exit(this);
}

synchronized void JavaFunc(int v) {
	while (!flag)
		try {
			wait();
		} catch(InterruptedException e) {
			System.out.println("InterruptedException caught");
		}
	System.out.println("Valuse: " + v);
	flag = false;
	notify();
}

    前几天出门体验了一次7号共享电单车,以为无桩的可以为所欲为骑行,结果冲了押金又充值,扫码开锁竟然要指定目的地,因为目的地周边没有停车场,只好骑到地铁站再换乘,这叫啥事呀,账上趴着充值剩余的金额,提不出来也不知道下次啥时候消费,有种上当受骗的感觉,有桩的共享出行交通工具都是反人类设计,改改吧。

相关文章
|
3天前
|
监控 Java
java异步判断线程池所有任务是否执行完
通过上述步骤,您可以在Java中实现异步判断线程池所有任务是否执行完毕。这种方法使用了 `CompletionService`来监控任务的完成情况,并通过一个独立线程异步检查所有任务的执行状态。这种设计不仅简洁高效,还能确保在大量任务处理时程序的稳定性和可维护性。希望本文能为您的开发工作提供实用的指导和帮助。
39 17
|
14天前
|
Java
Java—多线程实现生产消费者
本文介绍了多线程实现生产消费者模式的三个版本。Version1包含四个类:`Producer`(生产者)、`Consumer`(消费者)、`Resource`(公共资源)和`TestMain`(测试类)。通过`synchronized`和`wait/notify`机制控制线程同步,但存在多个生产者或消费者时可能出现多次生产和消费的问题。 Version2将`if`改为`while`,解决了多次生产和消费的问题,但仍可能因`notify()`随机唤醒线程而导致死锁。因此,引入了`notifyAll()`来唤醒所有等待线程,但这会带来性能问题。
Java—多线程实现生产消费者
|
16天前
|
安全 Java Kotlin
Java多线程——synchronized、volatile 保障可见性
Java多线程中,`synchronized` 和 `volatile` 关键字用于保障可见性。`synchronized` 保证原子性、可见性和有序性,通过锁机制确保线程安全;`volatile` 仅保证可见性和有序性,不保证原子性。代码示例展示了如何使用 `synchronized` 和 `volatile` 解决主线程无法感知子线程修改共享变量的问题。总结:`volatile` 确保不同线程对共享变量操作的可见性,使一个线程修改后,其他线程能立即看到最新值。
|
16天前
|
消息中间件 缓存 安全
Java多线程是什么
Java多线程简介:本文介绍了Java中常见的线程池类型,包括`newCachedThreadPool`(适用于短期异步任务)、`newFixedThreadPool`(适用于固定数量的长期任务)、`newScheduledThreadPool`(支持定时和周期性任务)以及`newSingleThreadExecutor`(保证任务顺序执行)。同时,文章还讲解了Java中的锁机制,如`synchronized`关键字、CAS操作及其实现方式,并详细描述了可重入锁`ReentrantLock`和读写锁`ReadWriteLock`的工作原理与应用场景。
|
16天前
|
安全 Java 编译器
深入理解Java中synchronized三种使用方式:助您写出线程安全的代码
`synchronized` 是 Java 中的关键字,用于实现线程同步,确保多个线程互斥访问共享资源。它通过内置的监视器锁机制,防止多个线程同时执行被 `synchronized` 修饰的方法或代码块。`synchronized` 可以修饰非静态方法、静态方法和代码块,分别锁定实例对象、类对象或指定的对象。其底层原理基于 JVM 的指令和对象的监视器,JDK 1.6 后引入了偏向锁、轻量级锁等优化措施,提高了性能。
42 3
|
16天前
|
存储 安全 Java
Java多线程编程秘籍:各种方案一网打尽,不要错过!
Java 中实现多线程的方式主要有四种:继承 Thread 类、实现 Runnable 接口、实现 Callable 接口和使用线程池。每种方式各有优缺点,适用于不同的场景。继承 Thread 类最简单,实现 Runnable 接口更灵活,Callable 接口支持返回结果,线程池则便于管理和复用线程。实际应用中可根据需求选择合适的方式。此外,还介绍了多线程相关的常见面试问题及答案,涵盖线程概念、线程安全、线程池等知识点。
99 2
|
24天前
|
安全 Java API
java如何请求接口然后终止某个线程
通过本文的介绍,您应该能够理解如何在Java中请求接口并根据返回结果终止某个线程。合理使用标志位或 `interrupt`方法可以确保线程的安全终止,而处理好网络请求中的各种异常情况,可以提高程序的稳定性和可靠性。
46 6
|
2月前
|
设计模式 Java 开发者
Java多线程编程的陷阱与解决方案####
本文深入探讨了Java多线程编程中常见的问题及其解决策略。通过分析竞态条件、死锁、活锁等典型场景,并结合代码示例和实用技巧,帮助开发者有效避免这些陷阱,提升并发程序的稳定性和性能。 ####
|
1月前
|
存储 监控 小程序
Java中的线程池优化实践####
本文深入探讨了Java中线程池的工作原理,分析了常见的线程池类型及其适用场景,并通过实际案例展示了如何根据应用需求进行线程池的优化配置。文章首先介绍了线程池的基本概念和核心参数,随后详细阐述了几种常见的线程池实现(如FixedThreadPool、CachedThreadPool、ScheduledThreadPool等)的特点及使用场景。接着,通过一个电商系统订单处理的实际案例,分析了线程池参数设置不当导致的性能问题,并提出了相应的优化策略。最终,总结了线程池优化的最佳实践,旨在帮助开发者更好地利用Java线程池提升应用性能和稳定性。 ####
|
2月前
|
缓存 Java 开发者
Java多线程编程的陷阱与最佳实践####
本文深入探讨了Java多线程编程中常见的陷阱,如竞态条件、死锁和内存一致性错误,并提供了实用的避免策略。通过分析典型错误案例,本文旨在帮助开发者更好地理解和掌握多线程环境下的编程技巧,从而提升并发程序的稳定性和性能。 ####