C# 新建线程递归调用包含回调函数,怎么判断递归调用结束,获取返回值

如题,在新建线程中递归调用函数,一次结果的返回值由回调函数获取,我想根据线程的状态判断
递归调用是否结束,并获取正确返回值,但是一次执行后线程状态就变成了Stopped了,回调
函数还在继续执行,用什么标记回调函数执行结束呢?

c#

1个回答

你是怎么递归的,在递归函数内部又启了新的线程没有,把你的代码贴出来看下。

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
递归函数和函数调用的值问题

函数递归调用时保留上一次调用的值 但别的函数每次调用递归函数时初值为0

JAVA函数递归调用问题

/** 计算5! */ public class Function { static int i=5,sum=1; public static void print(){ sum=sum*i; i--; if(i>1) {print(); System.out.println("****** "+sum); } else System.out.println("sum="+sum); } public static void main(String[] args) { // TODO Auto-generated method stub print(); } 输出结果: sum=120 ****** 120 ****** 120 ****** 120 在结果输出后为何继续多次执行 System.out.println("****** "+sum);

C#递归算法实现!!!

一列数的规则如下:1、1、2、3、5、8、13、21、34......求第30位数是多少,用递归算法实现。

一个函数中两次递归调用自己,是一个怎么样的流程啊

例如: 为了方便,我简写一下 fun() { if() { xxx; } else { fun() fun() xxx; xxx: } } main() { xxx; fun(); xxx: return 0; } 大概这个框架,重点是二次递归不太懂理解,劳烦大神求讲解流程

求大神指导调用递归函数中的栈是怎么运行的

回溯法与树的遍历 回溯法:其求解过程实质是一个先序遍历一棵“状态树”的过程,只是这棵树不是遍历前预先建立的,而 是隐含在遍历过程中。 题目描述:求含n个元素的集合的幂集。 例:A={1,2,3},则A的幂集为{{1,2,3},{1,2},{1, 3},{2,3},{1},{2},{3},{}} 解题思路:求幂集的过程可看成是依次对集合A中的元素进行取或舍的过程。 1. 选择合适的数据结构——假设以线性表表示集合。 2. 树根结点表示幂集元素的初始状态(空集),叶子结点表示终结状态(幂集的元素),第i层表 示已对前i-1个元素进行了取舍的当前状态 编码: #include "stdafx.h" #include< iostream.h> #define N 10 typedef struct { int data[N]; int length; }SqList; //输出线性表B void Output(SqList& B) { int i; if(B.length ==0) cout<<"空集\n"; else { for(i=0;i<B.length ;i++) cout<<B.data [i]<<"\t"; cout<<endl; } } //求集合A的幂集,其中B为暂存幂集元素的线性表,i表示从第i个元素开始取舍,当 //i>n时则求得幂集的一个元素,并输出 void GetPowerSet(int i,SqList A,SqList& B) { int x,k,j; if(i>=A.length ) Output(B); else { x=A.data [i]; k=B.length ; B.data [k]=x; B.length ++; GetPowerSet(i+1,A,B); B.length --; GetPowerSet(i+1,A,B); } } A={1,2,3},则A的幂集为{{1,2,3},{1,2},{1, 3},{2,3},{1},{2},{3},{}} int main(int argc, char* argv[]) { SqList A,B; int i; cout<<"输入A集合的元素个数\n"; cin>>A.length ; cout<<"输入A集合的元素\n"; for(i=0;i<A.length ;i++) cin>>A.data [i]; B.length =0; GetPowerSet(0,A,B); return 0; } 我不解的是第一次执行完output函数后该怎么办,如果继续执行下面的语句,即b.length--和递归函数,那第二次输出的集合显然与答案不符,求大神指点,我记得老师说过还有什么出栈的过程,求指导

异常机制与递归调用

请问:如果某个函数出现异常,能否在捕获某个异常之后再递归的调用这个函数呢? public Object invokeHook() { try { 。。。 } catch (ConnectException e) { System.out.println(e.getMessage()); }catch (NullPointerException e5) { System.out.println("目标为空,寻找下个目标"); return invokeHook(); } catch (CommunicationException e1) { System.out.println("连接超时,寻找下个目标"); return invokeHook(); } } catch (Exception e2) { }

c#winfrom treeview递归问题

![图片说明](https://img-ask.csdn.net/upload/201803/14/1521015427_734766.png) 我遇到了一个问题,需要将一张表里的数据,弄成treeview形式, sql 文件是这个 https://www.wenwenlove.cn/my/script.sql ,我放到我服务器上了 这个表里目前有4级结构,分别是1,2,3,4,后面可能有5,或则。。。 能帮我解决的万分感谢

Java语言采用递归函数的调用的方式编写一个函数,判断输入的字符串是不是一个回文串

Java语言采用递归函数的调用的方式编写一个函数,判断输入的字符串是不是一个回文串

怎么判断全部线程结束

![图片说明](https://img-ask.csdn.net/upload/201707/25/1500967510_53952.png) ![图片说明](https://img-ask.csdn.net/upload/201707/25/1500967523_347277.png) 我把一个list分为了10份,开启了10个线程同时查询,把结果add到了sorankgridlist里, 现在我想在全部线程结束后,把sorankgridlist存进数据库,该怎么写,求教

不太会这种递归,希望指导下小白整个递归递归过程、递归调用树,伪代码如下,算法导论第三版上的

CUT-ROD(p,n) if n==0 return 0 q=-inf(无穷) for i=1 to n q=max(q,p[i]+CUT-ROD(p,n-1)) return q

想用函数调用的方法排序数组,提示“如递归所有控件路径,函数将导致运行时堆栈溢出”

注释部分的“起泡法”是没问题的,但是换成调用函数的方法后就不对了,是哪里出错了? ``` #include<stdio.h> int main() { int sort(int a[10]); int i[10]; printf("%d",sort(i)); } int sort(int a[10]) { /* int b[10]; int m,n,t; printf("input 10 numbers:\n"); for(m=0;m<10;m++) scanf("%d",&b[10]); printf("\n"); for(n=0;n<9;n++) for(m=0;m<9-n;m++) if(b[m]>b[m+1]) {t=b[m];b[m]=b[m+1];b[m+1]=t;} printf("the sorted numbers:\n"); for(m=0;m<10;m++) printf("%d",b[m]); printf("\n"); */ return sort(b); } ```

c语言递归调用中要不要return结果都一样

以下来自啊哈算法这本书,用于输出数字全排列,发现注释掉的return属于多余。这是怎么回事啊??? #include <stdio.h> int a[10],book[10],n; void dfs(int step) { int i,j; if (step == n+1) { for ( i = 1; i<=n; i++ ) printf("%d",a[i]); //return; } for (i = 1; i<=n; i++) { if (book[i]==0) { a[step]=i; book[i]=1; dfs(step+1); book[i]=0; } } //return; } int main() { scanf("%d",&n); dfs(1); getchar(); getchar(); return 0; }

python分别用递归函数和非递归函数的形式实现:输入两个1至10000之间的正整数,输出这两个数之间的所有Fibonacci数列?

分别用递归函数和非递归函数的形式实现:输入两个1至10000之间的正整数,输出这两个数之间的所有Fibonacci数列?

递归调用时,如果跳出循环标示放在方法内是否无法跳出循环?

递归调用时,如果跳出循环标示放在方法内是否无法跳出循环? 所以跳出递归循环应该如何操作?

怎么在递归调用中让其中一部分代码只运行一次

怎么在递归调用中让其中一部分代码只运行一次。 怎么在递归调用中让其中一部分代码只运行一次

归并排序递归调用的流程理解

``` static void mergearray(int[] a , int first , int mid , int last , int temp[]){ System.out.println(first+"-"+ mid +"-"+last); int i = first , j = mid+1; int m = mid , n = last; int k = 0 ; while(i<=m && j <= n){ if(a[i] <= a[j]){ temp[k++] = a[i++]; }else{ temp[k++] = a[j++]; } } while(i <= m){ temp[k++] = a[i++]; } while(j <= n ){ temp[k++] = a[j++]; } for( i = 0 ; i < k ; i++){ a[first+ i] = temp[i]; } } static int count = 0; static void mergesort(int a[] , int first , int last , int temp[]){ if(first < last){ System.out.println( first + " - " + last); int mid = (first + last) / 2; mergesort(a, first, mid, temp); mergesort(a, mid+1, last, temp); mergearray(a, first, mid, last, temp); } } public static void main(String[] args) { int[] arr = {10,4,6,3,8,2,5,7}; int[] temp = new int[arr.length]; mergesort(arr, 0, arr.length-1, temp); for (int i : temp) { System.out.println(i); } } ``` 这是一段归并排序,下面的代码, 其中对数组左边拆解,右边拆解,然后排序那段的执行流程不太理解。 当递归调用左边拆解结束后如何继续执行?递归是用栈来实现,如何用栈来理解这段代码? static void mergesort(int a[] , int first , int last , int temp[]){ if(first < last){ System.out.println( first + " - " + last); int mid = (first + last) / 2; mergesort(a, first, mid, temp); mergesort(a, mid+1, last, temp); mergearray(a, first, mid, last, temp); } }

用递归函数调用对数组进行排序?

<div class="post-text" itemprop="text"> <p>I need the following array in alphabetical order (at all levels), but <code>asort</code> doesn't seem to work because I have a recursive call in my function (or so I think); it only partially sorts my array, so I'll have chunks of it that are alphabetized, but they'll be out of order.</p> <p>Help!</p> <p>Ex. Directory Listing:</p> <pre><code>apartments.html js/ application.js jquery.js something.js css/ reset.css master.css preview.html ab_restaurant_at_the_end_of_the_universe.jpg </code></pre> <p>Desired output:</p> <pre><code>array() { [0] =&gt; string() "ab_restaurant_at_the_end_of_the_universe.jpg" [1] =&gt; string() "apartments.html" ["css"] =&gt; array() { [0] =&gt; string() "master.css" [1] =&gt; string() "reset.css" } ["js"] =&gt; array() { [0] =&gt; string() "application.js" [1] =&gt; string() "jquery.js" [2] =&gt; string() "something.js" } [2] =&gt; string() "preview.html" } </code></pre> <hr> <pre><code>function directory_list($directory) { $files = array(); if (is_dir($directory)) { if ($curr_dir = opendir($directory)) { while (false !== ($file = readdir($curr_dir))) { if ($file != "." &amp;&amp; $file != ".." &amp;&amp; $file != "apartment" &amp;&amp; $file != "blog") { if (is_dir($directory. "/" . $file)) { $files[$file] = directory_list($directory. "/" . $file); } else { $files[] = $file; } } } closedir($curr_dir); } } //asort($files); &lt;-- doesn't work; sorts, but interrupts itself because of self-referencing call above (I think) return $files; } </code></pre> </div>

如何递归调用Ajax函数

<div class="post-text" itemprop="text"> <p>I want to know how to call Ajax function Recursively. My ajax code is like this,</p> <pre><code>&lt;html&gt; &lt;head&gt; &lt;script type="text/javascript" src="jquery.js"&gt;&lt;/script&gt; &lt;script type="text/javascript"&gt; var step='1'; $.ajax ( { url: 'test1.php', data: {step: step}, success: function(output) { step=eval(output); alert(step); } } ); &lt;/script&gt; &lt;/head&gt; &lt;/html&gt; </code></pre> <p>And php code is like this</p> <pre><code>&lt;?php function writeName() { echo "step=2"; } function ReadName() { echo "In Read Name Function"; } if(isset($_REQUEST['step']) &amp;&amp; !empty($_REQUEST['step'])) { $step = $_REQUEST['step']; switch($step) { case '1' : writeName(); break; case '2' : ReadName(); break; default : echo "Empty String"; } } ?&gt; </code></pre> <p>first time this function is get called with value of step variable equal to 1 and Function Write name modified it as 2. Now i want to call this Ajax function with Step variable value equal to 2. So that 2nd php function gets called.</p> </div>

Java中的递归方法,是那个对象调用的

当递归方法在其他类中的时候,需要创建该类对象才能调用这个递归方法,那么递归调用自己的时候,需不需要写,this。我发现不写也没什么问题,可是当这个方法第二次调用的时候是那个对象调用的呢 ,还是第一次那个调用递归方法的对象吗,

在中国程序员是青春饭吗?

今年,我也32了 ,为了不给大家误导,咨询了猎头、圈内好友,以及年过35岁的几位老程序员……舍了老脸去揭人家伤疤……希望能给大家以帮助,记得帮我点赞哦。 目录: 你以为的人生 一次又一次的伤害 猎头界的真相 如何应对互联网行业的「中年危机」 一、你以为的人生 刚入行时,拿着傲人的工资,想着好好干,以为我们的人生是这样的: 等真到了那一天,你会发现,你的人生很可能是这样的: ...

程序员请照顾好自己,周末病魔差点一套带走我。

程序员在一个周末的时间,得了重病,差点当场去世,还好及时挽救回来了。

Java基础知识面试题(2020最新版)

文章目录Java概述何为编程什么是Javajdk1.5之后的三大版本JVM、JRE和JDK的关系什么是跨平台性?原理是什么Java语言有哪些特点什么是字节码?采用字节码的最大好处是什么什么是Java程序的主类?应用程序和小程序的主类有何不同?Java应用程序与小程序之间有那些差别?Java和C++的区别Oracle JDK 和 OpenJDK 的对比基础语法数据类型Java有哪些数据类型switc...

技术大佬:我去,你写的 switch 语句也太老土了吧

昨天早上通过远程的方式 review 了两名新来同事的代码,大部分代码都写得很漂亮,严谨的同时注释也很到位,这令我非常满意。但当我看到他们当中有一个人写的 switch 语句时,还是忍不住破口大骂:“我擦,小王,你丫写的 switch 语句也太老土了吧!” 来看看小王写的代码吧,看完不要骂我装逼啊。 private static String createPlayer(PlayerTypes p...

和黑客斗争的 6 天!

互联网公司工作,很难避免不和黑客们打交道,我呆过的两家互联网公司,几乎每月每天每分钟都有黑客在公司网站上扫描。有的是寻找 Sql 注入的缺口,有的是寻找线上服务器可能存在的漏洞,大部分都...

Intellij IDEA 实用插件安利

1. 前言从2020 年 JVM 生态报告解读 可以看出Intellij IDEA 目前已经稳坐 Java IDE 头把交椅。而且统计得出付费用户已经超过了八成(国外统计)。IDEA 的...

女程序员,为什么比男程序员少???

昨天看到一档综艺节目,讨论了两个话题:(1)中国学生的数学成绩,平均下来看,会比国外好?为什么?(2)男生的数学成绩,平均下来看,会比女生好?为什么?同时,我又联想到了一个技术圈经常讨...

总结了 150 余个神奇网站,你不来瞅瞅吗?

原博客再更新,可能就没了,之后将持续更新本篇博客。

副业收入是我做程序媛的3倍,工作外的B面人生是怎样的?

提到“程序员”,多数人脑海里首先想到的大约是:为人木讷、薪水超高、工作枯燥…… 然而,当离开工作岗位,撕去层层标签,脱下“程序员”这身外套,有的人生动又有趣,马上展现出了完全不同的A/B面人生! 不论是简单的爱好,还是正经的副业,他们都干得同样出色。偶尔,还能和程序员的特质结合,产生奇妙的“化学反应”。 @Charlotte:平日素颜示人,周末美妆博主 大家都以为程序媛也个个不修边幅,但我们也许...

MySQL数据库面试题(2020最新版)

文章目录数据库基础知识为什么要使用数据库什么是SQL?什么是MySQL?数据库三大范式是什么mysql有关权限的表都有哪几个MySQL的binlog有有几种录入格式?分别有什么区别?数据类型mysql有哪些数据类型引擎MySQL存储引擎MyISAM与InnoDB区别MyISAM索引与InnoDB索引的区别?InnoDB引擎的4大特性存储引擎选择索引什么是索引?索引有哪些优缺点?索引使用场景(重点)...

如果你是老板,你会不会踢了这样的员工?

有个好朋友ZS,是技术总监,昨天问我:“有一个老下属,跟了我很多年,做事勤勤恳恳,主动性也很好。但随着公司的发展,他的进步速度,跟不上团队的步伐了,有点...

我入职阿里后,才知道原来简历这么写

私下里,有不少读者问我:“二哥,如何才能写出一份专业的技术简历呢?我总感觉自己写的简历太烂了,所以投了无数份,都石沉大海了。”说实话,我自己好多年没有写过简历了,但我认识的一个同行,他在阿里,给我说了一些他当年写简历的方法论,我感觉太牛逼了,实在是忍不住,就分享了出来,希望能够帮助到你。 01、简历的本质 作为简历的撰写者,你必须要搞清楚一点,简历的本质是什么,它就是为了来销售你的价值主张的。往深...

魂迁光刻,梦绕芯片,中芯国际终获ASML大型光刻机

据羊城晚报报道,近日中芯国际从荷兰进口的一台大型光刻机,顺利通过深圳出口加工区场站两道闸口进入厂区,中芯国际发表公告称该光刻机并非此前盛传的EUV光刻机,主要用于企业复工复产后的生产线扩容。 我们知道EUV主要用于7nm及以下制程的芯片制造,光刻机作为集成电路制造中最关键的设备,对芯片制作工艺有着决定性的影响,被誉为“超精密制造技术皇冠上的明珠”,根据之前中芯国际的公报,目...

优雅的替换if-else语句

场景 日常开发,if-else语句写的不少吧??当逻辑分支非常多的时候,if-else套了一层又一层,虽然业务功能倒是实现了,但是看起来是真的很不优雅,尤其是对于我这种有强迫症的程序"猿",看到这么多if-else,脑袋瓜子就嗡嗡的,总想着解锁新姿势:干掉过多的if-else!!!本文将介绍三板斧手段: 优先判断条件,条件不满足的,逻辑及时中断返回; 采用策略模式+工厂模式; 结合注解,锦...

离职半年了,老东家又发 offer,回不回?

有小伙伴问松哥这个问题,他在上海某公司,在离职了几个月后,前公司的领导联系到他,希望他能够返聘回去,他很纠结要不要回去? 俗话说好马不吃回头草,但是这个小伙伴既然感到纠结了,我觉得至少说明了两个问题:1.曾经的公司还不错;2.现在的日子也不是很如意。否则应该就不会纠结了。 老实说,松哥之前也有过类似的经历,今天就来和小伙伴们聊聊回头草到底吃不吃。 首先一个基本观点,就是离职了也没必要和老东家弄的苦...

2020阿里全球数学大赛:3万名高手、4道题、2天2夜未交卷

阿里巴巴全球数学竞赛( Alibaba Global Mathematics Competition)由马云发起,由中国科学技术协会、阿里巴巴基金会、阿里巴巴达摩院共同举办。大赛不设报名门槛,全世界爱好数学的人都可参与,不论是否出身数学专业、是否投身数学研究。 2020年阿里巴巴达摩院邀请北京大学、剑桥大学、浙江大学等高校的顶尖数学教师组建了出题组。中科院院士、美国艺术与科学院院士、北京国际数学...

为什么你不想学习?只想玩?人是如何一步一步废掉的

不知道是不是只有我这样子,还是你们也有过类似的经历。 上学的时候总有很多光辉历史,学年名列前茅,或者单科目大佬,但是虽然慢慢地长大了,你开始懈怠了,开始废掉了。。。 什么?你说不知道具体的情况是怎么样的? 我来告诉你: 你常常潜意识里或者心理觉得,自己真正的生活或者奋斗还没有开始。总是幻想着自己还拥有大把时间,还有无限的可能,自己还能逆风翻盘,只不是自己还没开始罢了,自己以后肯定会变得特别厉害...

男生更看重女生的身材脸蛋,还是思想?

往往,我们看不进去大段大段的逻辑。深刻的哲理,往往短而精悍,一阵见血。问:产品经理挺漂亮的,有点心动,但不知道合不合得来。男生更看重女生的身材脸蛋,还是...

为什么程序员做外包会被瞧不起?

二哥,有个事想询问下您的意见,您觉得应届生值得去外包吗?公司虽然挺大的,中xx,但待遇感觉挺低,马上要报到,挺纠结的。

当HR压你价,说你只值7K,你该怎么回答?

当HR压你价,说你只值7K时,你可以流畅地回答,记住,是流畅,不能犹豫。 礼貌地说:“7K是吗?了解了。嗯~其实我对贵司的面试官印象很好。只不过,现在我的手头上已经有一份11K的offer。来面试,主要也是自己对贵司挺有兴趣的,所以过来看看……”(未完) 这段话主要是陪HR互诈的同时,从公司兴趣,公司职员印象上,都给予对方正面的肯定,既能提升HR的好感度,又能让谈判气氛融洽,为后面的发挥留足空间。...

面试:第十六章:Java中级开发

HashMap底层实现原理,红黑树,B+树,B树的结构原理 Spring的AOP和IOC是什么?它们常见的使用场景有哪些?Spring事务,事务的属性,传播行为,数据库隔离级别 Spring和SpringMVC,MyBatis以及SpringBoot的注解分别有哪些?SpringMVC的工作原理,SpringBoot框架的优点,MyBatis框架的优点 SpringCould组件有哪些,他们...

面试阿里p7,被按在地上摩擦,鬼知道我经历了什么?

面试阿里p7被问到的问题(当时我只知道第一个):@Conditional是做什么的?@Conditional多个条件是什么逻辑关系?条件判断在什么时候执...

Python爬虫,高清美图我全都要(彼岸桌面壁纸)

爬取彼岸桌面网站较为简单,用到了requests、lxml、Beautiful Soup4

差点跪了...

最近微信又搞出了一个大利器,甚至都上了热搜,当然消息最敏捷的自媒体人,纷纷都开通了自己的视频号。01 视频号是什么呢?视频号是微信体系内的短视频,它不同...

面试了一个 31 岁程序员,让我有所触动,30岁以上的程序员该何去何从?

最近面试了一个31岁8年经验的程序猿,让我有点感慨,大龄程序猿该何去何从。

Vue回炉重造之router路由(更新中)

你好,我是Vam的金豆之路,可以叫我豆哥。2019年年度博客之星、技术领域博客专家。主要领域:前端开发。我的微信是 maomin9761,有什么疑问可以加我哦,自己创建了一个微信技术交流群,可以加我邀请你一起交流学习。最后自己也创建了一个微信公众号,里面的文章是我自己精挑细选的文章,主要介绍各种IT新技术。欢迎关注哦,微信搜索:臻美IT,等你来。 欢迎阅读本博文,本博文主要讲述【】,文字通...

大三实习生,字节跳动面经分享,已拿Offer

说实话,自己的算法,我一个不会,太难了吧

程序员垃圾简历长什么样?

已经连续五年参加大厂校招、社招的技术面试工作,简历看的不下于万份 这篇文章会用实例告诉你,什么是差的程序员简历! 疫情快要结束了,各个公司也都开始春招了,作为即将红遍大江南北的新晋UP主,那当然要为小伙伴们做点事(手动狗头)。 就在公众号里公开征简历,义务帮大家看,并一一点评。《启舰:春招在即,义务帮大家看看简历吧》 一石激起千层浪,三天收到两百多封简历。 花光了两个星期的所有空闲时...

Java岗开发3年,公司临时抽查算法,离职后这几题我记一辈子

前几天我们公司做了一件蠢事,非常非常愚蠢的事情。我原以为从学校出来之后,除了找工作有测试外,不会有任何与考试有关的事儿。 但是,天有不测风云,公司技术总监、人事总监两位大佬突然降临到我们事业线,叫上我老大,给我们组织了一场别开生面的“考试”。 那是一个风和日丽的下午,我翘着二郎腿,左手端着一杯卡布奇诺,右手抓着我的罗技鼠标,滚动着轮轴,穿梭在头条热点之间。 “淡黄的长裙~蓬松的头发...

大胆预测下未来5年的Web开发

在2019年的ReactiveConf 上,《Elm in Action》的作者Richard Feldman对未来5年Web开发的发展做了预测,很有意思,分享给大家。如果你有机会从头...

立即提问
相关内容推荐