Ⅰ 如何在 android 中執行 C++ 的 main 函數
聲明是在編譯階段做檢查的。告訴編譯器這個函數的返回值參數等信息激輪。然後調用實在main()函數中進行,然後會檢旁銷查是否明啟信和聲明過的匹配
Ⅱ android main.xml在android中怎麼運行
main.xml必須在res/layout目錄下賣梁創建。
運行方式:笑圓
創建Activity 並重寫onCreate方法。
在onCreate方法中載入main.xml
setContentView(R.layout.main);即可
以下中升運為完整代碼:
public class MainActivity extends Activity{
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
}
Ⅲ androidstudio運行只運行mainactivity.xml
解決方法在gradle.xml 裡面添沒漏加
<option name="delegatedBuild" value="false" /枯山爛>
添加之後再次運行會出現新錯誤
錯誤的意思是activity沒有設置android:exported,但是我實唯李際是有的具體原因也不太清楚,去掉androidTest部分就好了。
Ⅳ android項目文件中不能有main函數嗎
可以有main函數游咐旁,簡源只是android中把它當成一個普通的函數,有別神橡於java程序中把main當為程序主入口。
Ⅳ Android主函數怎麼看,Android studio 運行main 函數的方法
標題Gradle構轎納建問題
切換到Project工程下.idea/gradle.xml添加屬性
圖例
寫出main函兆敬數,右擊選擇builder
運閉猜沒行結果:
Ⅵ Android 啟動流程
makeApplication創建application中會執行attachBaseContext(context);
installContentProviders第一個參數context,是從上面傳遞下來的app,也就是application。
遍歷providers列表,初始化每一個provider,都是用application的context。構造出ContentProvider然後執行attachInfo() 方法,attachInfo()執行完畢會執行onCreate()。
最後再mInstrumentation.callApplicationOnCreate(app);執行Application的OnCreate方法。
總結
從流程上來看,符合日誌列印的流程Application#attachBaseContext() → ContentProvider#attachInfo() → ContentProvider#onCreate() → Application#onCreate()
ContentProvider持有的Context也是application,具備給SDK初始化使用。
這時候第一進程是zygote。zygote英文是受精卵的意思。android系統的所有進程都是由zygote進程fork而來。zygote最先啟動的第一個進程是鼎鼎大名的SystemServer進程。這個進程包含了我們常說的三個大神級系統服務,分別是ActivityManagerService,WindowManagerService以及PackegeManagerService。
http://androidxref.com/6.0.0_r1/xref/frameworks/base/core/java/android/app/ActivityThread.java
進程入口在ActivityThread這個類的main()方法,這個main方法類似C語言的mian方法,是一個程序入口。
這個方法會接著調用ActivityManagerNatvie(一個單例類,可以獲取ActivityManagerService的實例)的getDeafault()返回ActivityManagerService實例。
ApplicationThread是ActivityThread的內部類,他是App和系統跨進程交互的入口,它的實現類在客戶端進程。
獲得了正在Binder通信的客戶端的當前線程的id,然後和ApplicationThread對象作為參數傳入到AMS的attachApplicationLocked。
thread是ApplicationThreadProxy的對象引用,它是代理對象,先調用ApplicationThreadProxy的bindApplication方法,接著在這個方法中又調用ApplicationThreadNative的函數onTransact,然後函數onTransact中根據code找到對應的case,最終會調用ApplicationThread的bindApplication方法。
在這里,bindApplication方法通過向ActivityThread的消息隊列發送BIND_APPLICATION消息
消息的處理調用handleBindApplication方法,handleBindApplication方法比較重要的是會調用如下方法
在執行完bindApplication()之後進入ActivityStackSupervisor.attachApplicationLocked(),這樣我們整個應用進程已經啟動起來了。開始activity的啟動邏輯了。
這個類是一個AMS的一個棧管理類,裡面存儲著ActivityStack的集合。在這個方法,會遍歷各個ActivityStack,找到前台棧,找到裡面的TopActivity。然後比較 傳進來的ProcessRecord.processName和UID是否個和opActivity對用的ActivityRecord裡面的一致。如果一致,就調用ActivityStackSupervisor.realStartAcvitiyLocked(ProcessRecord,ActivityRecord)方法。
這個方法會調用傳過來的ApplicationThread實例的ScheelLaunchActivity(包括ActivityRecord)方法,所以真正執行的是ActivityThread中的scheleLaunchActivity
這個方法是跨進程的,會把ActivityRecord同步到App進程的ActivityRecordClient數據結構,用來後面構造Application和Activity等。
ActivityThread接收到SystemServer進程的消息之後會通過其內部的Handler對象分發消息,經過一系列的分發之後調用了ActivityThread的handleLaunchActivity方法:
接著調用PerformLaunchActivity方法和HandleLaunchActivtiy()方法。performLauncherActivity,看名字應該就是執行Activity的啟動操作了
1.這個方法主要是構造Application和通過mInstrumention.newActivity()構造Activity。
這個方法會初始化一個Window,以後詳細講,人格視圖都是附在一個window的docorView上,然後由WMS.addView顯示。
這個方法會調用Actiity的resume()方法,並且在makrVisible()裡面調用WMS.addView(window),這個windows裡面的docorView的contentView就是onCreate()裡面setContentView(int layout)設置的contentView。
注意關於WMS.addView(window),這個系統服務,我們下次再講,裡面有一個類RootViewImpl,這個類負責管理我們contentView視圖樹的逐級繪制。
原文鏈接
https://www.cnblogs.com/mingfeng002/p/10330414.html
https://blog.csdn.net/ZZB_Bin/article/details/125209192
Ⅶ android直接運行java文件main方法,報錯
1)右鍵入口類(含有Main方法的)==>Run
Configurations==>雙擊(Java
Application)==>New==>
(2)在標簽Main里選好相應行叢陸鄭帶的ProjectName和要運行ClassName,
(3)選標簽ClassPath中的Bootstrap
Entries ,再從右邊點Advance==>Add Library==>JRE System Library,完成,然後將JRE System
Library 點中再檔頃點Up按鈕,OK了
Ⅷ Android studio怎麼新建並運行普通的java類,就是那種帶main方法的
如果不添加配置直接在Android的項目中創建一個帶有main函數的類是無法當櫻虧做Java
Application運行的。
當在寫Android的應用的時候需要測試一下和Android本身無關的代碼,只是脊旦神純Java代碼而已,完全用不著開啟Android模擬器,如果想直接運行Java代碼,是會報錯。
後來成這么個錯:
Error
occurred
ring
initialization
of
VM
java/lang/NoClassDefFoundError:
java/lang/ref/FinalReference
下面給出解決方遲配案,其實很簡單:總結一句話就是,導入jre!
Eclipse中,你要運行的類上右鍵,Run
as
—->Runconfigurations…
然後看下圖:
按著
上圖
1
—2—-3的步驟操作,在步驟2後選擇Bootstrap
Entries
—–>3然後下圖:
然後點擊OK
—->選擇JRE
System
Library
—->Next
—–>Finish
下面這步很重要:
在下圖中選擇
你剛剛導入的
JRE
System
Library
點擊右側的UP按鈕,把它弄到第一個位置,這樣才行!最終結果如下圖
Applay
或者Run
Ⅸ 安卓應用怎麼運行的java中是先運行main函數,安卓中是先運行哪個函數別說運行在虛擬機裡面,
這個要看工程里的AndroidManifest.xml文件,旁嫌這里有注冊各種activity,而哪個註明了
<actionandroid:name="android.intent.action.MAIN"/>
就代表先啟動這個activity, 後面也有標志MAIN , 可以想成與java的main函數類似
例子如下:
<activity
android:name=".SettingsActivity"
android:label="@string/app_name">
<intent-filter>
<actionandroid:name="android.intent.action.MAIN"/>
<categoryandroid:name="android.intent.category.LAUNCHER"/>
</intent-filter>
</activity>
(這個SettingsActivity會首先啟動,下面的<category android:name="android.intent.category.LAUNCHER" /> 代表笑雀安裝完之後 軟體自動啟動,若沒有碰啟早這句話,軟體安裝完不會自動啟動,要你自己去點擊)
Ⅹ Android Studio run main()方法報錯
* What went wrong:
A problem occurred configuring project ':app'.
> Could not create task ':app: **** .main()'.
> SourceSet with name 'main' not found.
<GradleProjectSettings>標簽節點下添加一行
<option name="delegatedBuild" value="false" />
保存,即可使用run ** with main() 和 debug ** with main()
有人在上面蓋了gradle.xml之後運行main方法又報如下錯尺缺誤:
Error running '猜運 ** ': Command line is too long. Shorten command line for ** or also for Application default configuration.
修改.idea下的陵兆辯workspace.xml
找到<component name="PropertiesComponent">標簽節點並在之下添加一行
<property name="dynamic.classpath" value="true" />
然後保存即可。